Refactor default screen resize into SilverStripeContext

This commit is contained in:
Damian Mooyman 2014-08-14 16:21:31 +12:00
parent 01b129de35
commit c0801a63ef
2 changed files with 7 additions and 21 deletions

View File

@ -97,21 +97,6 @@ JS;
$this->getSession()->executeScript($javascript); $this->getSession()->executeScript($javascript);
} }
/**
* @BeforeStep ~@resizes&&~@modal
*
* Resize the window to maximum size, unless the step will resize itself
*/
public function maximiseWindowBeforeStep(StepEvent $event) {
$driver = $this->getSession()->getDriver();
if($screenSize = getenv('BEHAT_SCREEN_SIZE')) {
list($screenWidth, $screenHeight) = explode('x', $screenSize);
$driver->resizeWindow((int)$screenWidth, (int)$screenHeight);
} else {
$driver->resizeWindow(1024, 768);
}
}
/** /**
* @AfterStep ~@modal * @AfterStep ~@modal
* *

View File

@ -62,7 +62,7 @@ class SilverStripeContext extends MinkContext implements SilverStripeAwareContex
protected $context; protected $context;
protected $testSessionEnvironment; protected $testSessionEnvironment;
/** /**
* Initializes context. * Initializes context.
@ -205,17 +205,18 @@ class SilverStripeContext extends MinkContext implements SilverStripeAwareContex
$this->testSessionEnvironment->loadFixtureIntoDb($fixtureFile); $this->testSessionEnvironment->loadFixtureIntoDb($fixtureFile);
} }
if($screenSize = getenv('BEHAT_SCREEN_SIZE')) { if($screenSize = getenv('BEHAT_SCREEN_SIZE')) {
list($screenWidth, $screenHeight) = explode('x', $screenSize); list($screenWidth, $screenHeight) = explode('x', $screenSize);
$this->getSession()->resizeWindow((int)$screenWidth, (int)$screenHeight); $this->getSession()->resizeWindow((int)$screenWidth, (int)$screenHeight);
} else {
$this->getSession()->resizeWindow(1024, 768);
} }
} }
/** /**
* Returns a parameter map of state to set within the test session. * Returns a parameter map of state to set within the test session.
* Takes TESTSESSION_PARAMS environment variable into account for run-specific configurations. * Takes TESTSESSION_PARAMS environment variable into account for run-specific configurations.
* *
* @return array * @return array
*/ */
public function getTestSessionState() { public function getTestSessionState() {
@ -350,10 +351,10 @@ class SilverStripeContext extends MinkContext implements SilverStripeAwareContex
if($fields) foreach($fields as $field) { if($fields) foreach($fields as $field) {
if($field->isVisible()) { if($field->isVisible()) {
$field->setValue($value); $field->setValue($value);
return; return;
} }
} }
throw new ElementNotFoundException( throw new ElementNotFoundException(
$this->getSession(), 'form field', 'id|name|label|value', $field $this->getSession(), 'form field', 'id|name|label|value', $field
); );
@ -370,7 +371,7 @@ class SilverStripeContext extends MinkContext implements SilverStripeAwareContex
if($links) foreach($links as $l) { if($links) foreach($links as $l) {
if($l->isVisible()) { if($l->isVisible()) {
$l->click(); $l->click();
return; return;
} }
} }
throw new ElementNotFoundException( throw new ElementNotFoundException(