模拟pdo对象会产生简单的参数错误

时间:2014-09-11 20:35:18

标签: php mysql unit-testing pdo phpunit

我正在尝试模拟PDO对象,但是收到的错误是“PDO :: __ construct()需要至少1个参数,0给出”

我正在嘲笑的课程在这里:

class MockPDO extends PDO
{

public function __construct() {
try 
    {
     $dsn = "mysql:host=localhost;dbname=somedatabase";
     parent::__construct($dsn, "root", "root"); 
    }
    catch (PDOException $exception) 
    {
     die($exception->getMessage());
    }
 }
}

我的测试课在这里

class DatabaseTest extends \PHPUnit_Framework_TestCase
{
public function testFindById() {
$pdo = $this->getMock('PDO', array('prepare'));
$stmt = $this->getMock('PDOStatement', array('execute', 'fetch'));
$stmt->expects($this->once())->method('execute')->with($this->equalTo(array(':id' => 2)));
$stmt->expects($this->once())->method('fetch');

$pdo->expects($this->once())->method('prepare')
  ->with($this->equalTo('SELECT * FROM sometable WHERE id => :id'))
  ->will($this->returnValue($stmt));
}

我知道这很简单,但我做错了什么?

2 个答案:

答案 0 :(得分:2)

我解决这个问题的方法是为pdo创建一个包装类。这是为了破坏构造函数。 除非您为构造函数提供有效的连接字符串

如何提供构造函数参数的示例:

$pdo = $this->getMock('PDO', array('prepare', '__construct'), ["mysql:host=server;dbname=db;"]);

解决方案:

class PDOMock extends \PDO {
    public function __construct() {} }

class PDOTest extends \PHPUnit_Framework_TestCase {
    public function setup() {
        $pdo = $this->getMockBuilder('PDOMock')
            ->getMock();
    } }

答案 1 :(得分:2)

PhpUnit调用对象的构造函数,除非您明确告诉

$pdo = $this->getMockBuilder('PDO')
    ->disableOriginalConstructor()
    ->setMethods(array('prepare'))
    ->getMock();