mirror of
https://github.com/moodle/moodle.git
synced 2025-03-22 16:40:07 +01:00
MDL-48374 behat: Check flag before searching for span on page
This commit is contained in:
parent
1b2c35af34
commit
9f3a68fe61
@ -67,7 +67,7 @@ class behat_general extends behat_base {
|
||||
* @var $pageloaddetectionrunning boolean Used to ensure that page load detection was started before a page reload
|
||||
* was checked for.
|
||||
*/
|
||||
private $pageloaddetectionrunning = null;
|
||||
private $pageloaddetectionrunning = false;
|
||||
|
||||
/**
|
||||
* Opens Moodle homepage.
|
||||
@ -1246,15 +1246,18 @@ class behat_general extends behat_base {
|
||||
throw new DriverException('Page load detection requires JavaScript.');
|
||||
}
|
||||
|
||||
if ($this->getSession()->getPage()->find('xpath', $this->get_page_load_xpath())) {
|
||||
$session = $this->getSession();
|
||||
|
||||
if ($this->pageloaddetectionrunning || $session->getPage()->find('xpath', $this->get_page_load_xpath())) {
|
||||
// If we find this node at this point we are already watching for a reload and the behat steps
|
||||
// are out of order. We will treat this as an error - really it needs to be fixed as it indicates a problem.
|
||||
throw new ExpectationException('Page load expectation error: page reloads are already been watched for.');
|
||||
throw new ExpectationException(
|
||||
'Page load expectation error: page reloads are already been watched for.', $session);
|
||||
}
|
||||
|
||||
$this->pageloaddetectionrunning = true;
|
||||
|
||||
$this->getSession()->evaluateScript(
|
||||
$session->evaluateScript(
|
||||
'var span = document.createElement("span");
|
||||
span.setAttribute("data-rel", "' . self::PAGE_LOAD_DETECTION_STRING . '");
|
||||
span.setAttribute("style", "display: none;");
|
||||
@ -1268,23 +1271,23 @@ class behat_general extends behat_base {
|
||||
* @Given /^a new page should have loaded since I started watching$/
|
||||
*/
|
||||
public function a_new_page_should_have_loaded_since_i_started_watching() {
|
||||
// As the node is inserted by code above it is either there or not, and we do not need spin and it is safe
|
||||
// to use the native API here which is great as exception handling (the alternative is slow).
|
||||
if ($this->getSession()->getPage()->find('xpath', $this->get_page_load_xpath())) {
|
||||
// We don't want to find this node, if we do we have an error.
|
||||
throw new ExpectationException(
|
||||
'Page load expectation error: a new page has not been loaded when it should have been.',
|
||||
$this->getSession()
|
||||
);
|
||||
}
|
||||
$session = $this->getSession();
|
||||
|
||||
// Make sure page load tracking was started.
|
||||
if (!$this->pageloaddetectionrunning) {
|
||||
throw new ExpectationException(
|
||||
'Page load expectation error: page load tracking was not started.',
|
||||
$this->getSession());
|
||||
'Page load expectation error: page load tracking was not started.', $session);
|
||||
}
|
||||
|
||||
// Cancel the trakcing of pageloaddetectionrunning.
|
||||
// As the node is inserted by code above it is either there or not, and we do not need spin and it is safe
|
||||
// to use the native API here which is great as exception handling (the alternative is slow).
|
||||
if ($session->getPage()->find('xpath', $this->get_page_load_xpath())) {
|
||||
// We don't want to find this node, if we do we have an error.
|
||||
throw new ExpectationException(
|
||||
'Page load expectation error: a new page has not been loaded when it should have been.', $session);
|
||||
}
|
||||
|
||||
// Cancel the tracking of pageloaddetectionrunning.
|
||||
$this->pageloaddetectionrunning = false;
|
||||
}
|
||||
|
||||
@ -1295,6 +1298,12 @@ class behat_general extends behat_base {
|
||||
* @Given /^a new page should not have loaded since I started watching$/
|
||||
*/
|
||||
public function a_new_page_should_not_have_loaded_since_i_started_watching() {
|
||||
// Make sure page load tracking was started.
|
||||
if (!$this->pageloaddetectionrunning) {
|
||||
throw new ExpectationException(
|
||||
'Page load expectation error: page load tracking was not started.', $session);
|
||||
}
|
||||
|
||||
// We use our API here as we can use the exception handling provided by it.
|
||||
$this->find(
|
||||
'xpath',
|
||||
|
Loading…
x
Reference in New Issue
Block a user