. /** * Steps definitions related with blocks. * * @package core_block * @category test * @copyright 2012 David Monllaó * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ // NOTE: no MOODLE_INTERNAL test here, this file may be required by behat before including /config.php. require_once(__DIR__ . '/../../../lib/behat/behat_base.php'); /** * Blocks management steps definitions. * * @package core_block * @category test * @copyright 2012 David Monllaó * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class behat_blocks extends behat_base { /** * Adds the selected block. Editing mode must be previously enabled. * * @Given /^I add the "(?P(?:[^"]|\\")*)" block$/ * @param string $blockname */ public function i_add_the_block($blockname) { $this->execute('behat_forms::i_set_the_field_to', array("bui_addblock", $this->escape($blockname)) ); // If we are running without javascript we need to submit the form. if (!$this->running_javascript()) { $this->execute('behat_general::i_click_on_in_the', array(get_string('go'), "button", "#add_block", "css_element") ); } } /** * Docks a block. Editing mode should be previously enabled. * * @Given /^I dock "(?P(?:[^"]|\\")*)" block$/ * @param string $blockname */ public function i_dock_block($blockname) { // Looking for both title and alt. $xpath = "//input[@type='image'][@title='" . get_string('dockblock', 'block', $blockname) . "' or @alt='" . get_string('addtodock', 'block') . "']"; $this->execute('behat_general::i_click_on_in_the', array($xpath, "xpath_element", $this->escape($blockname), "block") ); } /** * Opens a block's actions menu if it is not already opened. * * @Given /^I open the "(?P(?:[^"]|\\")*)" blocks action menu$/ * @throws DriverException The step is not available when Javascript is disabled * @param string $blockname */ public function i_open_the_blocks_action_menu($blockname) { if (!$this->running_javascript()) { // Action menu does not need to be open if Javascript is off. return; } // If it is already opened we do nothing. $blocknode = $this->get_text_selector_node('block', $blockname); if ($blocknode->hasClass('action-menu-shown')) { return; } $this->execute('behat_general::i_click_on_in_the', array("a[role='menuitem']", "css_element", $this->escape($blockname), "block") ); } /** * Clicks on Configure block for specified block. Page must be in editing mode. * * Argument block_name may be either the name of the block or CSS class of the block. * * @Given /^I configure the "(?P(?:[^"]|\\")*)" block$/ * @param string $blockname */ public function i_configure_the_block($blockname) { // Note that since $blockname may be either block name or CSS class, we can not use the exact label of "Configure" link. $this->execute("behat_blocks::i_open_the_blocks_action_menu", $this->escape($blockname)); $this->execute('behat_general::i_click_on_in_the', array("Configure", "link", $this->escape($blockname), "block") ); } }