mirror of
https://github.com/moodle/moodle.git
synced 2025-04-25 10:26:17 +02:00
Merge branch 'MDL-58023_behat_find_node_in_navigation_improvement_master' of https://github.com/gthomas2/moodle
This commit is contained in:
commit
edf102805a
@ -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…
x
Reference in New Issue
Block a user