Extension hooks

This commit is contained in:
Ingo Schommer 2013-12-09 13:29:46 +01:00
parent 3dbaf8f92a
commit d8debeba08

View File

@ -44,6 +44,8 @@ class TestSessionController extends Controller {
$dbExists = false; $dbExists = false;
} }
$this->extend('onBeforeStart', $dbName);
if(!$dbExists) { if(!$dbExists) {
// Create a new one with a randomized name // Create a new one with a randomized name
$dbName = SapphireTest::create_temp_db(); $dbName = SapphireTest::create_temp_db();
@ -51,6 +53,8 @@ class TestSessionController extends Controller {
$this->setState(array_merge($request->getVars(), array('database' => $dbName))); $this->setState(array_merge($request->getVars(), array('database' => $dbName)));
$this->extend('onAfterStart', $dbName);
return $this->renderWith('TestSession_start'); return $this->renderWith('TestSession_start');
} }
@ -74,7 +78,10 @@ class TestSessionController extends Controller {
); );
} }
$this->setState($request->getVars()); $state = $request->getVars();
$this->extend('onBeforeSet', $state);
$this->setState($data);
$this->extend('onAfterSet');
return $this->renderWith('TestSession_inprogress'); return $this->renderWith('TestSession_inprogress');
} }
@ -87,12 +94,16 @@ class TestSessionController extends Controller {
); );
} }
$this->extend('onBeforeClear');
SapphireTest::empty_temp_db(); SapphireTest::empty_temp_db();
if(isset($_SESSION['_testsession_codeblocks'])) { if(isset($_SESSION['_testsession_codeblocks'])) {
unset($_SESSION['_testsession_codeblocks']); unset($_SESSION['_testsession_codeblocks']);
} }
$this->extend('onAfterClear');
return "Cleared database and test state"; return "Cleared database and test state";
} }
@ -104,12 +115,16 @@ class TestSessionController extends Controller {
); );
} }
$this->extend('onBeforeEnd');
SapphireTest::kill_temp_db(); SapphireTest::kill_temp_db();
DB::set_alternative_database_name(null); DB::set_alternative_database_name(null);
// Workaround for bug in Cookie::get(), fixed in 3.1-rc1 // Workaround for bug in Cookie::get(), fixed in 3.1-rc1
self::$alternative_database_name = null; self::$alternative_database_name = null;
Session::clear('testsession'); Session::clear('testsession');
$this->extend('onAfterEnd');
return $this->renderWith('TestSession_end'); return $this->renderWith('TestSession_end');
} }