Error Codes
The UTAM compiler generates Java or JavaScript page objects from source JSON page objects. If the compiler encounters an error in a JSON page object, it emits an error code and an error message.
To combine all compilation errors into one report and throw an error at the end, set the interruptCompilerOnError
option to false
in the compiler configuration file. For information about the compiler configuration options, see:
Here's the list of error codes.
Error Code 7
This property isn't supported. For a list of supported page object properties, see the JSON Grammar.
Incorrect JSON example:
{
"methods": [
{
"name": "testNestedArgs",
"compose": [
{
"element": "self",
"apply": "unknownMethod",
"args": [
{
"value": "string",
"args": [
{
"value": "not allowed"
}
]
}
]
}
]
}
]
}
Error message:
error 7: method "testNestedArgs" statement "unknownMethod": property "args" is not supported
Error Code 8
This property isn't supported. The set of supported properties is listed in the error message.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"selector": { "css": "css" },
"type": "frame",
"nullable": true
}
]
}
Error message:
error 8: element "test": property "nullable" is not supported, supported are: name, public, selector, type
Error Code 9
A required property is missing.
Incorrect JSON example:
{
"elements": [
{
"name": "test"
}
]
}
Error message:
error 9: element "test": property "selector" is required
Error Code 10
This property isn't supported. An alternative property is suggested in the error message.
Incorrect JSON example:
{
"description": ""
}
Error message:
error 10: page object description: property "text" should be a non-empty string, instead found empty
Error Code 11
This array can't contain a member with an empty string.
Incorrect JSON example:
{
"profile": [
{
"name": [1]
}
]
}
Error message:
error 11: profile "name": array member should be a non-empty string, instead found number
Error Code 12
This property must be set to a non-empty array.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "world",
"apply": "setText",
"args": []
}
]
}
]
}
Error message:
error 12: method "test": property "args" should be a not empty array
Error Code 13
This object can't be empty.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [true]
}
]
}
Error message:
error 13: method "test": compose statement should be a non-empty object
Error Code 100
The arguments are incorrectly formatted. See Supported Argument Types.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "world",
"apply": "setText",
"args": [
{
"value": true,
"type": "string"
}
]
}
]
}
]
}
Error message:
error 100: method "test" arguments: incorrect argument format
Error Code 101
An unknown element is referenced as an argument. Check that the elementReference
in the args
array corresponds to a defined element.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "world",
"apply": "setText",
"args": [
{
"value": "argName",
"type": "elementReference"
}
]
}
]
}
]
}
Error message:
error 101: method "test" arguments: unknown element with name "argName" is referenced
Error Code 102
An argument is using an unsupported literal argument type. This example uses a number (1.024) but only integers are supported. See Supported Argument Types.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "world",
"apply": "setText",
"args": [
{
"value": 1.024
}
]
}
]
}
]
}
Error message:
error 102: method "test" arguments: unsupported literal argument type "1.024"
Error Code 103
An argument is using an unsupported argument type. See Supported Argument Types.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "world",
"apply": "setText",
"args": [
{
"type": "elementReference"
}
]
}
]
}
]
}
Error message:
error 103: method "test" arguments: unsupported argument type "elementReference"
Error Code 104
A function argument type requires a predicate
property and it's missing or incorrectly formatted. See Supported Argument Types.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "world",
"apply": "setText",
"args": [
{
"name": "name",
"type": "function"
}
]
}
]
}
]
}
Error message:
error 104: method "test" arguments: incorrect predicate format
Error Code 105
Literal arguments aren't allowed in this context. Use a name
property instead of a value
property. See Supported Argument Types.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"args": [
{
"value": "string literal"
}
],
"compose": [
{
"element": "root"
}
]
}
]
}
Error message:
error 105: method "test" arguments: literal arguments are not allowed
Error Code 106
An argument is using an incorrect elementReference
format. See Element Reference.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "world",
"apply": "setText",
"args": [
{
"value": "myElement",
"type": "elementReference",
"predicate": []
}
]
}
]
}
]
}
Error message:
error 106: method "test" arguments: incorrect format of elementReference argument
Error Code 107
A duplicate argument name is defined. Look for duplicate argument names.
Incorrect JSON example:
{
"elements": [
{
"name": "element",
"selector": {
"css": "selector %s",
"returnAll": true,
"args": [
{
"name": "arg1",
"type": "string"
}
]
},
"filter": {
"apply": "getAttribute",
"args": [
{
"name": "arg1",
"type": "string"
}
],
"matcher": {
"type": "stringContains",
"args": [
{
"name": "arg1",
"type": "string"
}
]
}
}
}
]
}
Error message:
error 107: element "element" arguments: argument with name "arg1" is already declared
Error Code 108
There's a mismatch in the expected number of arguments.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"selector": {
"css": "selector",
"returnAll": true
},
"type": "my/page/object",
"filter": {
"apply": "getText",
"matcher": {
"type": "isTrue",
"args": [
{
"name": "arg",
"type": "string"
}
]
}
}
}
]
}
Error message:
error 108: element "test" filter matcher arguments: expected number of arguments is 0, found 1
Error Code 109
An argument has an incorrect type. See Supported Argument Types.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"apply": "waitFor",
"args": [
{
"type": "function",
"predicate": [
{
"element": "root",
"apply": "isPresent"
}
]
},
{
"value": true
}
]
}
]
}
]
}
Error message:
error 109: method "test" arguments: argument "true" has incorrect type, expected "literal string", found "Boolean"
Error Code 110
A selector has an unknown parameter type. See Selector Parameters.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"public": true,
"selector": {
"css": "str[%f]",
"args": [
{
"name": "num",
"type": "number"
}
]
}
}
]
}
Error message:
error 110: element "test" selector arguments: unknown selector parameter type "%f", only string and number are supported
Error Code 111
An argument can only define either a "name" or "value" property. See Supported Argument Types. Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "world",
"apply": "setText",
"args": [{ "value": "true", "name": "name" }]
}
]
}
]
}
Error message:
error 111: method "test" arguments: either "name" or "value" is supported for an argument, not both
Error Code 112
An argument with a "name" property also requires a "type" property. See Supported Argument Types.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "world",
"apply": "setText",
"args": [
{
"name": "name"
}
]
}
]
}
]
}
Error message:
error 112: method "test" arguments: "type" is required for an argument "name"
Error Code 113
An argument must have either a "name" or "value" property. See Supported Argument Types.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "world",
"apply": "setText",
"args": [
{
"type": "string"
}
]
}
]
}
]
}
Error message:
error 113: method "test" arguments: either "name" or "value" is required for an argument
Error Code 114
A literal or function argument doesn't support a description
property.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"apply": "waitFor",
"args": [
{
"type": "function",
"description": "redundant",
"predicate": [
{
"element": "root"
}
]
}
]
}
]
}
]
}
Error message:
error 114: method "test" arguments: property "description" is not supported for literal or function argument
Error Code 115
An invalid basic element type is defined. See Basic Element.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"type": ["wrong"],
"selector": {
"css": "css"
}
}
]
}
Error message:
error 115: element "test" type: basic type "wrong" is not supported, valid values are: actionable, clickable, draggable, editable, touchable
Error Code 116
A duplicate basic type is defined.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"type": ["clickable", "clickable"],
"selector": {
"css": "css"
}
}
]
}
Error message:
error 116: element "test" type: duplicate basic type "clickable", basic type values must be unique
Error Code 200
An element is incorrectly formatted. See Basic Element.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"wrong": "test",
"type": "container"
}
]
}
Error message:
error 200: root elements: incorrect format of elements
Error Code 201
An incorrect element type is defined. A custom type must contain alphanumeric characters only with the schema [package-name]/[custom/path]/pageObject
.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"type": "wrong",
"selector": {
"css": "css"
}
}
]
}
Error message:
error 201: element "test": type "wrong" is not supported, valid values are: custom, container, frame, actionable, clickable, draggable, editable, touchable
Error Code 202
A duplicate element with the same name is defined.
Incorrect JSON example:
{
"elements": [
{
"name": "dupElement",
"selector": {
"css": "css"
}
},
{
"name": "dupElement",
"selector": {
"css": "css"
}
}
]
}
Error message:
error 202: element "dupElement": element with same name was already declared
Error Code 204
A frame selector can't set a returnAll
property to true
.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"selector": {
"css": "css",
"returnAll": true
},
"type": "frame"
}
]
}
Error message:
error 204: element "test": frame selector cannot have "returnAll" set to true
Error Code 205
Only a basic element can have nested elements or a shadow root.
Incorrect JSON example:
{
"elements": [
{
"name": "one",
"selector": {
"css": ".one"
},
"elements": [
{
"name": "nestedCustom",
"selector": {
"css": ".nestedCustom"
},
"type": "utam-test/pageObjects/test/componentType",
"public": true
}
],
"shadow": {
"elements": [
{
"name": "nestedInsideShadow",
"selector": {
"css": ".css"
}
}
]
}
}
]
}
Error message:
error 205: element "test": only basic element can have nested elements or shadow root
Error Code 206
The load
property is not supported for elements with arguments or container type elements.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"selector": {
"css": "test[%s]",
"args": [
{
"name": "selectorArgs",
"type": "string"
}
]
},
"load": true
}
]
}
Error message:
error 206: element "test": property "load" is not supported for element with arguments, filter or for container element
Error Code 300
An element filter is incorrectly defined. See Element Filter.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"selector": {
"css": "selector %s",
"returnAll": true,
"args": [
{
"name": "arg1",
"type": "string"
}
]
},
"filter": {
"apply": "wrong",
"args": [
{
"name": "arg1",
"type": "string"
}
]
}
}
]
}
Error message:
error 300: element "test" filter: incorrect format of element filter
Error Code 301
An unknown action is defined for a basic element.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"selector": {
"css": "selector %s",
"returnAll": true,
"args": [
{
"name": "arg1",
"type": "string"
}
]
},
"filter": {
"apply": "wrong",
"args": [
{
"name": "arg1",
"type": "string"
}
],
"matcher": {
"type": "isTrue"
}
}
}
]
}
Error message:
error 301: element "test" filter: unknown action "wrong" for basic element
Error Code 302
A filter can only be set for a list element. See List and Index.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"selector": {
"css": "css"
},
"filter": {
"apply": "isVisible",
"matcher": {
"type": "isTrue"
}
}
}
]
}
Error message:
error 302: element "test" filter: filter can only be set for list
Error Code 303
An unsupported action is defined for this element type. See Basic Element.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"type": "touchable",
"selector": {
"css": "selector %s",
"returnAll": true,
"args": [
{
"name": "arg1",
"type": "string"
}
]
},
"filter": {
"apply": "click",
"matcher": {
"type": "isTrue"
}
}
}
]
}
Error message:
error 303: element "test" filter: unsupported action "click" for type "touchable"
Error Code 400
An interface is incorrectly defined. Declare an interface's API as an array of objects in the methods
property. See Interfaces.
Incorrect JSON example:
{
"interface": true,
"methods": [
{
"name": "test",
"compose": [
{
"element": "root",
"apply": "getText"
}
]
}
]
}
Error message:
error 400: method "test": incorrect format of abstract method
Error Code 401
Reserved for future use.
Error Code 402
A returnAll
property can't be set in an interface without setting a returnType
property. See Interfaces.
Incorrect JSON example:
{
"interface": true,
"methods": [
{
"name": "test",
"returnAll": true
}
]
}
Error message:
error 402: abstract method "test": "returnAll" property can't be set without setting return type
Error Code 403
An unsupported returnType
property for an interface was defined. See Interfaces.
Incorrect JSON example:
{
"interface": true,
"methods": [
{
"name": "test",
"returnType": "container"
}
]
}
Error message:
error 403: abstract method "test": return type "container" is not supported
Error Code 500
The compose method is incorrectly formatted. See Compose Method.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"unsupportedProperty": "value",
"compose": [
{
"element": "root"
}
]
}
]
}
Error message:
error 500: method "test": incorrect format of compose method
Error Code 501
An argument at the method level can't have an argumentReference
type. See Argument Reference.
Incorrect JSON example:
{
"methods": [
{
"args": [
{
"name": "arg1",
"type": "argumentReference"
}
],
"name": "test",
"compose": [
{
"apply": "something"
}
]
}
]
}
Error message:
error 501: method "test" arguments: parameter "arg1" at method level can't have type "argumentReference"
Error Code 502
An argumentReference
is used but there's no matching argument defined at the method level. See Argument Reference.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"apply": "something",
"args": [
{
"name": "arg1",
"type": "argumentReference"
}
]
}
]
}
]
}
Error message:
error 502: method "test": statement declares a reference to an "arg1" argument, but there is no matching argument at the method level
Error Code 503
A declared argument is never used.
Incorrect JSON example:
{
"methods": [
{
"args": [
{
"type": "string",
"name": "arg"
}
],
"name": "test",
"compose": [
{
"apply": "someMethod"
}
]
}
]
}
Error message:
error 503: method "test": declared parameter "arg" is never used
Error Code 504
A duplicate method name is declared. This can be fixed by renaming one of the methods.
Incorrect JSON example:
{
"methods": [
{
"name": "method1",
"compose": [
{
"apply": "someMethod1"
}
]
},
{
"name": "method1",
"compose": [
{
"apply": "someMethod2"
}
]
}
]
}
Error message:
error 504: method "method1": method with the same name was already declared
Error Code 505
The name of a method will duplicate the name of a generated method.
In the example below, the compiler will generate a helper function for the test
element named waitForTest
.
Because there is a declared method with the same name, an error is thrown.
To fix this, rename the element or the method.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"selector": {
"css": "div"
},
"wait": true,
"public": true
}
],
"methods": [
{
"name": "waitForTest",
"compose": [
{
"element": "test"
}
]
}
]
}
Error message:
error 505: method "waitForTest": the given method name would duplicate the name of a generated helper function for element "test"
Error Code 600
The compose statement is incorrectly formatted. See Compose Method.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"apply": "returnSelf",
"element": "document"
}
]
}
]
}
Error message:
error 600: method "test" statement: incorrect compose statement format
Error Code 601
A compose statement references an unknown element.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "test"
}
]
}
]
}
Error message:
error 601: method "test" statement: unknown element with name "test" is referenced in a compose statement
Error Code 602
A compose statement is using an unsupported returnType
property. See Method Return Types.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "root",
"returnType": "container"
}
]
}
]
}
Error message:
error 602: method "test" statement: return type "container" is not supported in a compose statement
Error Code 603
A compose statement with a returnAll
property must also have a returnType
property. See Compose Method.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "root",
"returnAll": true
}
]
}
]
}
Error message:
error 603: method "test" statement: "returnAll" property can't be set without setting return type in a compose statement
Error Code 605
The return type for element
can't be inferred. Please add a returnType
property.
Incorrect JSON example:
{
"elements": [
{
"name": "element",
"type": "my/pageobject/foo",
"selector": {
"css": "css"
}
}
],
"methods": [
{
"name": "test",
"compose": [
{
"element": "element"
},
{
"chain": true,
"element": "element"
}
]
}
]
}
Error message:
error 605: method "test" statement: can't infer return type for "element", please provide a "returnType"
Error Code 606
An element
property is redundant because it's a chain statement. See Chain Compose Statements.
Incorrect JSON example:
{
"elements": [
{
"name": "element",
"type": "my/custom/type",
"selector": {
"css": "css"
}
}
],
"methods": [
{
"name": "test",
"compose": [
{
"element": "element"
},
{
"chain": true,
"element": "element",
"apply": "method"
}
]
}
]
}
Error message:
error 606: method "test" statement: "element" property is redundant because statement is marked as a chain
Error Code 607
Only a document
or root
element is allowed in a beforeLoad
statement. See beforeLoad.
Incorrect JSON example:
{
"beforeLoad": [
{
"element": "test",
"apply": "getAttribute"
}
]
}
Error message:
error 607: method "beforeLoad" statement: only "document" or "root" elements are allowed
Error Code 608
A "returnSelf" statement can only be invoked from the last statement. See returnSelf statement.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"apply": "returnSelf"
},
{
"apply": "someMethod"
}
]
}
]
}
Error message:
error 608: method "test" statement: "returnSelf" can only be invoked from the last statement
Error Code 609
A compose method must define either an element
, apply
, or applyExternal
property. See Compose Method and Imperative Extensions.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [{}]
}
]
}
Error message:
error 609: method "test" statement: either "element" or "apply" or "applyExternal" should be defined
Error Code 610
A compose method can define either an apply
or applyExternal
property, but not both. See Compose Method and Imperative Extensions.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "root",
"apply": "getText",
"applyExternal": {}
}
]
}
]
}
Error message:
error 610: method "test" statement: either "apply" or "applyExternal" should be defined"
Error Code 611
A compose statement that uses an applyExternal
property can't also use element
or apply
properties.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "root",
"applyExternal": {}
}
]
}
]
}
Error message:
error 611: method "test" utility statement: "element" property is redundant
Error Code 612
This method isn't supported for this basic element type. See Basic Actions.
Incorrect JSON example:
{
"exposeRootElement": true,
"methods": [
{
"name": "test",
"compose": [
{
"apply": "click",
"element": "root"
}
]
}
]
}
Error message:
error 612: method "test" statement: unknown method "click" for basic element
Error Code 613
The compose statement has an unexpected returnType
property. See Method Return Types.
Incorrect JSON example:
{
"elements": [
{
"name": "element",
"selector": {
"css": "css"
},
"type": ["actionable"]
}
],
"methods": [
{
"name": "test",
"compose": [
{
"returnType": "string",
"element": "element"
}
]
}
]
}
Error message:
error 613: method "test" statement: incorrect return type; expected "ElementElement", provided is "String"
Error Code 614
Chains are supported only if the previous statement returns a custom type (another page object). See Chain Compose Statements.
Incorrect JSON example:
{
"elements": [
{
"name": "element",
"selector": {
"css": "css"
}
}
],
"methods": [
{
"name": "test",
"compose": [
{
"element": "element"
},
{
"chain": true,
"element": "element"
}
]
}
]
}
Error message:
error 614: method "test" statement: to use chain, previous statement should return custom type, but it returns "BasicElement"
Error Code 615
A nested waitFor
statement isn't supported. See Explicit Waits.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"apply": "waitFor",
"args": [
{
"type": "function",
"predicate": [
{
"apply": "waitFor",
"args": [
{
"type": "function",
"predicate": [
{
"apply": "invoke"
}
]
}
]
}
]
}
]
}
]
}
]
}
Error message:
error 615: method "test" statement: nested waitFor is not supported
Error Code 616
The first statement in a compose method can't set chain
to true
. See Chain Compose Statements.
Incorrect JSON example:
{
"methods": [
{
"name": "test",
"compose": [
{
"element": "root",
"chain": true
}
]
}
]
}
Error message:
error 616: method "test" statement: first statement can't be marked as chain
Error Code 617
This method isn't supported for this element type. See Basic Actions.
Incorrect JSON example:
{
"type": ["editable"],
"methods": [
{
"name": "test",
"compose": [
{
"apply": "click",
"element": "root"
}
]
}
]
}
Error message:
error 617: method "test" statement: unsupported action "click" for type "Editable"
Error Code 700
The description
property is incorrectly formatted. See Page Object Description.
Incorrect JSON example:
{
"elements",
[
{
"name": "test",
"description": true,
"selector": {
"css": "css"
}
}
]
}
Error message:
error 700: element "test" description: format of the description is incorrect
Error Code 800
The profile
property is incorrectly formatted. See Interfaces.
Incorrect JSON example:
{
"profile": [{}],
"implements": "my/pageobjects/type"
}
Error message:
error 800: profile format is incorrect
Error Code 801
The profile name is a duplicate. See Interfaces.
Incorrect JSON example:
{
"profile": [
{
"name": "value"
},
{
"name": "value"
}
],
"implements": "my/pageobjects/type"
}
Error message:
error 801: "profile": duplicate profile name "name"
Error Code 802
The profile has a duplicate value. See Interfaces.
Incorrect JSON example:
{
"profile": [
{
"name":
["same", "same"]
}
]
"implements", "my/pageobjects/type"
}
Error message:
error 802: profile "name": duplicate profile value "same"
Error Code 803
The profile isn't configured. Make sure that the profile is in the compiler configuration file. See Interfaces.
Incorrect JSON example:
{
"profile": [
{
"name": "error"
}
],
"implements": "my/pageobjects/type"
}
Error message:
error 803: profile { "name": "error" } is not configured, make sure it's in compiler config
Error Code 804
A profile with this name isn't configured. Make sure that the profile is in the compiler configuration file. See Interfaces.
Incorrect JSON example:
{
"profile": [
{
"name1": "value1"
}
],
"implements": "my/pageobjects/type"
}
Error message:
error 804: profile with name "name1" is not configured, make sure it's in compiler config
Error Code 805
A profile can only be set for a page object that also sets the implements
property. See Interfaces.
Incorrect JSON example:
{
"profile": [
{
"profile": "test"
}
]
}
Error message:
error 805: "profile" can only be set for a page object that implements an interface
Error Code 806
A profile value can either be a string or a non-empty string array. See Interfaces.
Incorrect JSON example:
{
"profile": [
{
"name": {}
}
],
"implements": "my/pageobjects/type"
}
Error message:
error 806: profile "name": values can either be string or non-empty string array
Error Code 900
The page object is incorrectly formatted.
Incorrect JSON example:
{
"error": true
}
Error message:
error 900: incorrect format of the page object. Unrecognized field "error".
Error Code 901
A non-root page object can't have a selector
property. Either remove the selector
property or add "root": true
. See Root Element.
Incorrect JSON example:
{
"selector": {
"css": "rootSelector"
}
}
Error message:
error 901: non-root page object can't have selector
Error Code 902
A root page object requires a selector
property. Either add a selector
property or remove "root": true
. See Root Element.
Incorrect JSON example:
{
"root": true
}
Error message:
error 902: root page object requires "selector" property
Error Code 903
The platform
property value must be either web
or native
. See Interfaces.
Incorrect JSON example:
{
"platform": "wibblywobblywonder"
}
Error message:
error 903: "platform" property: platform should be a string with "web" or "native" value, instead found "wibblywobblywonder"
Error Code 904
The beforeLoad
property can't have arguments. See beforeLoad.
Incorrect JSON example:
{
"beforeLoad": [
{
"element": "root",
"apply": "getAttribute",
"args": [
{
"type": "string",
"name": "str"
}
]
}
]
}
Error message:
error 904: method "beforeLoad" cannot have parameters
Error Code 905
The the root description
property is incorrectly formatted. See Page Object Description.
Incorrect JSON example:
{
"description": true
}
Error message:
error 905: format of the root description is incorrect
Error Code 1000
The selector
property is incorrectly formatted. See Element Selector.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"selector": "selector"
}
]
}
Error message:
error 1000: element "test": format of selector is incorrect
Error Code 1002
The selector
must contain css
, accessid
, uiautomator
, or classchain
properties. See Element Selector.
Incorrect JSON example:
{
"root": true,
"selector": {}
}
Error message:
error 1002: element "root" selector: one of "css", "accessid", "uiautomator" or "classchain" should be set"
Error Code 1003
The root selector
can only be one of "css", "accessid", "uiautomator", or "classchain". See Element Selector.
Incorrect JSON example:
{
"root": true,
"selector": {
"css": "css",
"accessid": "accessid"
}
}
Error message:
error 1003: element "root" selector: only one of "css", "accessid", "uiautomator" or "classchain" can be set
Error Code 1004
The selector
is using an invalid UiSelector
method. See Element Selector.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"selector": {
"uiautomator": "new UiScrollable(new UiSelector().scrollable(true)).scrollIntoView(new UiSelector().unsupported())"
}
}
]
}
Error message:
error 1004: element "test" selector: unsupported UiSelector method "unsupported", supported methods are checkable, checked, classname, description, descriptioncontains, descriptionstartswith, enabled, selected, resourceid, resourceidmatches
Error Code 1005
The classchain
property in the selector is using unsupported quotes. See Element Selector.
Incorrect JSON example:
{
"selector": {
"classchain": "**/XCUIElementTypeStaticText[\"label == 'something'\"]"
},
"root": true
}
Error message:
error 1005: element "root" selector "label == 'something'": for class chain only one of supported quotes can be set, supported are $,`
Error Code 1006
The classchain
property in the selector can set only one of the supported operators. See Element Selector.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"selector": {
"classchain": "**/XCUIElementTypeStaticText[`label=='something'`]"
}
}
]
}
Error message:
error 1006: element "test" selector "`label=='something'`": for class chain only one of supported operators can be set, supported are ==,BEGINSWITH,ENDSWITH,CONTAINS,OR,AND
Error Code 1100
The elements
property inside shadow
is incorrectly formatted. See Root Element.
Incorrect JSON example:
{
"shadow": {
"elements": [{}]
}
}
Error message:
error 1100: root shadow: incorrect format of elements inside shadow
Error Code 1200
The matcher
property is incorrectly formatted. See Matchers.
Incorrect JSON example:
{
"name": "test",
"selector": {
"css": ".css",
"returnAll": true
},
"filter": {
"apply": "getText",
"matcher": {
"typemisprinted": "stringEquals"
}
}
}
Error message:
error 1200: element "test" filter: incorrect format of matcher
Error Code 1201
The filter matcher type isn't supported. See Matchers.
Incorrect JSON example:
{
"elements": [
{
"name": "test",
"selector": {
"css": ".helloworld",
"returnAll": true
},
"type": "vanilla-js/pageObjects/counter",
"filter": {
"apply": "getText",
"matcher": {
"type": "invalid"
}
}
}
]
}
Error message:
error 1201: element "test" filter matcher: unsupported matcher type "invalid", supported are isTrue, isFalse, notNull, stringContains, stringEquals
Error Code 1202
The apply
method returns a type that's incompatible with the matcher
. See Matchers.
Incorrect JSON example:
{
"methods": [
{
"name": "matcherThrows",
"compose": [
{
"element": "root",
"apply": "getText",
"matcher": {
"type": "isTrue"
}
}
]
}
]
}
Error message:
error 1202: method "matcherThrows" statement matcher: applied method returns type "String", which is only compatible with the following matchers - stringContains, stringEquals, notNull