tddwizard / magento2-fixtures
tddwizard/magento2-fixtures
Fixture library for Magento 2 integration tests
TddWizard Fixture library
This library is in alpha state, that means:
- it's super incomplete
- nothing is guaranteed to work
- everything can still be changed
What is it?
An alternative to the procedural script based fixtures in Magento 2 integration tests.
It aims to be:
- extensible
- expressive
- easy to use
Usage examples:
Customer
If you need a customer without specific data, this is all:
protected function setUp()
{
$this->customerFixture = new CustomerFixture(
CustomerBuilder::aCustomer()->build()
);
}
protected function tearDown()
{
CustomerFixtureRollback::create()->execute($this->customerFixture);
}
It uses default sample data and a random email address. If you need the ID or email address in the tests, the CustomerFixture gives you access:
$this->customerFixture->getId();
$this->customerFixture->getEmail();
You can configure the builder with attributes:
CustomerBuilder::aCustomer()
->withEmail('[email protected]')
->withCustomAttributes(
[
'my_custom_attribute' => 42
]
)
->build()
You can add addresses to the customer:
CustomerBuilder::aCustomer()
->withAddresses(
AddressBuilder::anAddress()->asDefaultBilling(),
AddressBuilder::anAddress()->asDefaultShipping(),
AddressBuilder::anAddress()
)
->build()
Or just one:
CustomerBuilder::aCustomer()
->withAddresses(
AddressBuilder::anAddress()->asDefaultBilling()->asDefaultShipping()
)
->build()
The CustomerFixture also has a shortcut to create a customer session:
$this->customerFixture->login();
Adresses
Similar to the customer builder you can also configure the address builder with custom attributes:
AddressBuilder::anAddress()
->withCountryId('DE')
->withCity('Aachen')
->withPostcode('52078')
->withCustomAttributes(
[
'my_custom_attribute' => 42
]
)
->asDefaultShipping()
Product
Product fixtures work similar as customer fixtures:
protected function setUp()
{
$this->productFixture = new ProductFixture(
ProductBuilder::aSimpleProduct()
->withPrice(10)
->withCustomAttributes(
[
'my_custom_attribute' => 42
]
)
->build()
);
}
protected function tearDown()
{
ProductFixtureRollback::create()->execute($this->productFixture);
}
The SKU is randomly generated and can be accessed through ProductFixture, just as the ID:
$this->productFixture->getSku();
$this->productFixture->getId();
Cart/Checkout
To create a quote, use the CartBuilder together with product fixtures:
$cart = CartBuilder::forCurrentSession()
->withSimpleProduct(
$productFixture1->getSku()
)
->withSimpleProduct(
$productFixture2->getSku(), 10 // optional qty parameter
)
->build()
$quote = $cart->getQuote();
Checkout is supported for logged in customers. To create an order, you can simulate the checkout as follows, given a customer fixture with default shipping and billing addresses and a product fixture:
$this->customerFixture->login();
$checkout = CustomerCheckout::fromCart(
CartBuilder::forCurrentSession()
->withSimpleProduct(
$productFixture->getSku()
)
->build()
);
$order = $checkout->placeOrder();
It will try to select the default addresses and the first available shipping and payment methods.
You can also select them explicitly:
$order = $checkout
->withShippingMethodCode('freeshipping_freeshipping')
->withPaymentMethodCode('checkmo')
->withCustomerBillingAddressId($this->customerFixture->getOtherAddressId())
->withCustomerShippingAddressId($this->customerFixture->getOtherAddressId())
->placeOrder();
No changelog yet
The vendor hasn't published a changelog. Tagged releases appear in the Versions tab.
| Version | Stability | QA Status | Released |
|---|---|---|---|
| 1.2.0 | stable | Fail | 2025-10-24 09:33:50 |
| 1.1.2 | stable | Not tested | 2022-05-24 15:35:13 |
| 1.1.1 | stable | Not tested | 2022-04-28 07:29:11 |
| 1.1.0 | stable | Not tested | 2021-05-05 06:37:45 |
| 1.1.0-rc1 | RC | Not tested | 2021-02-18 09:55:31 |
| 1.0.0 | stable | Not tested | 2020-10-03 19:50:59 |
| 0.12.1 | stable | Not tested | 2020-09-03 16:21:39 |
| 0.12.0 | stable | Not tested | 2020-08-27 15:27:04 |
| 0.11.0 | stable | Not tested | 2020-07-28 14:43:43 |
| 0.10.0 | stable | Not tested | 2020-05-08 21:27:51 |
| 0.9.0 | stable | Not tested | 2020-04-07 18:29:47 |
| 0.8.0 | stable | Not tested | 2019-03-01 23:15:23 |
| 0.7.0 | stable | Not tested | 2018-11-22 11:37:07 |
| 0.6.0 | stable | Not tested | 2018-11-15 21:07:56 |
| 0.5.0 | stable | Not tested | 2018-10-16 16:59:28 |
| 0.4.0 | stable | Not tested | 2018-09-27 07:53:55 |
| 0.3.1 | stable | Not tested | 2018-01-11 13:13:54 |
| 0.3.0 | stable | Not tested | 2017-12-14 14:55:56 |
| 0.2.0 | stable | Not tested | 2017-12-14 11:08:55 |
| 0.1.1 | stable | Not tested | 2017-10-05 18:01:55 |
| 0.1.0 | stable | Not tested | 2017-08-05 23:05:02 |
Requires 13
| Package | Constraint |
|---|---|
| php | ^7.1|^8.0 |
| magento/framework | ^102.0|^103.0 |
| magento/zendframework1 | ^1.14 |
| magento/module-catalog | ^103.0|^104.0 |
| magento/module-catalog-inventory | ^100.3 |
| magento/module-checkout | ^100.3 |
| magento/module-customer | ^102.0|^103.0 |
| magento/module-directory | ^100.3 |
| magento/module-indexer | ^100.3 |
| magento/module-payment | ^100.3 |
| magento/module-quote | ^101.1 |
| magento/module-sales | ^102.0|^103.0 |
| fakerphp/faker | ^1.9.1 |
Requires-dev 7
| Package | Constraint |
|---|---|
| ext-json | * |
| magento/module-store | ^101.0 |
| phpunit/phpunit | ^6.0|^9.0 |
| pds/skeleton | ^1.0 |
| phpro/grumphp | ^0.19.0 |
| phpstan/phpstan | ^0.12.0 |
| squizlabs/php_codesniffer | ^3.3.1 |
No QA results yet
QA pipelines haven't run for this version. Status appears here once the vendor publishes a tagged release that gets ingested.
Turn an existing module into recurring revenue.
If you already maintain a Magento 2 module on GitHub or GitLab, listing it on Packagento takes about five minutes. We mirror your tags, handle distribution signing, and route paid licenses through Stripe Connect, so you can keep shipping the way you already do.