2010-09-21 22:29:11 +02:00
|
|
|
<?php
|
|
|
|
// Simulate an execution from sapphire/cli-script.php, Core.php has too many
|
|
|
|
// hardcoded assumptions about folder depth of the executing script.
|
2012-03-14 14:06:59 +01:00
|
|
|
//
|
|
|
|
// Make sure display_errors is on
|
|
|
|
ini_set('display_errors', 1);
|
2010-09-21 22:29:11 +02:00
|
|
|
|
|
|
|
// Overrides paths relative to this file (in sapphire/tests/FullTestSuite.php)
|
2012-03-14 14:06:59 +01:00
|
|
|
global $_SERVER;
|
|
|
|
if (!$_SERVER) $_SERVER = array();
|
|
|
|
$_SERVER['SCRIPT_FILENAME'] = getcwd() . DIRECTORY_SEPARATOR . 'sapphire' . DIRECTORY_SEPARATOR . 'cli-script.php';
|
2010-09-21 22:29:11 +02:00
|
|
|
|
2012-03-14 14:06:59 +01:00
|
|
|
// Prepare manifest autoloader
|
|
|
|
function silverstripe_test_autoload($className) {
|
|
|
|
global $_CLASS_MANIFEST;
|
|
|
|
$lClassName = strtolower($className);
|
|
|
|
if(isset($_CLASS_MANIFEST[$lClassName])) include_once($_CLASS_MANIFEST[$lClassName]);
|
|
|
|
else if(isset($_CLASS_MANIFEST[$className])) include_once($_CLASS_MANIFEST[$className]);
|
|
|
|
}
|
|
|
|
spl_autoload_register('silverstripe_test_autoload');
|
|
|
|
|
|
|
|
require_once(getcwd()."/sapphire/core/Core.php");
|
2010-09-21 22:29:11 +02:00
|
|
|
|
|
|
|
// Copied from cli-script.php, to enable same behaviour through phpunit runner.
|
|
|
|
if(isset($_SERVER['argv'][2])) {
|
|
|
|
$args = array_slice($_SERVER['argv'],2);
|
|
|
|
$_GET = array();
|
|
|
|
foreach($args as $arg) {
|
|
|
|
if(strpos($arg,'=') == false) {
|
|
|
|
$_GET['args'][] = $arg;
|
|
|
|
} else {
|
|
|
|
$newItems = array();
|
|
|
|
parse_str( (substr($arg,0,2) == '--') ? substr($arg,2) : $arg, $newItems );
|
|
|
|
$_GET = array_merge($_GET, $newItems);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$_REQUEST = $_GET;
|
|
|
|
}
|
|
|
|
|
2012-03-14 14:06:59 +01:00
|
|
|
// Now set a fake REQUEST_URI
|
|
|
|
$_SERVER['REQUEST_URI'] = BASE_URL . '/dev/tests/all';
|
|
|
|
|
|
|
|
// Fake a session
|
|
|
|
$_SESSION = null;
|
|
|
|
|
|
|
|
// Fake a current controller. Way harder than it should be
|
|
|
|
class FakeController extends Controller {
|
|
|
|
|
|
|
|
function __construct() {
|
|
|
|
parent::__construct();
|
|
|
|
|
|
|
|
$session = new Session(isset($_SESSION) ? $_SESSION : null);
|
|
|
|
$this->setSession($session);
|
|
|
|
|
|
|
|
$this->pushCurrent();
|
|
|
|
|
|
|
|
$this->request = new SS_HTTPRequest(
|
|
|
|
(isset($_SERVER['X-HTTP-Method-Override'])) ? $_SERVER['X-HTTP-Method-Override'] : $_SERVER['REQUEST_METHOD'],
|
|
|
|
'/'
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->response = new SS_HTTPResponse();
|
|
|
|
|
|
|
|
$this->init();
|
|
|
|
}
|
2010-09-21 22:29:11 +02:00
|
|
|
}
|
|
|
|
|
2012-03-14 14:06:59 +01:00
|
|
|
global $_ALL_CLASSES;
|
|
|
|
$_ALL_CLASSES['parents']['FakeController'] = array_merge($_ALL_CLASSES['parents']['Controller'], array('Controller' => 'Controller'));
|
|
|
|
|
|
|
|
$controller = new FakeController();
|
|
|
|
|
|
|
|
// Connect to database
|
|
|
|
global $databaseConfig;
|
|
|
|
|
|
|
|
require_once(getcwd()."/sapphire/core/model/DB.php");
|
|
|
|
DB::connect($databaseConfig);
|
2010-09-21 22:29:11 +02:00
|
|
|
|
2012-03-14 14:06:59 +01:00
|
|
|
// Get test manifest
|
2010-09-21 22:29:11 +02:00
|
|
|
ManifestBuilder::load_test_manifest();
|