facile-it/doctrine-test-module 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

facile-it/doctrine-test-module

最新稳定版本:1.0.0

Composer 安装命令:

composer require --dev facile-it/doctrine-test-module

包简介

Laminas Framework module that provides features that help you run your Laminas-based App's testsuite more efficiently with isolated tests

README 文档

README

Laminas module that provides features that help you run your Laminas App's testsuite more efficiently with isolated tests.

Based on Symfony's doctrine-test-bundle.

It provides a StaticDriver that will wrap your originally configured Driver class (like DBAL\Driver\PDOMysql\Driver) and keeps a database connection statically in the current php process.

With the help of a PHPUnit extension class it will begin a transaction before every testcase and roll it back again after the test finished for all configured DBAL connections. This results in a performance boost as there is no need to rebuild the schema, import a backup SQL dump or re-insert fixtures before every testcase. As long as you avoid issuing DDL queries that might result in implicit transaction commits (Like ALTER TABLE, DROP TABLE etc; see https://wiki.postgresql.org/wiki/Transactional_DDL_in_PostgreSQL:_A_Competitive_Analysis) your tests will be isolated and all see the same database state.

How to install and use this Module?

  1. install via composer

    composer require --dev facile-it/doctrine-test-module
  2. Enable the module for your test environment in your config/application.php

    <?php
    
    return [
        'modules' => [
           'Facile\DoctrineTestModule',
        ],
    ];

Using the Module with PHPUnit

  1. Add the Extension to your PHPUnit XML config

    • PHPUnit 9:

      <phpunit>
          ...
          <extensions>
              <extension class="Facile\DoctrineTestModule\PHPUnit\PHPUnitExtension" />
          </extensions>
      </phpunit>
    • PHPUnit 10+:

      <phpunit>
          ...
          <extensions>
              <bootstrap class="Facile\DoctrineTestModule\PHPUnit\PHPUnitExtension" />
          </extensions>
      </phpunit>
  2. Make sure you also have phpunit/phpunit available as a dev dependency (versions 9 and 10 are supported with the built-in extension) to run your tests.

  3. That's it! From now on whatever changes you do to the database within each single testcase are automatically rolled back for you 😊

Configuration

The module exposes a configuration that looks like this by default:

use Facile\DoctrineTestModule\ConfigProvider;

return [
    ConfigProvider::CONFIGURATION: [
        'enable_static_connection' => true,
    ]
];

Setting enable_static_connection: true means it will enable it for all configured doctrine dbal connections.

You can selectively only enable it for some connections if required:

use Facile\DoctrineTestModule\ConfigProvider;

return [
    ConfigProvider::CONFIGURATION: [
        'enable_static_connection' => [
            'orm_default' => true,
        ],
    ]
];

统计信息

  • 总下载量: 16.28k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 4
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2018-07-04