Actions in the MFTF allow you to automate different scenarios of Magento user's actions. They are mostly XML implementations of Codeception actions. Some actions drive browser elements, while others use REST APIs.
All <actions>
contain the following attributes that are useful for merging needs.
stepKey
is a required attribute that stores a unique identifier of the action.
Example test step of the myAction
action with the conditionalClickStep1
identifier:
<myAction stepKey="conditionalClickStep1"/>
This step can be referenced within the test using conditionalClickStep1
.
The value format should met the following principles:
- Must be unique within
<test>
. - Naming should be as descriptive as possible:
- Describe the action performed.
- Briefly describe the purpose.
- Describe which data is in use.
- Should be in camelCase with lowercase first letter.
- Should be the last attribute of an element.
before
and after
are optional attributes that insert the action into the test while merging. The action will be executed before or after the one set in these attributes. The value here is the stepKey
of reference action.
Example with before
:
<myAction before="fillField" stepKey="conditionalClickStep1"/>
myAction
will be executed before the action, which has stepKey="fillField"
.
Example with after
:
<myAction after="fillField" stepKey="seeResult"/>
myAction
will be executed after the action, which has stepKey="fillField"
.
The following example contains four actions:
-
<amOnPage url="{{StorefrontCustomerSignInPage.url}}" stepKey="amOnSignInPage"/> <fillField userInput="$$customer.email$$" selector="{{StorefrontCustomerSignInFormSection.emailField}}" stepKey="fillEmail"/> <fillField userInput="$$customer.password$$" selector="{{StorefrontCustomerSignInFormSection.passwordField}}" stepKey="fillPassword"/> <click selector="{{StorefrontCustomerSignInFormSection.signInAccountButton}}" stepKey="clickSignInAccountButton"/>
<amOnPage url="{{StorefrontCustomerSignInPage.url}}" stepKey="amOnSignInPage"/>
The Customer Sign In page is declared in the .../Customer/Page/StorefrontCustomerSignInPage.xml
file.
The given relative URI is declared in StorefrontCustomerSignInPage.url
.
Source code (StorefrontCustomerSignInPage.xml
):
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="urn:magento:mftf:Page/etc/PageObject.xsd">
<page name="StorefrontCustomerSignInPage" url="/customer/account/login/" module="Magento_Customer">
<section name="StorefrontCustomerSignInFormSection" />
</page>
</config>
<amOnPage>
is an action that opens a page for a given URI. It has a key "amOnSignInPage"
that will be used as a reference for merging needs in other modules.
This action uses the url
attribute value for the given relative URI to open a browser page.
Here, url
contains a pointer to a url
attribute of the StorefrontCustomerSignInPage
.
<fillField userInput="$customer.email$" selector="{{StorefrontCustomerSignInFormSection.emailField}}" stepKey="fillEmail"/>
<fillField>
fills a text field with the given string.
The customer's email is stored in the email
parameter of the customer
entity created somewhere earlier in the test using a <createData>
tag.
userInput
points to that data.
selector
points to the field where you enter the data.
A required selector is stored in the emailField
element of the StorefrontCustomerSignInFormSection
section.
This section is declared in .../Customer/Section/StorefrontCustomerSignInFormSection.xml
file:
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="urn:magento:mftf:Page/etc/SectionObject.xsd">
<section name="StorefrontCustomerSignInFormSection">
<element name="emailField" type="input" selector="#email"/>
<element name="passwordField" type="input" selector="#pass"/>
<element name="signInAccountButton" type="button" selector="#send2" timeout="30"/>
</section>
</config>
<fillField userInput="$customer.password$" selector="{{StorefrontCustomerSignInFormSection.passwordField}}" stepKey="fillPassword"/>
This <action>
is very similar to the <action>
in a previous step.
The only difference is that different data is assigned to the attributes, which set a field with a password.
<click selector="{{StorefrontCustomerSignInFormSection.signInAccountButton}}" stepKey="clickSignInAccountButton"/>
Here, <click>
performs a click on a button that can be found by the selector that is stored in the signInAccountButton
of the StorefrontCustomerSignInFormSection
.
The following test actions return a variable:
- grabAttributeFrom
- grabCookie
- grabFromCurrentUrl
- grabMultiple
- grabPageSource
- grabTextFrom
- grabValueFrom
- executeJS
- getOTP
- return
Learn more in Using data returned by test actions.
The following test actions handle data entities using metadata:
Learn more in Handling a REST API response.
To use HTML in actions you must encode the HTML string. We recommend using CyberChef. Using CyberChef or a similar tool is straightforward: enter in your HTML string, copy the encoded result, and paste that value into your MFTF test.
For example, we want to ensure that this value is presented as a string and not rendered as a H1 tag: <h1 class="login-header">
After passing <h1 class="login-header">
through CyberChef we get <h1 class="login-header">
which can be used in a test like:
<dontSeeInSource html="<h1 class="login-header">" stepKey="dontSeeInSource"/>
The following list contains reference documentation about all action elements available in the MFTF. If the description of an element does not include a link to Codeception analogue, it means that the action is developed by Magento for specific MFTF needs.
Accepts the current popup visible on the page.
See acceptPopup docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Accept the current popup visible on the page. -->
<acceptPopup stepKey="acceptPopup"/>
Opens the page by the URL relative to the one set in the MAGENTO_BASE_URL
configuration variable.
See amOnPage docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
url |
string | optional | A path to the page relative to the MAGENTO_BASE_URL . |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Open the `(baseURL)/admin` page. -->
<amOnPage url="{{AdminLogoutPage.url}}" stepKey="goToLogoutPage"/>
Takes the base URL and changes the subdomain.
See amOnSubdomain docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
url |
string | optional | The name of the subdomain. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
Pre-condition: the current base URL is https://www.magento.com
.
<!-- Change the sub-domain to `https://devdocs.magento.com`. -->
<amOnSubdomain url="devdocs" stepKey="changeSubdomain"/>
<!-- Open the page `https://devdocs.magento.com` -->
<amOnPage url="/" stepKey="goToDataPage"/>
Opens a page by the absolute URL.
See amOnUrl docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
url |
string | optional | The absolute URL to be used in subsequent steps. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Set url to be used in the next steps to https://www.magento.com/ -->
<amOnUrl url="https://www.magento.com/" stepKey="amOnUrl"/>
See appendField docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector used to identify the form field. |
userInput |
string | optional | Value to append to the form field. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Append the "Sample Text" string to the selected input element -->
<appendField userInput="Sample Text" selector="input#name" stepKey="appendSuffix"/>
See attachFile docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element (<input type="file"> ). |
userInput |
string | optional | The name of attaching file. The file must be placed in the tests/_data directory. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Upload a file from the `tests/_data` directory with the `image.png` name to the selected input element. -->
<attachFile userInput="image.png" selector="input#imgUpload" stepKey="uploadFile"/>
See cancelPopup docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Cancel the current popup visible on the page. -->
<cancelPopup stepKey="cancelPopup"/>
See checkOption docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Ensure the checkbox `<input type="checkbox" id="checkbox" ... >...</input>` is checked. -->
<checkOption selector="input#checkbox" stepKey="checkCheckbox"/>
Clears a text input field.
Equivalent to using <fillField>
with an empty string.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | required | The selector identifying the corresponding HTML element to be cleared. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Clear the selected field. -->
<clearField selector="input#name" stepKey="clearField"/>
See click docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
selectorArray |
string | optional | Selects an element as a key value array. See strict locator. |
userInput |
string | optional | Data to be sent with the click. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Click the selected button. -->
<click selector="button#clickable" stepKey="clickButton"/>
<!-- Click on the "<a href=...>Login</a>" link. -->
<click selectorArray="['link' => 'Login']" stepKey="clickButton2"/>
See clickWithLeftButton docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
selectorArray |
string | optional | Selects an element as a key value array; See [strict locator]. |
x |
string | optional | The x-axis value in pixels for the click location. |
y |
string | optional | The y-axis value in pixels for the click location. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Left click on the center of the `<button id="clickable" />` element. -->
<clickWithLeftButton selector="button#clickable" stepKey="clickButton1"/>
<!-- Left click on the point that is 50 px from the top of the window and 50 px from the left of the window. -->
<clickWithLeftButton x="50" y="50" stepKey="clickButton2"/>
<!-- Left click on the point that is 50 px from the top and 50 px from the left of of the `<button id="clickable" />` element.. -->
<clickWithLeftButton selector="button#clickable" x="50" y="50" stepKey="clickButton3"/>
See clickWithRightButton docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
selectorArray |
string | optional | Selects an element as a key value array; See [strict locator]. |
x |
string | optional | The x-axis value in pixels for the click location. |
y |
string | optional | The y-axis value in pixels for the click location. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Right click on the center of the `<button id="clickable" />` element. -->
<clickWithRightButton selector="button#clickable" stepKey="clickButton1"/>
<!-- Right click on the point that is 50 px from the top of the window and 50 px from the left of the window. -->
<clickWithRightButton x="50" y="50" stepKey="clickButton2"/>
<!-- Right click on the point that is 50 px from the top and 50 px from the left of of the `<button id="clickable" />` element.. -->
<clickWithRightButton selector="button#clickable" x="50" y="50" stepKey="clickButton3"/>
Remove from the DOM all elements with the CSS classes .modal-popup
or .modals-overlay
.
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Remove elements of the `.modal-popup` or `.modals-overlay` CSS classes. -->
<closeAdminNotification stepKey="closeAdminNotification"/>
See closeTab docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Close the active tab. -->
<closeTab stepKey="closeTab"/>
Allows input of a string as a PHP code comment. This tag is not executed. It is intended to aid documentation and clarity of tests.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | required | PHP comment that will be written in generated test file. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Open the specified page and print a comment "I am on the login page" in the log during test execution. -->
<amOnPage url="/login" stepKey="goToLoginPage"/>
<comment userInput="I am on the login page" stepKey="loginPageComment"/>
Conditionally clicks on an element if, and only if, another element is visible or not.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the HTML element to be clicked. |
dependentSelector |
string | optional | The selector of the HTML element whose visibility is checked for to activate the click. |
visible |
boolean | optional | Determines whether the conditional click is activated by the element being visible or hidden. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Click on the element with `id="foo"` if the element with `id="bar"` is visible. -->
<conditionalClick selector="#foo" dependentSelector="#bar" visible="true" stepKey="click1"/>
Creates an entity (for example, a category or product).
To create an entity, the MFTF makes a POST
request to the Magento API according to the data and metadata of the entity to be created.
Attribute | Type | Use | Description |
---|---|---|---|
entity |
string | required | Type of entity to be created. |
storeCode |
string | optional | ID of the store within which the data is created. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
It can optionally contain one or more requiredEntity
child elements.
<!-- Create an entity with the "SampleProduct" name. -->
<createData entity="SampleProduct" stepKey="createSampleProduct"/>
Specify relationships amongst data to be created. For example, a complex Product object may contain within it a pointer (an ID) to a complex Category object.
<!-- Create an entity with the "SampleCategory" name. -->
<createData entity="SampleCategory" stepKey="createCategory"/>
<!-- Create the "SampleProduct" product in that category. -->
<createData entity="SampleProduct" stepKey="createProduct">
<requiredEntity createDataKey="createCategory"/>
</createData>
Attribute | Type | Use | Description |
---|---|---|---|
createDataKey |
string | required | Name of the required entity. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
Persists a custom field (as a part of the entity) overriding the matching declaration in static data. This field is replaced at a top level only (nested values such as custom attributes or extension attributes are not replaced).
Attribute | Type | Use | Description |
---|---|---|---|
key |
string | required | Name of the field to be replaced or added. |
To overwrite the name
field in a particular product, specify a field element during its creation.
<createData entity="SampleProduct" stepKey="createProduct">
<field key="name">myCustomProductName</field>
</createData>
Delete an entity that was previously created.
Attribute | Type | Use | Description |
---|---|---|---|
createDataKey |
string | optional | Reference to stepKey of the createData action . |
url |
string | optional | REST API route to send a DELETE request. |
storeCode |
string | optional | ID of the store from which to delete the data. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
Delete the entity that was previously created using createData
in the scope of the test.
- Create SampleCategory:
<createData entity="SampleCategory" stepKey="createCategory"/>
- Delete SampleCategory:
<deleteData createDataKey="createCategory" stepKey="deleteCategory"/>
Delete an entity using REST API request to the corresponding route:
<grabFromCurrentUrl regex="/^.+id\/([\d]+)/" stepKey="grabId"/>
<deleteData url="V1/categories/{$grabId}" stepKey="deleteCategory"/>
See the codeception.com documentation for more information about this action.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Value for the form field. |
selector |
string | optional | The selector identifying the corresponding HTML element. |
selectorArray |
string | optional | Array of selectors to evaluate. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Check that the page does not contain the `<h2 id="title">Sample title</h2>` element. -->
<dontSee userInput="Sample title" selector="h2#title" stepKey="dontSeeTitle"/>
See dontSeeCheckboxIsChecked docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that the page does not contain the `<input type="checkbox" id="option1" ... >...</input>` element. -->
<dontSeeCheckboxIsChecked selector="input#option1" stepKey="checkboxNotChecked"/>
See dontSeeCookie docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Value for the form field. |
parameterArray |
string | optional | Parameters to search for within the cookie. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that there is no cookie with the given name `cookie1`. -->
<dontSeeCookie userInput="cookie1" stepKey="cookie1NotPresent"/>
<!-- Verify that there is no cookie with the given name `cookie1` from the domain `www.example.com`. -->
<dontSeeCookie userInput="cookie1" parameterArray="['domainName' => '.example.com']" stepKey="dontSeeCookieInExampleDomain"/>
See dontSeeCurrentUrlEquals docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
url |
string | optional | URL to be compared with the current URL. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that the relative URL of the current page does not match `/admin`. -->
<dontSeeCurrentUrlEquals url="/admin" stepKey="notOnAdminPage"/>
See dontSeeCurrentUrlMatches docs on codeception.com
Attribute | Type | Use | Description |
---|---|---|---|
regex |
string | optional | Regular expression against the current URI. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that the relative URL of the current page does not match the `~$/users/(\d+)~` regular expression. -->
<dontSeeCurrentUrlMatches regex="~$/users/(\d+)~" stepKey="dontSeeCurrentUrlMatches"/>
See dontSeeElement docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
parameterArray |
string | optional | Parameters to search for within the selected element. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that `<div id="box" ... >...</div>` is missing or invisible on the current page. -->
<dontSeeElement selector="div#box" stepKey="dontSeeBox"/>
See dontSeeElementInDOM docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
parameterArray |
string | optional | Array of parameters to search for within the selector. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that `<div id="box" ... >...</div>` is completely missing on the current page. -->
<dontSeeElementInDOM selector="div#box" stepKey="dontSeeBoxInDOM"/>
See dontSeeInCurrentUrl docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
url |
string | optional | String to search for within the current URL. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that the url of the current active tab does not contain the string "/users/". -->
<dontSeeInCurrentUrl url="/users/" stepKey="dontSeeInCurrentUrl"/>
See dontSeeInField docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
selectorArray |
string | optional | Array of selectors to be searched. |
userInput |
string | optional | Value for the form field. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that `<input id="field" ... >...</input>` does not contain the text "Sample text". -->
<dontSeeInField userInput="Sample text" selector="input#field" stepKey="dontSeeInField1"/>
See dontSeeInFormFields docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
parameterArray |
string | optional | Array of name/value pairs of the form fields to check against. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that `<form name="myform" ... >...</form>` with the input elements `<input name="input1">...</input>` and `<input name="input2">...</input>`, do not have the values of `value1` and `value2` respectively. -->
<dontSeeInFormFields selector="form[name=myform]" parameterArray="['input1' => 'value1', 'input2' => 'value2']" stepKey="dontSeeInFormFields"/>
See dontSeeInPageSource docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
html |
string | required | HTML code to be searched for within the page source. The value must be entity-encoded. See example. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that the page source does not contain the raw source code `<h1 class="login-header">`. -->
<dontSeeInPageSource userInput="<h1 class="login-header">" stepKey="dontSeeInPageSource"/>
See dontSeeInSource docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
html |
string | required | HTML code to be searched for within the page source. The value must be entity-encoded. See example. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
You must encode the html
using a tool such as CyberChef.
<!-- Verify that the page source does not contain the raw source code `<h1 class="login-header">`. -->
<dontSeeInSource html="<h1 class="login-header">" stepKey="dontSeeInSource"/>
See dontSeeInTitle docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Value to be located in the page title. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that the title of the current active window does not contain the text "Page Title". -->
<dontSeeInTitle userInput="Page Title" stepKey="dontSeeInTitle"/>
Ensure that the current page does not have JavaScript errors.
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify there are no JavaScript errors in the current active window. -->
<dontSeeJsError stepKey="dontSeeJsError"/>
See dontSeeLink docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Text of the link field to search for. |
url |
string | optional | Value of the href attribute to search for. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that there is no hyperlink tag on the page with the text "External link". -->
<dontSeeLink userInput="External link" stepKey="dontSeeLink"/>
<!-- Verify that there is no hyperlink tag with the text "External link" and the `href` attribute of `/admin`. -->
<dontSeeLink userInput="External link" url="/admin" stepKey="dontSeeAdminLink"/>
See dontSeeOptionIsSelected docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding select element. |
userInput |
string | optional | Name of the option to look for. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that `<select id="myselect" ... >...</select>` does not have the option `option1` selected -->
<dontSeeOptionIsSelected userInput="option1" selector="select#myselect" stepKey="dontSeeOption1"/>
See doubleClick docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Click the selected element twice in succession. -->
<doubleClick selector="button#mybutton" stepKey="doubleClickButton"/>
See dragAndDrop docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector1 |
string | optional | A selector for the HTML element to drag. |
selector2 |
string | optional | A selector for the HTML element to drop onto. |
x |
int | optional | X offset applied to drag-and-drop destination. |
y |
int | optional | Y offset applied to drag-and-drop destination. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Click and drag `<div id="block1" ... >...</div>` to the middle of `<div id="block2" ... >...</div>` -->
<dragAndDrop selector1="div#block1" selector2="div#block2" stepKey="dragAndDrop"/>
<!-- Click and drag `<div id="block1" ... >...</div>` to the middle of `<div id="block2" ... >...</div>` with a left offset of 50px and top offset of 50px. -->
<dragAndDrop selector1="#block1" selector2="#block2" x="50" y="50" stepKey="dragAndDrop"/>
See executeJS docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
function |
string | optional | JavaScript to be executed. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Return the time in seconds since Unix Epoch (January 1, 1970) using the JavaScript Date() function.
To access this value, use `{$returnTime}` in later actions. -->
<executeJS function="return Math.floor(new Date() / 1000);" stepKey="returnTime"/>
To access this value you would use {$returnTime}
in later actions.
See fillField docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
selectorArray |
string | optional | Array of name/value pairs with which to populate the form. |
userInput |
string | optional | Value for the form field. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Fill in `<input id="myfield" ... >...</input>` with the text "Sample text". -->
<fillField userInput="Sample text" selector="input#myfield" stepKey="fillField"/>
Format input to specified currency according to the locale specified. Returns formatted string for test use. Use NumberFormatter::formatCurrency(), see https://www.php.net/manual/en/numberformatter.formatcurrency.php
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | required | Number to be formatted. |
locale |
string | required | The locale to format to. |
currency |
string | required | The 3-letter ISO 4217 currency code indicating the currency to use. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
Generates a date for use in {$stepKey}
format in other test actions.
Attribute | Type | Use | Description |
---|---|---|---|
date |
string | required | Date input to parse. Uses the same functionality as the PHP strtotime() function. |
format |
string | required | Format in which to save the given date. Uses the same formatting as the PHP date() function. |
timezone |
string | optional | Timezone to use when generating date, defaults to America/Los_Angeles . |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Generate a date that is 1 minute after the current date using Pacific Standard Time. For example "07/11/2020 7:00 AM".
To access this value, use `{$generateDate}` in later actions. -->
<generateDate date="+1 minute" format="m/d/Y g:i A" stepKey="generateDate"/>
Gets an entity (for example, a category), from the Magento API according to the data and metadata of the entity type that is requested.
Attribute | Type | Use | Description |
---|---|---|---|
storeCode |
string | optional | Identifier of the store from which to get the data. |
index |
integer | optional | The index in the returned data array. |
entity |
string | required | Name of the entity from which to get the data. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Get the product attribute that was created using `<createData stepKey="productAttributeHandle" ... />`. -->
<getData entity="ProductAttributeOptionGetter" index="1" stepKey="getAttributeOption1Handle">
<requiredEntity createDataKey="productAttributeHandle"/>
</getData>
The ProductAttributeOptionGetter
entity must be defined in the corresponding data *.xml
.
This action can optionally contain one or more requiredEntity child elements.
Generate a one-time password (OTP) based on a saved secret
at path magento/tfa/OTP_SHARED_SECRET
in a MFTF credential storage.
The one-time password (OTP) is returned and accessible through the stepkey.
MFTF use TOTP from Spomky-Labs/otphp, if you want to learn more about this action.
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<getOTP stepKey="getOtp"/>
See grabAttributeFrom docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
userInput |
string | optional | Name of tag attribute to grab. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Grab the `title` attribute from `<input id="myinput" ... >...</input>`.
To access this value, use `{$grabAttributeFromInput}` in later actions. -->
<grabAttributeFrom userInput="title" selector="input#myinput" stepKey="grabAttributeFromInput"/>
See grabCookie docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Name of the cookie to grab. |
parameterArray |
string | optional | Array of cookie parameters to grab. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Grab the cookie with the given name `cookie1`.
To access this value, use `{$grabCookie1}` in later actions. -->
<grabCookie userInput="cookie1" stepKey="grabCookie1"/>
<!-- Grab the cookie with the given name `cookie1` from the domain `www.example.com`.
To access this value, use `{$grabCookieExampleDomain}` in later actions. -->
<grabCookie userInput="cookie1" parameterArray="['domainName' => '.example.com']" stepKey="grabCookieExampleDomain"/>
See grabFromCurrentUrl docs on codeception.com..
Attribute | Type | Use | Description |
---|---|---|---|
regex |
string | optional | Regular expression against the current URI. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Grab the text from the current URL that matches the regex expression `~$/user/(\d+)/~`.
To access this value, use `{$grabFromCurrentUrl}` in later actions. -->
<grabFromCurrentUrl regex="~$/user/(\d+)/~" stepKey="grabFromCurrentUrl"/>
See grabMultiple docs on codeception.com..
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
userInput |
string | optional | Name of the tag attribute to grab. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Grab every element on the page with the class `myElement` and return them as an array.
To access this value, use `{$grabAllMyElements}` in later actions. -->
<grabMultiple selector="div.myElement" stepKey="grabAllMyElements"/>
<!-- Grab the `href` tag from every `a` element on the page and return them as an array.
To access this value, use `{$grabAllLinks}` in later actions. -->
<grabMultiple userInput="href" selector="a" stepKey="grabAllLinks"/>
See grabPageSource docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Store the page source code as text
To access this value, use `{$grabPageSource}` in later actions. -->
<grabPageSource stepKey="grabPageSource"/>
See grabTextFrom docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Store the text currently displayed by the selected element.
To access this value, use `{$grabTitle}` in later actions. -->
<grabTextFrom selector="h2#title" stepKey="grabTitle"/>
See grabValueFrom docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
selectorArray |
string | optional | Array of selectors for the form fields to be selected. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Store the value currently entered in <input id="name" ... >...</input>.
To access this value, use `{$grabInputName}` in later actions. -->
<grabValueFrom selector="input#name" stepKey="grabInputName"/>
Specifies what value is returned by an action group. The value can be then accessed in later steps using the action group stepKey. See Action groups returning a value for usage information.
Attribute | Type | Use | Description |
---|---|---|---|
value |
string | required | value returned by action group. |
stepKey |
string | required | A unique identifier of the action. |
<!-- Returns value of $grabInputName to the calling -->
<return value="{$grabInputName}" stepKey="returnInputName"/>
See loadSessionSnapshot docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Name of saved cookie. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Load all cookies saved via `<saveSessionSnapshot name="savedSnapshot" ... />`.
To access this value, use the `loadSessionSnapshot` action -->
<loadSessionSnapshot userInput="savedSnapshot" stepKey="loadSnapshot"/>
Specifies a CLI command to execute in a Magento environment.
Attribute | Type | Use | Description |
---|---|---|---|
command |
string | optional | CLI command to be executed in Magento environment. |
arguments |
string | optional | Unescaped arguments to be passed in with the CLI command. |
timeout |
string | optional | Number of seconds CLI command can run without outputting anything. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Re-index all indices via the command line. -->
<magentoCLI command="indexer:reindex" stepKey="reindex"/>
Used to execute Magento Cron jobs. Groups may be provided optionally. Internal mechanism of <magentoCron>
ensures that Cron Job of single group is ran with 60 seconds interval.
Attribute | Type | Use | Description |
---|---|---|---|
groups |
string | optional | Run only specified groups of Cron Jobs |
arguments |
string | optional | Unescaped arguments to be passed in with the CLI command. |
timeout |
string | optional | Number of seconds CLI command can run without outputting anything. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<magentoCron stepKey="runStagingCronJobs" groups="staging"/>
<!-- No interval here -->
<magentoCron stepKey="runIndexCronJobs" groups="index"/>
<!-- 60 seconds interval takes place here -->
<magentoCron stepKey="runAllCronJobs"/>
See makeScreenshot docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Name of PNG file to be created. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
Note that the makeScreenshot action does not automatically add the screenshot to Allure reports.
<!-- Take a screenshot of the page and save it to the directory `tests/_output/debug` under the name `example.png`. -->
<makeScreenshot userInput="example" stepKey="screenshotPage"/>
See maximizeWindow docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Maximize the current window. -->
<maximizeWindow stepKey="maximizeWindow"/>
See moveBack docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Move back one page in history. -->
<moveBack stepKey="moveBack"/>
See moveForward docs on codeception.com..
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Move forward one page in history. -->
<moveForward stepKey="moveForward"/>
See moveMouseOver docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
selectorArray |
string | optional | Array of selectors. |
x |
string | optional | Number of pixels on the x-axis to offset from the selected element. |
y |
string | optional | Number of pixels on the y-axis to offset from the selected element. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Move the mouse cursor over the selected element. -->
<moveMouseOver selector="button#product1" stepKey="hoverOverProduct1"/>
<!-- Move the mouse cursor over the selected element with an offset of 50px from the top and 50px from the left. -->
<moveMouseOver selector="button#product1" x="50" y="50" stepKey="hoverOverProduct2"/>
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Value of the expected locale. |
locale |
string | optional | Number of the locale value to be set. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
See openNewTab docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Open and switch to a new browser tab. -->
<openNewTab stepKey="openNewTab"/>
Parses float number with thousands separator.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Float value to be parsed. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
See usage of <pause
in interactive-pause and pause docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Halt test execution until the `enter` key is pressed to continue. -->
<pause stepKey="pause"/>
See pressKey docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
userInput |
string | optional | Key to be pressed. |
parameterArray |
string | optional | Array of keys to be pressed and functions to be run for the action. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Press the `a` key within the selected area. -->
<pressKey userInput="a" selector="#targetElement" stepKey="pressA"/>
The parameterArray
attribute value must begin with [
and end with ]
.
To press more than one key at a time, wrap the keys in secondary []
.
<!-- Press the delete within the selected area uses key constants from the WebDriverKeys class. -->
<pressKey selector="#targetElement" parameterArray="[['ctrl', 'a'], \Facebook\WebDriver\WebDriverKeys::DELETE]" stepKey="pressDelete"/>
See reloadPage docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Reload the current page. -->
<reloadPage stepKey="reloadPage"/>
Removes action by its stepKey
.
Attribute | Type | Use | Description |
---|---|---|---|
keyForRemoval |
string | required | Set stepKey of the action you want to remove. |
<!-- Remove an action in the test with the stepKey of `stepKeyToRemove`. -->
<remove keyForRemoval="stepKeyToRemove"/>
See resetCookie docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Name of the cookie to be reset. |
parameterArray |
string | optional | Array of key/values to get reset within the cookie. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Reset a cookie with the name `cookie1`. -->
<resetCookie userInput="cookie1" stepKey="resetCookie1"/>
<!-- Reset a cookie with the given name `cookie1` from the domain `www.example.com`. -->
<resetCookie userInput="cookie1" parameterArray="['domainName' => '.example.com']" stepKey="resetCookieExampleDomain"/>
See resizeWindow docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
width |
string | optional | The new width of the window in pixels. |
height |
string | optional | The new height of the window in pixels. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Resize the current window to a width of 800px and a height of 600px. -->
<resizeWindow width="800" height="600" stepKey="resizeWindow"/>
See saveSessionSnapshot docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Name of snapshot where cookies are to be saved. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Save all of the current cookies under the name `savedSnapshot`. -->
<saveSessionSnapshot userInput="savedSnapshot" stepKey="saveCurrentCookies"/>
See scrollTo docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
selectorArray |
string | optional | Array of selectors to return. |
x |
string | optional | x offset of the element to be scrolled to. |
y |
string | optional | y offset of the element to be scrolled to. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Move the page to the middle of the selected area. -->
<scrollTo selector="div#anchor" stepKey="scrollToAnchor"/>
<!-- Move the page to the middle of the selected area with an offset of 50px from the top and 50px from the left. -->
<scrollTo selector="div#anchor" x="50" y="50" stepKey="scrollToAnchor2"/>
A convenience function that executes window.scrollTo(0,0)
as JavaScript, thus returning to the top of the page.
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Move the page to the uppermost, leftmost position. -->
<scrollToTopOfPage stepKey="scrollToTopOfPages"/>
Search for and select options from a Magento multi-select drop-down menu. For example, the drop-down menu you use to assign Products to Categories.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | required | The selector of a multi select HTML element (drop-down menu). |
parameterArray |
array | required | Items to search and select in the selected drop-down menu. |
requiredAction |
boolean | optional | Clicks Done after selections if true . |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Search and select for "Item 1" amd "Item 2" in the Magento multiselect element with the id of `multiSelect`. -->
<searchAndMultiSelectOption selector="#multiSelect" parameterArray="['Item 1', 'Item 2']" stepKey="searchAndMultiSelect1"/>
On this test step the MFTF:
- Searches for a drop-down HTML element that matches the
#stuff
selector. - Opens the drop-down menu.
- Enters Item 1 in a search field of the drop-down element.
- Selects first element from the filtered results.
- Enters Item 2 in a search field of the drop-down element.
- Selects first element from the filtered results.
See see docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | The text to be searched for within the selector. |
selector |
string | optional | The selector identifying the corresponding HTML element to be searched for. |
selectorArray |
string | optional | Array of selectors to be searched for. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that the selected element contains the text "Sample title". -->
<see userInput="Sample title" selector="h2#title" stepKey="seeTitle"/>
See seeCheckboxIsChecked docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify `<input type="checkbox" id="option1" ... >...</input>` is checked. -->
<seeCheckboxIsChecked selector="input#option1" stepKey="seeCheckboxChecked"/>
See seeCookie docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Name of the cookie to be searched for. |
parameterArray |
string | optional | Cookie parameters to be searched for. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that there is a cookie with the given name `cookie1`. -->
<seeCookie userInput="cookie1" stepKey="cookie1Present"/>
<!-- Verify that there is a cookie with the given name `cookie1` from the domain `www.example.com`. -->
<seeCookie userInput="cookie1" parameterArray="['domainName' => 'www.example.com']" stepKey="seeCookieInExampleDomain"/>
See seeCurrentUrlEquals docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
url |
string | optional | The full URL to be searched for. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that the relative URL of the current page matches `/admin`. -->
<seeCurrentUrlEquals url="/admin" stepKey="onAdminPage"/>
See seeCurrentUrlMatches docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
regex |
string | optional | Regular expression against the current URI. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that the relative URL of the current page matches the `~$/users/(\d+)~` regular expression. -->
<seeCurrentUrlMatches regex="~$/users/(\d+)~" stepKey="seeCurrentUrlMatches"/>
See seeElement docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
selectorArray |
string | optional | Array of selectors to be searched for. |
parameterArray |
string | optional | Array of parameters to be searched for within the selector. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that `<div id="box" ... >...</div>` is available and visible on the current page. -->
<seeElement selector="div#box" stepKey="seeBox"/>
See seeElementInDOM docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
parameterArray |
string | optional | Array of parameters to be searched for within the selected element. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that `<div id="box" ... >...</div>` is available on the current page. -->
<seeElementInDOM selector="div#box" stepKey="seeBoxInDOM"/>
See seeInCurrentUrl docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
url |
string | optional | String to be searched for within the current URL. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that the url of the current active tab contains the string "/users/". -->
<seeInCurrentUrl url="/users/" stepKey="seeInCurrentUrl"/>
See seeInField docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
selectorArray |
string | optional | Array of selectors to be searched. |
userInput |
string | optional | Value to be searched for within the selected form field. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that `<input id="field" ... >...</input>` contains the text "Sample text". -->
<seeInField userInput="Sample text" selector="input#field" stepKey="seeInField"/>
See seeInFormFields docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
parameterArray |
string | optional | Array of parameters to be searched for within the selector. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that `<form name="myform" ... >...</form>` with the input elements `<input name="input1">...</input>` and `<input name="input2">...</input>`, has the values of `value1` and `value2` respectively. -->
<seeInFormFields selector="form[name=myform]" parameterArray="['input1' => 'value1', 'input2' => 'value2']" stepKey="seeInFormFields"/>
See seeInPageSource docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
html |
string | required | HTML code to be searched for within the page source. The value must be entity-encoded. See example. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
You must encode the html
using a tool such as CyberChef.
<!-- Verify that the page source contains the raw source code `<h1 class="login-header">`. -->
<seeInPageSource html="<h1 class="login-header">" stepKey="seeInPageSource"/>
See seeInPopup docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | String to be searched for within the popup. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify the current popup on the page contains the string "Sample text". -->
<seeInPopup userInput="Sample text" stepKey="seeInPopup"/>
See seeInSource docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
html |
string | required | HTML code to be searched for within the page source. The value must be entity-encoded. See example. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
You must encode the html
using a tool such as CyberChef.
<!-- Verify that the page source contains the raw source code `<h1 class="login-header">`. -->
<seeInSource html="<h1 class="login-header">" stepKey="seeInSource"/>
See seeInTitle docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | String to be searched for within the current page title. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that the title of the current active window contains the text "Page Title". -->
<seeInTitle userInput="Page Title" stepKey="seeInTitle"/>
See seeLink docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | String to be searched for within the text of the link. |
url |
string | optional | Hyperlink to be searched. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that there is a hyperlink tag on the page with the text "External link". -->
<seeLink userInput="External link" stepKey="seeLink"/>
<!-- Verify that there is a hyperlink tag with the text "External link" and the `href` attribute of `/admin`. -->
<seeLink userInput="External link" url="/admin" stepKey="seeAdminLink"/>
See seeNumberOfElements docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
userInput |
string | optional | Number of instances of the specified selector to be found. |
parameterArray |
string | optional | Array of parameters to be searched for within the selector. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify there are 10 `<div class="product" ... >...</div>` elements on the page. -->
<seeNumberOfElements userInput="10" selector="div.product" stepKey="seeTenProducts"/>
<!-- Verify there are between 5 and 10 `<div class="product" ... >...</div>` elements on the page. -->
<seeNumberOfElements parameterArray="[5, 10]" selector="div.product" stepKey="seeFiveToTenProducts"/>
See seeOptionIsSelected docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
userInput |
string | optional | The name of the option that should be selected. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Verify that `<select id="myselect" ... >...</select>` has the option `option1` selected -->
<seeOptionIsSelected userInput="option1" selector="select#myselect" stepKey="seeOption1"/>
See selectOption docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
userInput |
string | optional | The name of the option to be selected. |
parameterArray |
string | optional | Array of options to be selected. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Select `option1` from `<select id="mySelect" ... >...</select>`. -->
<selectOption userInput="option1" selector="select#mySelect" stepKey="selectOption1"/>
Selects all given options in the given Magento drop-down element.
Attribute | Type | Use | Description |
---|---|---|---|
filterSelector |
string | required | The selector for the text filter field. |
optionSelector |
string | required | The selector used to select the corresponding options based on the filter field. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
It contains a child element <array>
where you specify the options that must be selected using an array format like ['opt1', 'opt2']
.
<!-- Select the options `opt1` and `opt2` from `<option class="option" ... >...</option>` and `<input class="filter" ...>...</input>` -->
<selectMultipleOptions filterSelector=".filter" optionSelector=".option" stepKey="selectMultipleOpts1">
<array>['opt1', 'opt2']</array>
</selectMultipleOptions>
See setCookie docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | The name of the cookie to be set. |
parameterArray |
string | optional | Array of name/value pairs to be set within the cookie. |
value |
string | optional | Value to be written to the cookie. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Set a cookie with the name of `cookieName` and value of `cookieValue`. -->
<setCookie userInput="cookieName" value="cookieValue" stepKey="setCookie"/>
See submitForm docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
parameterArray |
string | optional | An array of form field names and their corresponding values. |
button |
string | optional | Selector for the form submit button. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Submit a value of `admin` for `<input name="username" ... >...</input>`, a value of `123123q` for `<input name="password" ... >...</input>` for the form `<form id="loginForm" ...>...</form>` and a submit button of `<button id="submit" ... >...</button>` -->
<submitForm selector="#loginForm" parameterArray="['username' => 'admin','password' => '123123q']" button="#submit" stepKey="submitForm"/>
See switchToIFrame docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
userInput |
string | optional | The name of the IFrame to set focus to. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Set the focus to <iframe name="embeddedFrame" ... /> -->
<switchToIFrame userInput="embeddedFrame" stepKey="switchToIFrame"/>
See switchToNextTab docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Offset of the tab to open, usually a number. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Switch to the next tab. -->
<switchToNextTab stepKey="switchToNextTab"/>
<!-- Switch to the third next tab. -->
<switchToNextTab userInput="3" stepKey="switchToThirdNextTab"/>
See switchToPreviousTab docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | Number of tabs to go back. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Switch to the previous tab. -->
<switchToPreviousTab stepKey="switchToPreviousTab"/>
<!-- Switch to the third previous tab. -->
<switchToPreviousTab userInput="3" stepKey="switchToThirdPreviousTab"/>
See switchToWindow docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | The name of new window to be opened. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Switch to a window with the `name` parameter of `newWindow`. -->
<switchToWindow userInput="newWindow" stepKey="switchToWindow"/>
See typeInPopup docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | String to be added to the current popup. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Type the text "Sample Text" into the current popup visible on the page. -->
<typeInPopup userInput="Sample Text" stepKey="typeInPopup"/>
See uncheckOption docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Ensure the checkbox `<input type="checkbox" id="checkbox" ... >...</input>` is unchecked. -->
<uncheckOption selector="input#checkbox" stepKey="uncheckCheckbox"/>
See unselectOption docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
userInput |
string | optional | The name of the option to deselect. |
parameterArray |
string | optional | Array of options to be deselected. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Deselect `option1` from `<select id="mySelect" ... >...</select>`. -->
<unselectOption userInput="option1" selector="select#myselect" stepKey="unselectOption1"/>
When you create a data entity using createData
, you may need to update it later in the test.
The updateData
action allows this.
For example, to change the price of a product:
<updateData entity="AdjustPriceProduct" createDataKey="productHandle" stepKey="updateProduct"/>
Where AdjustPriceProduct
simply looks like this:
<entity name="AdjustPriceProduct" type="product">
<data key="price">321.00</data>
</entity>
Only the fields that you want to update are set.
Attribute | Type | Use | Description |
---|---|---|---|
storeCode |
string | optional | ID of the store in which to apply the updated data. |
entity |
string | required | The name of the updateData entity being created. |
createDataKey |
string | required | Key of the data entity to be updated. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
This action can optionally contain one or more requiredEntity child elements.
See wait docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
time |
string | optional | The number of seconds to wait. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Halt test execution for 10 seconds before continuing. -->
<wait time="10" stepKey="waitTenSeconds"/>
Wait for all AJAX calls to finish.
Attribute | Type | Use | Description |
---|---|---|---|
time |
string | optional | The number of seconds to wait for Ajax calls to finish. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Wait up to 30 seconds for all AJAX calls to finish before continuing. -->
<waitForAjaxLoad stepKey="waitForAjaxLoad"/>
See waitForElementChange docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the HTML element to be changed. |
function |
string | optional | The function to be run after the element changes. |
time |
string | optional | The number of seconds to wait for the change. Default is 30. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Wait up to 30 seconds for `<div id="changedElement" ... >...</div>` to change to displayed before continuing. -->
<waitForElementChange selector="div#changedElement" function="function(\WebDriverElement $el) {return $el->isDisplayed();}" stepKey="waitForElementChange"/>
See waitForElement docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
time |
string | optional | The number of seconds to wait for the element to appear. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Wait up to 30 seconds for `<div id="changedElement" ... >...</div>` to be appear on the page before continuing. -->
<waitForElement selector="#changedElement" stepKey="waitForElement"/>
See waitForElementNotVisible docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
time |
string | optional | The number of seconds to wait for the element to become not visible. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Wait up to 30 seconds for `<div id="changedElement" ... >...</div>` to become non-visible on the page before continuing. -->
<waitForElementNotVisible selector="#changedElement" stepKey="waitForElementNotVisible"/>
See waitForElementVisible docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
selector |
string | optional | The selector identifying the corresponding HTML element. |
time |
string | optional | The number of seconds to wait for the element to appear. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Wait up to 30 seconds for `<div id="changedElement" ... >...</div>` to become visible on the page before continuing. -->
<waitForElementVisible selector="#changedElement" stepKey="waitForElementVisible"/>
See waitForJS docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
function |
string | optional | The function to be run after all JavaScript finishes. |
time |
string | optional | The number of seconds to wait for JavaScript to finish. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Wait for all jQuery AJAX requests to finish before continuing. -->
<waitForJS function="return $.active == 0;" stepKey="waitForJS"/>
Wait for all Magento loading overlays to disappear.
# Wait for these classes to not be visible
//div[contains(@class, "loading-mask")]
//div[contains(@class, "admin_data-grid-loading-mask")]
//div[contains(@class, "admin__data-grid-loading-mask")]
//div[contains(@class, "admin__form-loading-mask")]
//div[@data-role="spinner"]
Attribute | Type | Use | Description |
---|---|---|---|
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Wait up to 30 seconds for all Magento loading overlays to disappear before continuing. -->
<waitForLoadingMaskToDisappear stepKey="waitForLoadingMaskToDisappear"/>
Wait for AJAX, Magento loading overlays, and document.readyState == "complete"
.
Attribute | Type | Use | Description |
---|---|---|---|
time |
string | optional | Number of seconds to wait for the page to load. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Wait up to 30 seconds for the current page to fully load before continuing. -->
<waitForPageLoad stepKey="waitForPageLoad"/>
Waits up to the given time
for a PWA Element to disappear from the screen.
Attribute | Type | Use | Description |
---|---|---|---|
time |
string | optional | Number of seconds to wait for the element to disappear. |
selector |
string | required | The selector identifying the corresponding HTML element. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Wait for the PWA element to disappear. -->
<waitForPwaElementNotVisible time="1" stepKey="waitForPwaElementNotVisible"/>
Waits up to the given 'time' for a PWA Element to appear on the screen.
Attribute | Type | Use | Description |
---|---|---|---|
time |
string | optional | Number of seconds to wait for the selected element. |
selector |
string | required | The selector identifying the corresponding HTML element. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Wait for the selected element to appear. -->
<waitForPwaElementVisible stepKey="waitForPwaElementVisible"/>
See waitForText docs on codeception.com.
Attribute | Type | Use | Description |
---|---|---|---|
userInput |
string | optional | The string to wait for. |
time |
string | optional | The number of seconds to wait for the text to appear. |
selector |
string | optional | The selector identifying the corresponding HTML element. |
stepKey |
string | required | A unique identifier of the action. |
before |
string | optional | stepKey of action that must be executed next. |
after |
string | optional | stepKey of preceding action. |
<!-- Wait for text "Sample Text" to appear in the selected area before continuing. -->
<waitForText userInput="Sample Text" selector="div#page" stepKey="waitForText"/>