mirror of
https://github.com/moodle/moodle.git
synced 2025-08-04 16:36:37 +02:00
MDL-58023 behat: Improve find_node_in_navigation function
This commit is contained in:
parent
1034421264
commit
01f2a530b7
2 changed files with 19 additions and 15 deletions
|
@ -944,4 +944,22 @@ class behat_base extends Behat\MinkExtension\Context\RawMinkContext {
|
|||
}
|
||||
return $DB->get_record('user', ['id' => $userid]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Trigger click on node via javascript instead of actually clicking on it via pointer.
|
||||
*
|
||||
* This function resolves the issue of nested elements with click listeners or links - in these cases clicking via
|
||||
* the pointer may accidentally cause a click on the wrong element.
|
||||
* Example of issue: clicking to expand navigation nodes when the config value linkadmincategories is enabled.
|
||||
* @param NodeElement $node
|
||||
*/
|
||||
protected function js_trigger_click($node) {
|
||||
if (!$this->running_javascript()) {
|
||||
$node->click();
|
||||
}
|
||||
$this->ensure_node_is_visible($node); // Ensures hidden elements can't be clicked.
|
||||
$xpath = $node->getXpath();
|
||||
$script = "Syn.click({{ELEMENT}})";
|
||||
$this->getSession()->getDriver()->triggerSynScript($xpath, $script);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -290,21 +290,7 @@ class behat_navigation extends behat_base {
|
|||
if ($pnode && $this->running_javascript() && $pnode->hasAttribute('aria-expanded') &&
|
||||
($pnode->getAttribute('aria-expanded') == "false")) {
|
||||
|
||||
$this->ensure_node_is_visible($pnode);
|
||||
|
||||
// If node is a link then some driver click in the middle of the node, which click on link and
|
||||
// page gets redirected. To ensure expansion works in all cases, check if the node to expand is a
|
||||
// link and if yes then click on link and wait for it to navigate to next page with node expanded.
|
||||
$nodetoexpandliteral = behat_context_helper::escape($parentnodes[$i]);
|
||||
$nodetoexpandxpathlink = $pnodexpath . "/a[normalize-space(.)=" . $nodetoexpandliteral . "]";
|
||||
|
||||
if ($nodetoexpandlink = $node->find('xpath', $nodetoexpandxpathlink)) {
|
||||
$behatgeneralcontext = behat_context_helper::get('behat_general');
|
||||
$nodetoexpandlink->click();
|
||||
$behatgeneralcontext->wait_until_the_page_is_ready();
|
||||
} else {
|
||||
$pnode->click();
|
||||
}
|
||||
$this->js_trigger_click($pnode);
|
||||
|
||||
// Wait for node to load, if not loaded before.
|
||||
if ($pnode->hasAttribute('data-loaded') && $pnode->getAttribute('data-loaded') == "false") {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue