带有 PDO 模拟的 phpunit 测试
phpunit test with PDO mock
我正在尝试用两种方法测试 class。两者都与数据库交互,这就是我尝试使用 PDO 模拟对象的原因。
我找不到很多关于模拟 PDO 对象和使用它们的文档,但是在学习了一个看起来非常接近我需要的教程之后,我最终得到了一个 PDO 模拟对象,但我不明白我应该如何使用它。
为简单起见,这是我的 class 我想测试的第一种方法:
<?php
use Slim\Slim;
class AdProviders {
public $providers = null;
protected $db = null;
function __construct() {
}
function getDbh() {
if ($this->db === null){
$this->db = Slim::getInstance()->db;
}
return $this->db->getConnection();
}
}
根据数据库模式,这就是我创建 PDO 对象的方式:
<?php
require dirname(__FILE__).'/../../src/vendor/autoload.php';
class AdProvidersTest extends PHPUnit_Framework_TestCase
{
public function dataProvider()
{
return array (
array (1, '1st', 'desc_1', 11),
array (2, '2nd', 'desc_2', 22),
array (3, '3rd', 'desc_3', 33),
);
}
/**
* @dataProvider dataProvider
*/
public function testAdProviders($id, $name, $desc, $account_id)
{
$data = array (
array (
'id' => $id,
'name' => $name,
'description' => $desc,
'account_id' => $account_id
)
);
$stmt = $this->getMock('PDOStatement', array ('fetchAll'));
$stmt->expects($this->any())
->method('fetchAll')
->will($this->returnValue($data));
$pdo = $this->getMock('PDO', array('prepare'),
array('sqlite:dbname=:memory'),'PDOMock_' . uniqid(),true);
$pdo->expects($this->any())
->method('prepare')
->will($this->returnValue($stmt));
}
}
现在我真的不知道应该如何测试 getDbh()
方法...这是为我的测试创建 PDO 模拟的正确方法吗?
如果是这样,我如何使用它来测试该方法?
任何形式的指导都将不胜感激...谢谢
你需要将这个 mock 注入到 Slim::getInstance() 中,这就是为什么使用单例是不好的,而使用依赖注入模式更好。
在 Slim::getInstance()->db
中无法更改 PDO 的地方模拟 PDO 是一种愚蠢的做法
您真正可以在这里测试的是方法 getDbh() returns Connection 的实例。
我正在尝试用两种方法测试 class。两者都与数据库交互,这就是我尝试使用 PDO 模拟对象的原因。 我找不到很多关于模拟 PDO 对象和使用它们的文档,但是在学习了一个看起来非常接近我需要的教程之后,我最终得到了一个 PDO 模拟对象,但我不明白我应该如何使用它。
为简单起见,这是我的 class 我想测试的第一种方法:
<?php
use Slim\Slim;
class AdProviders {
public $providers = null;
protected $db = null;
function __construct() {
}
function getDbh() {
if ($this->db === null){
$this->db = Slim::getInstance()->db;
}
return $this->db->getConnection();
}
}
根据数据库模式,这就是我创建 PDO 对象的方式:
<?php
require dirname(__FILE__).'/../../src/vendor/autoload.php';
class AdProvidersTest extends PHPUnit_Framework_TestCase
{
public function dataProvider()
{
return array (
array (1, '1st', 'desc_1', 11),
array (2, '2nd', 'desc_2', 22),
array (3, '3rd', 'desc_3', 33),
);
}
/**
* @dataProvider dataProvider
*/
public function testAdProviders($id, $name, $desc, $account_id)
{
$data = array (
array (
'id' => $id,
'name' => $name,
'description' => $desc,
'account_id' => $account_id
)
);
$stmt = $this->getMock('PDOStatement', array ('fetchAll'));
$stmt->expects($this->any())
->method('fetchAll')
->will($this->returnValue($data));
$pdo = $this->getMock('PDO', array('prepare'),
array('sqlite:dbname=:memory'),'PDOMock_' . uniqid(),true);
$pdo->expects($this->any())
->method('prepare')
->will($this->returnValue($stmt));
}
}
现在我真的不知道应该如何测试 getDbh()
方法...这是为我的测试创建 PDO 模拟的正确方法吗?
如果是这样,我如何使用它来测试该方法?
任何形式的指导都将不胜感激...谢谢
你需要将这个 mock 注入到 Slim::getInstance() 中,这就是为什么使用单例是不好的,而使用依赖注入模式更好。
在 Slim::getInstance()->db
您真正可以在这里测试的是方法 getDbh() returns Connection 的实例。