2009-01-04 16:15:32 +00:00
|
|
|
<?php
|
|
|
|
|
2009-01-22 19:38:10 +00:00
|
|
|
namespace Doctrine\Tests\Mocks;
|
2008-04-12 21:35:21 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This class is a mock of the PDOStatement class that can be passed in to the Hydrator
|
|
|
|
* to test the hydration standalone with faked result sets.
|
|
|
|
*
|
|
|
|
* @author Roman Borschel <roman@code-factory.org>
|
|
|
|
*/
|
2009-01-22 19:38:10 +00:00
|
|
|
class HydratorMockStatement
|
2008-04-12 21:35:21 +00:00
|
|
|
{
|
|
|
|
private $_resultSet;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a new mock statement that will serve the provided fake result set to clients.
|
|
|
|
*
|
|
|
|
* @param array $resultSet The faked SQL result set.
|
|
|
|
*/
|
|
|
|
public function __construct(array $resultSet)
|
|
|
|
{
|
|
|
|
$this->_resultSet = $resultSet;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetches all rows from the result set.
|
|
|
|
*
|
|
|
|
* NOTE: Must adhere to the PDOStatement::fetchAll() signature that looks as follows:
|
|
|
|
* array fetchAll ([ int $fetch_style [, int $column_index [, array $ctor_args ]]] )
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function fetchAll($fetchStyle = null, $columnIndex = null, array $ctorArgs = null)
|
|
|
|
{
|
|
|
|
return $this->_resultSet;
|
|
|
|
}
|
|
|
|
|
2008-05-18 16:21:55 +00:00
|
|
|
public function fetchColumn($columnNumber = 0)
|
|
|
|
{
|
|
|
|
$row = array_shift($this->_resultSet);
|
|
|
|
if ( ! is_array($row)) return false;
|
|
|
|
$val = array_shift($row);
|
|
|
|
return $val !== null ? $val : false;
|
|
|
|
}
|
|
|
|
|
2008-04-12 21:35:21 +00:00
|
|
|
/**
|
|
|
|
* Fetches the next row in the result set.
|
|
|
|
*
|
|
|
|
* NOTE: Must adhere to the PDOStatement::fetch() signature that looks as follows:
|
|
|
|
* mixed fetch ([ int $fetch_style [, int $cursor_orientation [, int $cursor_offset ]]] )
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function fetch($fetchStyle = null, $cursorOrientation = null, $cursorOffset = null)
|
|
|
|
{
|
|
|
|
return array_shift($this->_resultSet);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Closes the cursor, enabling the statement to be executed again.
|
|
|
|
*
|
|
|
|
* @return boolean
|
|
|
|
*/
|
|
|
|
public function closeCursor()
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setResultSet(array $resultSet)
|
|
|
|
{
|
|
|
|
$this->_resultSet = $resultSet;
|
|
|
|
}
|
|
|
|
}
|