Test cases in the Magento Functional Testing Framework (MFTF) are defined in XML as <tests>
.
<tests>
is a Codeception test container that contains individual test <test>
with its metadata (<annotations>
), before (<before>
) and after (<after>
) section.
MFTF <test>
is considered a sequence of actions with associated parameters.
Any failed assertion within a test constitutes a failed test.
The following diagram shows the structure of an MFTF test case:
The format of a test XML file is:
<?xml version="1.0" encoding="UTF-8"?>
<tests xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="urn:magento:mftf:Test/etc/testSchema.xsd">
<test name="" insertBefore="" insertAfter="">
<annotations>
<!-- TEST ANNOTATIONS -->
</annotations>
<before>
<!-- ACTIONS AND ACTION GROUPS PERFORMED BEFORE THE TEST -->
</before>
<after>
<!-- ACTIONS AND ACTION GROUPS PERFORMED AFTER THE TEST -->
</after>
<!-- TEST ACTIONS, ACTION GROUPS, AND ASSERTIONS-->
</test>
</tests>
The following conventions apply to MFTF tests:
- One
<test>
tag is allowed per test XML file. - All names within the framework are in the PascalCase format and must be alphanumeric.
- Each action and action group call should have its own identifier
<stepKey>
. - A test may have any number of assertions at any point within the
<test>
. - If
<test>
is included in<suite>
, it cannot be generated in isolation from<before>
and<after>
section of the suite (see suites for details).
There are several XML elements that are used within <test>
in the MFTF.
<tests>
is a container for test and must contain exactly one <test>
.
<test>
is a set of steps, including actions, assertions and Action Group calls. It is a sequence of test steps that define test flow within a test method.
Attribute | Type | Use | Description |
---|---|---|---|
name |
string | optional | The test identifier. |
remove |
boolean | optional | Set true to remove the test when merging. |
insertBefore |
string | optional | This option is used for merging. It enables you to add all test actions contained in the original test into a test with the same name BEFORE the test step with stepKey that you assigned in insertBefore . |
insertAfter |
string | optional | Set stepKey of the test step after which you want to insert the test when merging. |
deprecated |
string | optional | Used to warn about the future deprecation of the test. String will appear in Allure reports and console output at runtime. |
extends |
string | optional | A name of the parent test to extend. |
<test>
may also contain <annotations>
, <before>
, <after>
, any action, or <actionGroup>
.
Annotations are supported by both Codeception and Allure.
Codeception annotations typically provide metadata and are able to influence test selection. Allure annotations provide metadata for reporting.
<before>
wraps the steps that are preconditions for the <test>
. For example: Change configuration, create Customer Account, Create Category and Product.
<before>
may contain these child elements:
- Any Action
<actionGroup>
<after>
wraps the steps to perform after the <test>
. The steps are run in both successful and failed test runs. The goal of this section is to perform cleanup (revert the environment to the pre-test state).
<after>
may contain:
- Any Action
<actionGroup>
<actionGroup>
calls a corresponding action group.
Attribute | Type | Use | Description |
---|---|---|---|
ref |
string | required | References the required action group by its name . |
stepKey |
string | required | Identifies the element within <test> . |
before |
string | optional | <stepKey> of an action or action group that must be executed next while merging. |
after |
string | optional | <stepKey> of an action or action group that must be executed one step before the current one while merging. |
<actionGroup>
may contain <argument>
.
<argument>
sets an argument that is used in the parent <actionGroup>
.
Attribute | Type | Use |
---|---|---|
name |
string | optional |
value |
string | optional |
See Action groups for more information.