This package simplifies the process of automated testing with real database and search engine
- 📦 Pre-configured database and search containers: Instantly spin up containers with ready-to-use Magento data
- ⚙️ Easy setup and use: Use PHP package to automatically discard container after tests
- 🎯 Blazingly Fast: Container takes only few seconds to start, so you can focus on testing instead of waiting for db initialization
- 🐳 Docker: Ensure Docker is installed and operational on your system.
All the available Docker image version can be found in build repository EcomDev/testcontainer-magento-data
Use composer with --dev
flag to add it as dependency for your tests
composer require --dev ecomdev/testcontainers-magento-data
Create Latest Magento Database Build
use EcomDev\TestContainers\MagentoData\DbContainerBuilder;
$container = DbContainerBuilder::mysql()
->build();
Create Latest Magento Database Build with sample data
use EcomDev\TestContainers\MagentoData\DbContainerBuilder;
$container = DbContainerBuilder::mysql()
->withSampleData()
->build();
Create 2.4.7-p2 with sample data and fetch number of products
use EcomDev\TestContainers\MagentoData\DbContainerBuilder;
use PDO;
$container = DbContainerBuilder::mysql()
->withMagentoVersion('2.4.7-p2')
->withSampleData()
->build();
$connectionSettings = $container->getConnectionSettings();
$connection = new PDO(
$connectionSettings->dsn(),
$connectionSettings->user,
$connectionSettings->password
);
$result = $connection->query('SELECT COUNT(*) FROM catalog_product_entity');
// Outputs 2040
echo $result->fetch(PDO::FETCH_COLUMN);
Everything the same as for MySQL container, just a different builder method
use EcomDev\TestContainers\MagentoData\DbContainerBuilder;
$container = DbContainerBuilder::mariadb()
->withMagentoVersion('2.4.7-p2')
->withSampleData()
->build();
For OpenSearch container there is a different builder and container, that allows building base url for http connection
Here is a small example
use EcomDev\TestContainers\MagentoData\OpenSearchContainerBuilder;
use GuzzleHttp\Client;
$container = OpenSearchContainerBuilder::new()
->withSampleData()
->build();
$client = new Client([
'base_uri' => $container->getBaseUrl()
]);
$result = json_decode(
$client->get('magento2_product_1/_count')->getBody()->getContents(),
true
);
// Outputs 181
echo $result['count'];
This project is licensed under the MIT License.
See the LICENSE file for more details.