2011-05-13 16:00:25 +10:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* TestCase for testing a database
|
|
|
|
*
|
|
|
|
* @package Kohana/UnitTest
|
|
|
|
* @author Kohana Team
|
|
|
|
* @author BRMatt <matthew@sigswitch.com>
|
|
|
|
* @copyright (c) 2008-2009 Kohana Team
|
|
|
|
* @license http://kohanaphp.com/license
|
|
|
|
*/
|
2012-11-09 23:18:50 +11:00
|
|
|
abstract class Kohana_Unittest_Database_TestCase extends PHPUnit_Extensions_Database_TestCase {
|
2011-05-13 16:00:25 +10:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether we should enable work arounds to make the tests compatible with phpunit 3.4
|
|
|
|
* @var boolean
|
|
|
|
*/
|
|
|
|
protected static $_assert_type_compatability = NULL;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Make sure PHPUnit backs up globals
|
|
|
|
* @var boolean
|
|
|
|
*/
|
2012-11-09 23:18:50 +11:00
|
|
|
protected $backupGlobals = FALSE;
|
2011-05-13 16:00:25 +10:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A set of unittest helpers that are shared between normal / database
|
|
|
|
* testcases
|
|
|
|
* @var Kohana_Unittest_Helpers
|
|
|
|
*/
|
|
|
|
protected $_helpers = NULL;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A default set of environment to be applied before each test
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $environmentDefault = array();
|
|
|
|
|
2012-11-09 23:18:50 +11:00
|
|
|
/**
|
|
|
|
* The kohana database connection that PHPUnit should use for this test
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $_database_connection = 'default';
|
|
|
|
|
2011-05-13 16:00:25 +10:00
|
|
|
/**
|
|
|
|
* Creates a predefined environment using the default environment
|
|
|
|
*
|
|
|
|
* Extending classes that have their own setUp() should call
|
|
|
|
* parent::setUp()
|
|
|
|
*/
|
|
|
|
public function setUp()
|
|
|
|
{
|
2012-11-09 23:18:50 +11:00
|
|
|
if(self::$_assert_type_compatability === NULL)
|
2011-05-13 16:00:25 +10:00
|
|
|
{
|
2012-11-09 23:18:50 +11:00
|
|
|
if( ! class_exists('PHPUnit_Runner_Version'))
|
2011-05-13 16:00:25 +10:00
|
|
|
{
|
|
|
|
require_once 'PHPUnit/Runner/Version.php';
|
|
|
|
}
|
|
|
|
|
|
|
|
self::$_assert_type_compatability = version_compare(PHPUnit_Runner_Version::id(), '3.5.0', '<=');
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->_helpers = new Kohana_Unittest_Helpers;
|
|
|
|
|
|
|
|
$this->setEnvironment($this->environmentDefault);
|
|
|
|
|
|
|
|
return parent::setUp();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Restores the original environment overriden with setEnvironment()
|
|
|
|
*
|
|
|
|
* Extending classes that have their own tearDown()
|
|
|
|
* should call parent::tearDown()
|
|
|
|
*/
|
|
|
|
public function tearDown()
|
|
|
|
{
|
|
|
|
$this->_helpers->restore_environment();
|
|
|
|
|
|
|
|
return parent::tearDown();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a connection to the unittesting database
|
|
|
|
*
|
|
|
|
* @return PDO
|
|
|
|
*/
|
|
|
|
public function getConnection()
|
|
|
|
{
|
|
|
|
// Get the unittesting db connection
|
2012-11-09 23:18:50 +11:00
|
|
|
$config = Kohana::$config->load('database.'.$this->_database_connection);
|
2011-05-13 16:00:25 +10:00
|
|
|
|
|
|
|
if($config['type'] !== 'pdo')
|
|
|
|
{
|
|
|
|
$config['connection']['dsn'] = $config['type'].':'.
|
|
|
|
'host='.$config['connection']['hostname'].';'.
|
|
|
|
'dbname='.$config['connection']['database'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$pdo = new PDO(
|
|
|
|
$config['connection']['dsn'],
|
|
|
|
$config['connection']['username'],
|
|
|
|
$config['connection']['password']
|
|
|
|
);
|
|
|
|
|
|
|
|
return $this->createDefaultDBConnection($pdo, $config['connection']['database']);
|
|
|
|
}
|
|
|
|
|
2012-11-09 23:18:50 +11:00
|
|
|
/**
|
|
|
|
* Gets a connection to the unittest database
|
|
|
|
*
|
|
|
|
* @return Kohana_Database The database connection
|
|
|
|
*/
|
|
|
|
public function getKohanaConnection()
|
|
|
|
{
|
|
|
|
return Database::instance(Kohana::$config->load('unittest')->db_connection);
|
|
|
|
}
|
2011-05-13 16:00:25 +10:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes all kohana related cache files in the cache directory
|
|
|
|
*/
|
|
|
|
public function cleanCacheDir()
|
|
|
|
{
|
|
|
|
return Kohana_Unittest_Helpers::clean_cache_dir();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper function that replaces all occurences of '/' with
|
|
|
|
* the OS-specific directory separator
|
|
|
|
*
|
|
|
|
* @param string $path The path to act on
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function dirSeparator($path)
|
|
|
|
{
|
|
|
|
return Kohana_Unittest_Helpers::dir_separator($path);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Allows easy setting & backing up of enviroment config
|
|
|
|
*
|
|
|
|
* Option types are checked in the following order:
|
|
|
|
*
|
|
|
|
* * Server Var
|
|
|
|
* * Static Variable
|
|
|
|
* * Config option
|
|
|
|
*
|
|
|
|
* @param array $environment List of environment to set
|
|
|
|
*/
|
|
|
|
public function setEnvironment(array $environment)
|
|
|
|
{
|
|
|
|
return $this->_helpers->set_environment($environment);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check for internet connectivity
|
|
|
|
*
|
|
|
|
* @return boolean Whether an internet connection is available
|
|
|
|
*/
|
|
|
|
public function hasInternet()
|
|
|
|
{
|
|
|
|
return Kohana_Unittest_Helpers::has_internet();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Asserts that a variable is of a given type.
|
|
|
|
*
|
|
|
|
* @param string $expected
|
|
|
|
* @param mixed $actual
|
|
|
|
* @param string $message
|
|
|
|
* @since Method available since Release 3.5.0
|
|
|
|
*/
|
|
|
|
public static function assertInstanceOf($expected, $actual, $message = '')
|
|
|
|
{
|
2012-11-09 23:18:50 +11:00
|
|
|
if(self::$_assert_type_compatability)
|
|
|
|
{
|
2011-05-13 16:00:25 +10:00
|
|
|
return self::assertType($expected, $actual, $message);
|
2012-11-09 23:18:50 +11:00
|
|
|
}
|
2011-05-13 16:00:25 +10:00
|
|
|
|
|
|
|
return parent::assertInstanceOf($expected, $actual, $message);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Asserts that an attribute is of a given type.
|
|
|
|
*
|
|
|
|
* @param string $expected
|
|
|
|
* @param string $attributeName
|
|
|
|
* @param mixed $classOrObject
|
|
|
|
* @param string $message
|
|
|
|
* @since Method available since Release 3.5.0
|
|
|
|
*/
|
|
|
|
public static function assertAttributeInstanceOf($expected, $attributeName, $classOrObject, $message = '')
|
|
|
|
{
|
2012-11-09 23:18:50 +11:00
|
|
|
if(self::$_assert_type_compatability)
|
|
|
|
{
|
2011-05-13 16:00:25 +10:00
|
|
|
return self::assertAttributeType($expected, $attributeName, $classOrObject, $message);
|
2012-11-09 23:18:50 +11:00
|
|
|
}
|
2011-05-13 16:00:25 +10:00
|
|
|
|
|
|
|
return parent::assertAttributeInstanceOf($expected, $attributeName, $classOrObject, $message);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Asserts that a variable is not of a given type.
|
|
|
|
*
|
|
|
|
* @param string $expected
|
|
|
|
* @param mixed $actual
|
|
|
|
* @param string $message
|
|
|
|
* @since Method available since Release 3.5.0
|
|
|
|
*/
|
|
|
|
public static function assertNotInstanceOf($expected, $actual, $message = '')
|
|
|
|
{
|
2012-11-09 23:18:50 +11:00
|
|
|
if(self::$_assert_type_compatability)
|
|
|
|
{
|
2011-05-13 16:00:25 +10:00
|
|
|
return self::assertNotType($expected, $actual, $message);
|
2012-11-09 23:18:50 +11:00
|
|
|
}
|
2011-05-13 16:00:25 +10:00
|
|
|
|
|
|
|
return self::assertNotInstanceOf($expected, $actual, $message);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Asserts that an attribute is of a given type.
|
|
|
|
*
|
|
|
|
* @param string $expected
|
|
|
|
* @param string $attributeName
|
|
|
|
* @param mixed $classOrObject
|
|
|
|
* @param string $message
|
|
|
|
* @since Method available since Release 3.5.0
|
|
|
|
*/
|
|
|
|
public static function assertAttributeNotInstanceOf($expected, $attributeName, $classOrObject, $message = '')
|
|
|
|
{
|
2012-11-09 23:18:50 +11:00
|
|
|
if(self::$_assert_type_compatability)
|
|
|
|
{
|
2011-05-13 16:00:25 +10:00
|
|
|
return self::assertAttributeNotType($expected, $attributeName, $classOrObject, $message);
|
2012-11-09 23:18:50 +11:00
|
|
|
}
|
2011-05-13 16:00:25 +10:00
|
|
|
|
|
|
|
return self::assertAttributeNotInstanceOf($expected, $attributeName, $classOrObject, $message);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Asserts that a variable is of a given type.
|
|
|
|
*
|
|
|
|
* @param string $expected
|
|
|
|
* @param mixed $actual
|
|
|
|
* @param string $message
|
|
|
|
* @since Method available since Release 3.5.0
|
|
|
|
*/
|
|
|
|
public static function assertInternalType($expected, $actual, $message = '')
|
|
|
|
{
|
2012-11-09 23:18:50 +11:00
|
|
|
if(self::$_assert_type_compatability)
|
|
|
|
{
|
2011-05-13 16:00:25 +10:00
|
|
|
return self::assertType($expected, $actual, $message);
|
2012-11-09 23:18:50 +11:00
|
|
|
}
|
2011-05-13 16:00:25 +10:00
|
|
|
|
|
|
|
return parent::assertInternalType($expected, $actual, $message);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Asserts that an attribute is of a given type.
|
|
|
|
*
|
|
|
|
* @param string $expected
|
|
|
|
* @param string $attributeName
|
|
|
|
* @param mixed $classOrObject
|
|
|
|
* @param string $message
|
|
|
|
* @since Method available since Release 3.5.0
|
|
|
|
*/
|
|
|
|
public static function assertAttributeInternalType($expected, $attributeName, $classOrObject, $message = '')
|
|
|
|
{
|
2012-11-09 23:18:50 +11:00
|
|
|
if(self::$_assert_type_compatability)
|
|
|
|
{
|
2011-05-13 16:00:25 +10:00
|
|
|
return self::assertAttributeType($expected, $attributeName, $classOrObject, $message);
|
2012-11-09 23:18:50 +11:00
|
|
|
}
|
2011-05-13 16:00:25 +10:00
|
|
|
|
|
|
|
return self::assertAttributeInternalType($expected, $attributeName, $classOrObject, $message);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Asserts that a variable is not of a given type.
|
|
|
|
*
|
|
|
|
* @param string $expected
|
|
|
|
* @param mixed $actual
|
|
|
|
* @param string $message
|
|
|
|
* @since Method available since Release 3.5.0
|
|
|
|
*/
|
|
|
|
public static function assertNotInternalType($expected, $actual, $message = '')
|
|
|
|
{
|
2012-11-09 23:18:50 +11:00
|
|
|
if(self::$_assert_type_compatability)
|
|
|
|
{
|
2011-05-13 16:00:25 +10:00
|
|
|
return self::assertNotType($expected, $actual, $message);
|
2012-11-09 23:18:50 +11:00
|
|
|
}
|
2011-05-13 16:00:25 +10:00
|
|
|
|
|
|
|
return self::assertNotInternalType($expected, $actual, $message);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Asserts that an attribute is of a given type.
|
|
|
|
*
|
|
|
|
* @param string $expected
|
|
|
|
* @param string $attributeName
|
|
|
|
* @param mixed $classOrObject
|
|
|
|
* @param string $message
|
|
|
|
* @since Method available since Release 3.5.0
|
|
|
|
*/
|
|
|
|
public static function assertAttributeNotInternalType($expected, $attributeName, $classOrObject, $message = '')
|
|
|
|
{
|
2012-11-09 23:18:50 +11:00
|
|
|
if(self::$_assert_type_compatability)
|
|
|
|
{
|
2011-05-13 16:00:25 +10:00
|
|
|
return self::assertAttributeNotType($expected, $attributeName, $classOrObject, $message);
|
2012-11-09 23:18:50 +11:00
|
|
|
}
|
2011-05-13 16:00:25 +10:00
|
|
|
|
|
|
|
return self::assertAttributeNotInternalType($expected, $attributeName, $classOrObject, $message);
|
|
|
|
}
|
|
|
|
}
|