2007-08-15 08:38:41 +02:00
|
|
|
<?php
|
2008-01-08 07:37:50 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @package sapphire
|
|
|
|
* @subpackage testing
|
|
|
|
*/
|
|
|
|
|
2007-08-15 08:38:41 +02:00
|
|
|
/*
|
|
|
|
$dir = dirname(dirname((__FILE__)));
|
|
|
|
$_SERVER['SCRIPT_FILENAME'] = "$dir/main.php";
|
|
|
|
chdir($dir);
|
|
|
|
|
|
|
|
require_once 'core/Core.php';
|
|
|
|
require_once("core/ManifestBuilder.php");
|
|
|
|
require_once("core/ClassInfo.php");
|
|
|
|
require_once('core/Object.php');
|
|
|
|
require_once('core/control/Director.php');
|
|
|
|
require_once('filesystem/Filesystem.php');
|
|
|
|
require_once("core/Session.php");
|
|
|
|
|
|
|
|
$envFiles = array('../_ss_environment.php', '../../_ss_environment.php', '../../../_ss_environment.php');
|
|
|
|
foreach($envFiles as $envFile) {
|
|
|
|
if(@file_exists($envFile)) {
|
|
|
|
include($envFile);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
require_once(MANIFEST_FILE);
|
|
|
|
print_r($_CLASS_MANIFEST);
|
|
|
|
|
|
|
|
if(ManifestBuilder::staleManifest()) ManifestBuilder::compileManifest();
|
|
|
|
|
|
|
|
require_once(MANIFEST_FILE);
|
|
|
|
*/
|
2007-08-15 12:01:35 +02:00
|
|
|
|
|
|
|
|
|
|
|
// Check that PHPUnit is installed
|
|
|
|
$hasPhpUnit = false;
|
|
|
|
$paths = explode(PATH_SEPARATOR, ini_get('include_path'));
|
|
|
|
foreach($paths as $path) {
|
2007-08-20 05:50:57 +02:00
|
|
|
if(@file_exists("$path/PHPUnit/Framework.php")) $hasPhpUnit = true;
|
2007-08-15 12:01:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if($hasPhpUnit) {
|
|
|
|
|
2008-01-10 01:33:18 +01:00
|
|
|
/**
|
|
|
|
*/
|
2007-08-15 08:38:41 +02:00
|
|
|
require_once 'PHPUnit/Framework.php';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test case class for the Sapphire framework.
|
|
|
|
* Sapphire unit testing is based on PHPUnit, but provides a number of hooks into our data model that make it easier to work with.
|
2008-01-10 01:33:18 +01:00
|
|
|
* @package sapphire
|
|
|
|
* @subpackage testing
|
2007-08-15 08:38:41 +02:00
|
|
|
*/
|
|
|
|
class SapphireTest extends PHPUnit_Framework_TestCase {
|
2008-03-17 03:04:58 +01:00
|
|
|
static $fixture_file = null;
|
|
|
|
|
2007-08-15 08:38:41 +02:00
|
|
|
function setUp() {
|
2008-03-17 03:04:58 +01:00
|
|
|
$className = get_class($this);
|
|
|
|
$fixtureFile = eval("return {$className}::\$fixture_file;");
|
|
|
|
|
2008-03-17 03:09:32 +01:00
|
|
|
if($fixtureFile) {
|
2008-03-17 03:04:58 +01:00
|
|
|
// Create a temporary database
|
|
|
|
$dbConn = DB::getConn();
|
2007-08-15 08:38:41 +02:00
|
|
|
$dbname = 'tmpdb' . rand(1000000,9999999);
|
2008-03-17 03:04:58 +01:00
|
|
|
while(!$dbname || $dbConn->databaseExists($dbname)) {
|
|
|
|
$dbname = 'tmpdb' . rand(1000000,9999999);
|
|
|
|
}
|
|
|
|
$dbConn->selectDatabase($dbname);
|
2007-08-15 08:38:41 +02:00
|
|
|
|
2008-03-17 03:04:58 +01:00
|
|
|
// This code is a bit misplaced; we want some way of the whole session being reinitialised...
|
|
|
|
Versioned::reading_stage(null);
|
2007-08-15 08:38:41 +02:00
|
|
|
|
2008-03-17 03:04:58 +01:00
|
|
|
$dbConn->createDatabase();
|
|
|
|
singleton('DataObject')->flushCache();
|
2007-08-15 08:38:41 +02:00
|
|
|
|
2008-03-17 03:04:58 +01:00
|
|
|
$dbadmin = new DatabaseAdmin();
|
|
|
|
$dbadmin->doBuild(true, false);
|
2007-08-15 08:38:41 +02:00
|
|
|
|
2008-03-17 03:04:58 +01:00
|
|
|
// Load the fixture into the database
|
|
|
|
$className = get_class($this);
|
|
|
|
$this->loadFixture($fixtureFile);
|
|
|
|
}
|
2007-08-15 08:38:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Array of
|
|
|
|
*/
|
|
|
|
protected $fixtureDictionary;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the ID of an object from the fixture.
|
|
|
|
* @param $className The data class, as specified in your fixture file. Parent classes won't work
|
|
|
|
* @param $identifier The identifier string, as provided in your fixture file
|
|
|
|
*/
|
|
|
|
protected function idFromFixture($className, $identifier) {
|
2007-08-16 08:36:02 +02:00
|
|
|
return $this->fixtureDictionary[$className][$identifier];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return all of the IDs in the fixture of a particular class name.
|
|
|
|
* @return A map of fixture-identifier => object-id
|
|
|
|
*/
|
|
|
|
protected function allFixtureIDs($className) {
|
|
|
|
return $this->fixtureDictionary[$className];
|
2007-08-15 08:38:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get an object from the fixture.
|
|
|
|
* @param $className The data class, as specified in your fixture file. Parent classes won't work
|
|
|
|
* @param $identifier The identifier string, as provided in your fixture file
|
|
|
|
*/
|
|
|
|
protected function objFromFixture($className, $identifier) {
|
|
|
|
return DataObject::get_by_id($className, $this->idFromFixture($className, $identifier));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Load a YAML fixture file into the database.
|
|
|
|
* Once loaded, you can use idFromFixture() and objFromFixture() to get items from the fixture
|
|
|
|
* @param $fixtureFile The location of the .yml fixture file, relative to the site base dir
|
|
|
|
*/
|
|
|
|
function loadFixture($fixtureFile) {
|
|
|
|
$parser = new Spyc();
|
|
|
|
$fixtureContent = $parser->load(Director::baseFolder().'/'.$fixtureFile);
|
|
|
|
|
|
|
|
$this->fixtureDictionary = array();
|
|
|
|
|
|
|
|
foreach($fixtureContent as $dataClass => $items) {
|
|
|
|
foreach($items as $identifier => $fields) {
|
|
|
|
$obj = new $dataClass();
|
|
|
|
foreach($fields as $fieldName => $fieldVal) {
|
2008-01-08 20:59:00 +01:00
|
|
|
if($obj->many_many($fieldName) || $obj->has_many($fieldName)) {
|
2008-01-08 22:32:13 +01:00
|
|
|
$parsedItems = array();
|
2007-08-17 07:43:14 +02:00
|
|
|
$items = split(' *, *',trim($fieldVal));
|
|
|
|
foreach($items as $item) {
|
|
|
|
$parsedItems[] = $this->parseFixtureVal($item);
|
|
|
|
}
|
|
|
|
$obj->write();
|
2008-01-08 20:59:00 +01:00
|
|
|
$obj->getComponents($fieldName)->setByIDList($parsedItems);
|
2007-08-15 08:38:41 +02:00
|
|
|
|
|
|
|
} else {
|
2007-08-17 07:43:14 +02:00
|
|
|
$obj->$fieldName = $this->parseFixtureVal($fieldVal);
|
2007-08-15 08:38:41 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
$obj->write();
|
|
|
|
|
|
|
|
// Populate the dictionary with the ID
|
2007-08-16 08:36:02 +02:00
|
|
|
$this->fixtureDictionary[$dataClass][$identifier] = $obj->ID;
|
2007-08-15 08:38:41 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-08-17 07:43:14 +02:00
|
|
|
/**
|
|
|
|
* Parse a value from a fixture file. If it starts with => it will get an ID from the fixture dictionary
|
|
|
|
*/
|
|
|
|
protected function parseFixtureVal($fieldVal) {
|
|
|
|
// Parse a dictionary reference - used to set foreign keys
|
|
|
|
if(substr($fieldVal,0,2) == '=>') {
|
|
|
|
list($a, $b) = explode('.', substr($fieldVal,2), 2);
|
|
|
|
return $this->fixtureDictionary[$a][$b];
|
|
|
|
|
|
|
|
// Regular field value setting
|
|
|
|
} else {
|
|
|
|
return $fieldVal;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-08-15 08:38:41 +02:00
|
|
|
function tearDown() {
|
|
|
|
// Delete our temporary database
|
|
|
|
$dbConn = DB::getConn();
|
2008-03-17 03:04:58 +01:00
|
|
|
if($dbConn && substr($dbConn->currentDatabase(),0,5) == 'tmpdb') {
|
2007-08-15 08:38:41 +02:00
|
|
|
// echo "Deleted temp database " . $dbConn->currentDatabase() . "\n";
|
|
|
|
$dbConn->dropDatabase();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-08-15 12:01:35 +02:00
|
|
|
} else {
|
|
|
|
// Stub
|
2008-01-10 01:33:18 +01:00
|
|
|
/**
|
|
|
|
* @ignore
|
|
|
|
* @package sapphire
|
|
|
|
* @subpackage testing
|
|
|
|
*/
|
2007-08-15 12:01:35 +02:00
|
|
|
class SapphireTest extends Object {}
|
|
|
|
}
|
|
|
|
|
2008-01-08 04:00:38 +01:00
|
|
|
?>
|