lucaszz/doctrine-database-backup 问题修复 & 功能扩展

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

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

lucaszz/doctrine-database-backup

最新稳定版本:1.2.3

Composer 安装命令:

composer require lucaszz/doctrine-database-backup

包简介

Doctrine Database Backup

README 文档

README

Build Status Latest Stable Version Total Downloads Coverage Status

DoctrineDatabaseBackup is simple library for speed up tests in your app. It could be used for PHPUnit tests or Behat tests running from command line. My target was to avoid wasting time for dropping/creating or purging database for each test, so I optimized it.

This library puts contents of database to memory and share it between every tests.

Notice: I don't recommend to use this library with large fixtures because it can cause huge memory usage. I prefer to run tests with minimal database setup because it is more readable for me and it have better performance.

Requirements

  "require": {
    "php": ">=5.4",
    "doctrine/orm": "~2.3",
    "symfony/process": "~2.3"
  },

Features

  • It supports SqlitePlatform and MySqlPlatform,
  • It can create database backup per PHP process,
  • It can purge database in fast way,
  • It can restore database from backup before every test,
  • It can restore clear database before every test.

Installation

Require the library with composer:

composer require lzakrzewski/doctrine-database-backup "~1.2"

Basic usage (PHPUnit example)

/** {@inheritdoc} */
protected function setUp()
{
    parent::setUp();

    $this->entityManager = $this->createEntityManager();

    $backup = new DoctrineDatabaseBackup($this->entityManager);
    $backup->restore();
}

This database setup prepares clear database before every test. Full working example.

Advanced usage (PHPUnit example)

/** {@inheritdoc} */
protected function setUp()
{
    parent::setUp();

    $this->entityManager = $this->createEntityManager();
    $backup = new DoctrineDatabaseBackup($this->entityManager);
    
    $backup->restore(function (EntityManager $entityManager) {
        //your fixtures
        $entityManager->persist(new TestProduct('Iron', 99));
        $entityManager->flush();
    });
}

This database setup database with your fixtures before every test. Full working example.

Notice: that before first test of PHP process database should be created.

Behat example

/** @BeforeScenario*/
public function restoreDatabase()
{
    // "getEntityManager" is your own getter for EntityManager
    $backup = new DoctrineDatabaseBackup($this->getEntityManager());
    $backup->restore();
}

统计信息

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

GitHub 信息

  • Stars: 15
  • Watchers: 0
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-10-05