Merge pull request #75 from halkyon/disable_create_database

Allow setting create_temp_database to false to stop temp db creation
This commit is contained in:
Mateusz U 2014-10-09 09:30:46 +13:00
commit 276b5298f5
4 changed files with 79 additions and 51 deletions

View File

@ -25,7 +25,12 @@ use SilverStripe\BehatExtension\Context\SilverStripeAwareContextInterface;
class SilverStripeAwareInitializer implements InitializerInterface
{
private $databaseName;
/**
* @var bool
*/
protected $createTempDatabase;
protected $databaseName;
/**
* @var Array
@ -57,32 +62,28 @@ class SilverStripeAwareInitializer implements InitializerInterface
*/
protected $testSessionEnvironment;
/**
* Initializes initializer.
*/
public function __construct($frameworkPath)
{
$this->bootstrap($frameworkPath);
protected $frameworkPath;
public function initTestSession() {
$this->bootstrap($this->frameworkPath);
if($this->createTempDatabase) {
file_put_contents('php://stdout', "Creating test session environment" . PHP_EOL);
$testEnv = \Injector::inst()->get('TestSessionEnvironment');
$testEnv->startTestSession(array(
'createDatabase' => true
));
$testEnv->startTestSession();
$state = $testEnv->getState();
$this->databaseName = $state->database;
$this->testSessionEnvironment = $testEnv;
file_put_contents('php://stdout', "Temp Database: $this->databaseName" . PHP_EOL . PHP_EOL);
register_shutdown_function(array($this, '__destruct'));
register_shutdown_function(array($this, 'killTestSession'));
}
}
public function __destruct()
{
public function killTestSession() {
file_put_contents('php://stdout', "Killing test session environment...");
if($this->testSessionEnvironment) {
@ -111,6 +112,7 @@ class SilverStripeAwareInitializer implements InitializerInterface
*/
public function initialize(ContextInterface $context)
{
$context->setCreateTempDatabase($this->createTempDatabase);
$context->setDatabase($this->databaseName);
$context->setAjaxSteps($this->ajaxSteps);
$context->setAjaxTimeout($this->ajaxTimeout);
@ -118,6 +120,18 @@ class SilverStripeAwareInitializer implements InitializerInterface
$context->setRegionMap($this->regionMap);
$context->setAdminUrl($this->adminUrl);
$context->setLoginUrl($this->loginUrl);
$this->initTestSession();
}
public function setFrameworkPath($path)
{
$this->frameworkPath = $path;
}
public function setCreateTempDatabase($bool)
{
$this->createTempDatabase = $bool;
}
public function setAjaxSteps($ajaxSteps)

View File

@ -27,6 +27,9 @@ require_once 'vendor/autoload.php';
*/
class SilverStripeContext extends MinkContext implements SilverStripeAwareContextInterface
{
protected $createTempDatabase;
protected $databaseName;
/**
@ -76,6 +79,10 @@ class SilverStripeContext extends MinkContext implements SilverStripeAwareContex
$this->testSessionEnvironment = new \TestSessionEnvironment();
}
public function setCreateTempDatabase($bool) {
$this->createTempDatabase = $bool;
}
public function setDatabase($databaseName) {
$this->databaseName = $databaseName;
}
@ -180,6 +187,7 @@ class SilverStripeContext extends MinkContext implements SilverStripeAwareContex
* @BeforeScenario
*/
public function before(ScenarioEvent $event) {
if($this->createTempDatabase) {
if (!isset($this->databaseName)) {
throw new \LogicException(
'Context\'s $databaseName has to be set when implementing SilverStripeAwareContextInterface.'
@ -204,6 +212,7 @@ class SilverStripeContext extends MinkContext implements SilverStripeAwareContex
if($fixtureFile) {
$this->testSessionEnvironment->loadFixtureIntoDb($fixtureFile);
}
}
if($screenSize = getenv('BEHAT_SCREEN_SIZE')) {
list($screenWidth, $screenHeight) = explode('x', $screenSize);

View File

@ -54,6 +54,7 @@ class Extension implements ExtensionInterface
$container->setParameter('behat.silverstripe_extension.admin_url', $config['admin_url']);
$container->setParameter('behat.silverstripe_extension.login_url', $config['login_url']);
$container->setParameter('behat.silverstripe_extension.screenshot_path', $config['screenshot_path']);
$container->setParameter('behat.silverstripe_extension.create_temp_database', $config['create_temp_database']);
$container->setParameter('behat.silverstripe_extension.ajax_timeout', $config['ajax_timeout']);
if (isset($config['ajax_steps'])) {
$container->setParameter('behat.silverstripe_extension.ajax_steps', $config['ajax_steps']);
@ -82,6 +83,9 @@ class Extension implements ExtensionInterface
{
$builder->
children()->
scalarNode('create_temp_database')->
defaultValue(true)->
end()->
scalarNode('framework_path')->
defaultValue('framework')->
end()->

View File

@ -10,15 +10,16 @@ parameters:
behat.silverstripe_extension.admin_url: ~
behat.silverstripe_extension.login_url: ~
behat.silverstripe_extension.screenshot_path: ~
behat.silverstripe_extension.create_temp_database: true
behat.silverstripe_extension.module:
behat.silverstripe_extension.region_map: ~
behat.silverstripe_extension.context.path_suffix: tests/behat/features/
services:
behat.silverstripe_extension.context.initializer:
class: %behat.silverstripe_extension.context.initializer.class%
arguments:
- %behat.silverstripe_extension.framework_path%
calls:
- [setFrameworkPath, [%behat.silverstripe_extension.framework_path%]]
- [setCreateTempDatabase, [%behat.silverstripe_extension.create_temp_database%]]
- [setAjaxSteps, [%behat.silverstripe_extension.ajax_steps%]]
- [setAjaxTimeout, [%behat.silverstripe_extension.ajax_timeout%]]
- [setAdminUrl, [%behat.silverstripe_extension.admin_url%]]