gpt4 book ai didi

php - 使用 Symfony 测试数据库插入

转载 作者:塔克拉玛干 更新时间:2023-11-03 06:03:14 25 4
gpt4 key购买 nike

大家好

在过去的几天里,我一直在研究测试驱动开发,并决定我也需要学习它。虽然我不知道如何精确地做到这一点。

我的项目依赖于 Symfony2.1.6 框架和 Doctrine,所以我有一些需要填充的数据库表。

Book (1,n) - (0,n) Genre

现在,如果我想插入一个流派唱片,我首先需要编写一个测试以确保所有内容都按预期插入(或者我错了吗?)

现在的问题是我不知道如何访问我的数据库,因为它是由框架管理的。

我唯一能找到的是 LiipFunctionalTestBundle https://github.com/liip/LiipFunctionalTestBundle每次我运行测试时都会创建和恢复一个临时数据库。我已根据说明设置了所有内容。

编辑:我的 app/config/config_test.yml 现在看起来像这样:

imports:
- { resource: config_dev.yml }

framework:
test: ~
session:
storage_id: session.storage.filesystem

liip_functional_test: ~

web_profiler:
toolbar: false
intercept_redirects: false

swiftmailer:
disable_delivery: true

liip_functional_test:
cache_sqlite_db: true

doctrine:
dbal:
default_connection: default
connections:
default:
driver: pdo_sqlite
path: %kernel.cache_dir%/test.db

所以现在我有一个 GenreTest 类:
Liip 没有文档,所以我只是尝试了这样的方法。

use Liip\FunctionalTestBundle\Test\WebTestCase;
class GenreTest extends WebTestCase {
public function testInsert() {
$container = $this->getContainer();
$registry = $container->get('doctrine');
$em = $registry->getEntityManager(null);

$genre = new Genre();
$genre->setName("testGenre");

$em->persist($genre);
$em->flush();

$result = $em->createQuery("SELECT g FROM QkprodMangressBundle:Genre g ".
"WHERE g.name = :name")
->setParameter("name", $genre->getName())
->getResult();

$this->assertEqual($result[0]->getName(), $genre->getName());
}
}

phpunit -c web/

PDOException: could not find driver /.../Mangress/vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOConnection.php:36 /.../Mangress/vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOSqlite/Driver.php :60 /.../Mangress/vendor/doctrine/dbal/lib/Doctrine/DBAL/Connection.php:350 /.../Mangress/vendor/doctrine/dbal/lib/Doctrine/DBAL/Connection.php:949 /.../Mangress/vendor/doctrine/orm/lib/Doctrine/ORM/UnitOfWork.php:306 /.../Mangress/vendor/doctrine/orm/lib/Doctrine/ORM/EntityManager.php:355 /.../Mangress/app/cache/test/jms_diextra/doctrine/EntityManager_510128d0a5878.ph p:362 /.../Mangress/src/Qkprod/MangressBundle/Tests/Entity/GenreTest.php:27 FAILURES! Tests: 3, Assertions: 1, Errors: 1.

我遇到的最大问题是..我该如何测试这样的东西?或者我什至测试数据库通信?伪造数据库通过自定义实现的通信看起来不像对我来说是个好主意,因为它将在生产中使用 ORM 和 Doctrine环境也是如此。

Sorry.. 原来这里是小小说。

最佳答案

我几乎完全解决了我的问题:

  1. 安装 db-communication 所需的驱动程序 ;)
    PDO_SQLITE driver not present.. what to do?

    sudo apt-get install php5-sqlite
  2. 在每次测试运行时重新创建架构
    https://stackoverflow.com/a/10463614/1177024


这是我针对数据库的类测试

namespace Qkprod\MangressBundle\Entity;

use Qkprod\MangressBundle\Entity\Genre;
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;

private $em;

/**
* Sets up environment for testing
* Regenerates Database schema before every test-run
*/
public function setUp() {
static::$kernel = static::createKernel();
static::$kernel -> boot();
$this -> em = static::$kernel->getContainer()
->get('doctrine')
->getEntityManager();
$this->regenerateSchema();
}

protected function tearDown() {
parent::tearDown();
$this -> em -> close();
}

/**
* Drops current schema and creates a brand new one
*/
protected function regenerateSchema() {
$metadatas = $this->em->getMetadataFactory()->getAllMetadata();
if (!empty($metadatas)) {
$tool = new \Doctrine\ORM\Tools\SchemaTool($this->em);
$tool -> dropSchema($metadatas);
$tool -> createSchema($metadatas);
}
}


public function testInsert() {
$genre = new Genre();
$genre -> setName("testGenre");

$this -> em -> persist($genre);
$this -> em -> flush();

$result = $this -> em
-> createQuery("SELECT g "
. " FROM QkprodMangressBundle:Genre g "
. " WHERE g.name = :name")
-> setParameter("name", $genre -> getName())
-> getResult();

$this -> assertEquals($result[0] -> getName(), $genre -> getName());
}
}


无法让 LiipBundle 工作,但您可以通过设置 symfony 将 sqlite 数据库保存在内存而不是文件系统中来极大地提高速度。 https://stackoverflow.com/a/10460139/1177024

# app/config/config_test
doctrine:
dbal:
driver: pdo_sqlite
path: :memory:
memory: true


或者只创建一次架构而不是重新创建它,只需使用新备份覆盖数据库。

我希望这能缩短对遇到同样问题的人的搜索!感谢一路上帮助我的每一个人:)你太棒了!

关于php - 使用 Symfony 测试数据库插入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14502618/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com