tddwizard / magento2-fixtures
Fixture library for Magento 2 integration tests
Installs: 379 111
Dependents: 14
Suggesters: 0
Security: 0
Stars: 142
Watchers: 10
Forks: 28
Open Issues: 18
Type:magento2-module
Requires
- php: ^7.1|^8.0
- fakerphp/faker: ^1.9.1
- magento/framework: ^102.0|^103.0
- 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
- magento/zendframework1: ^1.14
Requires (Dev)
- ext-json: *
- magento/module-store: ^101.0
- pds/skeleton: ^1.0
- phpro/grumphp: ^0.19.0
- phpstan/phpstan: ^0.12.0
- phpunit/phpunit: ^6.0|^9.0
- squizlabs/php_codesniffer: ^3.3.1
- dev-master
- v1.1.2
- v1.1.1
- 1.1.0
- 1.1.0-rc1
- v1.0.0
- v0.12.1
- v0.12.0
- v0.11.0
- v0.10.0
- v0.9.0
- v0.8.0
- v0.7.0
- v0.6.0
- v0.5.0
- v0.4.0
- v0.3.1
- v0.3.0
- v0.2.0
- v0.1.1
- v0.1.0
- dev-dependabot/github_actions/dot-github/workflows/actions/download-artifact-4.1.7
- dev-php81
- dev-use-faker-fork
- dev-replace-faker
- dev-multi-source-inventory
- dev-graceful-rollback
- dev-theme-fixture
- dev-fixing-stuff
- dev-config-fixture
- dev-travis
- dev-virtual-products
- dev-analysis
- dev-address-builder-extension-fix-conflicts
- dev-lfolco-backorders
- dev-develop
This package is not auto-updated.
Last update: 2024-10-23 02:56:42 UTC
README
Magento 2 Fixtures by Fabian Schmengler
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
Installation
Install it into your Magento 2 project with composer:
composer require --dev tddwizard/magento2-fixtures
Requirements
- Magento 2.3 or Magento 2.4
- PHP 7.3 or 7.4 (7.1 and 7.2 is allowed via composer for full Magento 2.3 compatibility but not tested anymore)
Usage examples:
Customer
If you need a customer without specific data, this is all:
protected function setUp(): void { $this->customerFixture = new CustomerFixture( CustomerBuilder::aCustomer()->build() ); } protected function tearDown(): void { $this->customerFixture->rollback(); }
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('test@example.com') ->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();
Addresses
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(): void { $this->productFixture = new ProductFixture( ProductBuilder::aSimpleProduct() ->withPrice(10) ->withCustomAttributes( [ 'my_custom_attribute' => 42 ] ) ->build() ); } protected function tearDown(): void { $this->productFixture->rollback(); }
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:
$customerFixture = new CustomerFixture(CustomerBuilder::aCustomer()->withAddresses( AddressBuilder::anAddress()->asDefaultBilling(), AddressBuilder::anAddress()->asDefaultShipping() )->build()); $customerFixture->login(); $checkout = CustomerCheckout::fromCart( CartBuilder::forCurrentSession() ->withProductRequest(ProductBuilder::aVirtualProduct()->build()->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();
Order
The OrderBuilder
is a shortcut for checkout simulation.
$order = OrderBuilder::anOrder()->build();
Logged-in customer, products, and cart item quantities will be generated internally unless more control is desired:
$order = OrderBuilder::anOrder() ->withProducts( // prepare catalog product fixtures ProductBuilder::aSimpleProduct()->withSku('foo'), ProductBuilder::aSimpleProduct()->withSku('bar') )->withCart( // define cart item quantities CartBuilder::forCurrentSession()->withSimpleProduct('foo', 2)->withSimpleProduct('bar', 3) )->build();
Shipment
Orders can be fully or partially shipped, optionally with tracks.
$order = OrderBuilder::anOrder()->build(); // ship everything $shipment = ShipmentBuilder::forOrder($order)->build(); // ship only given order items, add tracks $shipment = ShipmentBuilder::forOrder($order) ->withItem($fooItemId, $fooQtyToShip) ->withItem($barItemId, $barQtyToShip) ->withTrackingNumbers('123-FOO', '456-BAR') ->build();
Invoice
Orders can be fully or partially invoiced.
$order = OrderBuilder::anOrder()->build(); // invoice everything $invoice = InvoiceBuilder::forOrder($order)->build(); // invoice only given order items $invoice = InvoiceBuilder::forOrder($order) ->withItem($fooItemId, $fooQtyToInvoice) ->withItem($barItemId, $barQtyToInvoice) ->build();
Credit Memo
Credit memos can be created for either all or some of the items ordered. An invoice to refund will be created internally.
$order = OrderBuilder::anOrder()->build(); // refund everything $creditmemo = CreditmemoBuilder::forOrder($order)->build(); // refund only given order items $creditmemo = CreditmemoBuilder::forOrder($order) ->withItem($fooItemId, $fooQtyToRefund) ->withItem($barItemId, $barQtyToRefund) ->build();
Fixture pools
To manage multiple fixtures, fixture pools have been introduced for all entities:
Usage demonstrated with the ProductFixturePool
:
protected function setUp()
{
$this->productFixtures = new ProductFixturePool;
}
protected function tearDown()
{
$this->productFixtures->rollback();
}
public function testSomethingWithMultipleProducts()
{
$this->productFixtures->add(ProductBuilder::aSimpleProduct()->build());
$this->productFixtures->add(ProductBuilder::aSimpleProduct()->build(), 'foo');
$this->productFixtures->add(ProductBuilder::aSimpleProduct()->build());
$this->productFixtures->get(); // returns ProductFixture object for last added product
$this->productFixtures->get('foo'); // returns ProductFixture object for product added with specific key 'foo'
$this->productFixtures->get(0); // returns ProductFixture object for first product added without specific key (numeric array index)
}
Config Fixtures
With the config fixture you can set a configuration value globally, i.e. it will ensure that it is not only set in the default scope but also in all store scopes:
ConfigFixture::setGlobal('general/store_information/name', 'Ye Olde Wizard Shop');
It uses MutableScopeConfigInterface
, so the configuration is not persisted in the database. Use @magentoAppIsolation enabled
in your test to make sure that changes are reverted in subsequent tests.
You can also set configuration values explicitly for stores with ConfigFixture::setForStore()
Credits
License
The MIT License (MIT). Please see License File for more information.