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

标签 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));
}

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

最佳答案

我对这个问题的解决方案是为 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();
    } }

关于php - 模拟 pdo 对象会产生简单的参数错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25796468/

相关文章:

php - 不使用 htmlentities 编码已经编码的项目

php - 如何以正确的 JSON 格式获取 FCM 通知响应?

javascript - 使用 Jasmine 2.0 对 $scope.$evalAsync 函数进行单元测试

asp.net-mvc-3 - 由于企业库,NUnit 测试失败

java - 如何模拟最终对象的外部依赖关系?

javascript - XMLHttpRequest 和 PHP 的问题

php - 根据列中内含的数据获取行

mysql - 错误 1264 (22003) : Out of range value for column 'amount' at row 1

php - 如何设置这个全文索引

javascript - 从查询中传递模态 ID,以便它可以在另一个查询中使用