See Release Notes
Long Term Support Release
<?php // This file is part of Moodle - http://moodle.org/ // // Moodle is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Moodle is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with Moodle. If not, see <http://www.gnu.org/licenses/>. /** * Behat course-related step definition overrides for the Classic theme. * * @package theme_classic * @category test * @copyright 2019 Michael Hawkins * @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__ . '/../../../../course/tests/behat/behat_course.php'); /** * Course-related step definition overrides for the Classic theme. * * @package theme_classic * @category test * @copyright 2019 Michael Hawkins * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class behat_theme_classic_behat_course extends behat_course { /** * Go to the course participants. */ public function i_navigate_to_course_participants() { $coursestr = behat_context_helper::escape(get_string('courses')); $mycoursestr = behat_context_helper::escape(get_string('mycourses'));< $xpath = "//div[contains(@class,'block')]//li[p/*[string(.)=$coursestr or string(.)=$mycoursestr]]";> $xpath = "//div[contains(@class,'block')]//li[contains(@class,'contains_branch')]" . > "[p/*[string(.)=$coursestr or string(.)=$mycoursestr]]";$this->execute('behat_general::i_click_on_in_the', [get_string('participants'), 'link', $xpath, 'xpath_element']);> } } > } > /** > * Returns whether the user has permission to modify this course. > * > * @return bool > */ > protected function is_course_editor(): bool { > // If the course is already in editing mode then it will have the class 'editing' on the body. > // This is a 'cheap' way of telling if the course is in editing mode. > $body = $this->find('css', 'body'); > if ($body->hasClass('editing')) { > return true; > } > > // If the course is not already in editing mode, then the only real way to find out if the current user may edit > // the page is to look for the "Turn editing on" button. > // If the button is found then the user is a course editor. > try { > $this->find('button', get_string('turneditingon'), false, false, 0); > return true; > } catch (Exception $e) { > return false; > }