用PDO模拟phpunit测试

时间:2015-08-12 11:14:20

标签: php pdo phpunit slim

我试图用两种方法测试一个类。两者都与数据库交互,这就是为什么我正在尝试使用PDO模拟对象。 我无法找到很多关于模拟PDO对象和使用它们的文档但是在完成了一个看起来非常接近我需要的教程之后我最终得到了一个PDO模拟对象,但是我不明白我应该怎么做用它。

为了简单起见,这是我的班级,我想测试第一种方法:

<?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();
  }

}

根据db模式,这就是我创建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模拟的正确方法吗? 如果是这样,我该如何使用它来测试方法?

任何形式的指导都将受到高度赞赏...... thx

1 个答案:

答案 0 :(得分:2)

你需要将这个模拟注入Slim :: getInstance(),这就是使用单例并且更好地使用依赖注入模式的原因。

Slim::getInstance()->db

中模拟无法更改PDO的PDO是毫无意义的

这里你真正可以测试的是方法getDbh()是否返回Connection的实例。