You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
211 lines
8.5 KiB
211 lines
8.5 KiB
<?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/>.
|
|
|
|
/**
|
|
* Steps definitions related with the forum activity.
|
|
*
|
|
* @package mod_forum
|
|
* @category test
|
|
* @copyright 2013 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');
|
|
|
|
use Behat\Gherkin\Node\TableNode as TableNode;
|
|
/**
|
|
* Forum-related steps definitions.
|
|
*
|
|
* @package mod_forum
|
|
* @category test
|
|
* @copyright 2013 David Monllaó
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
class behat_mod_forum extends behat_base {
|
|
|
|
/**
|
|
* Adds a topic to the forum specified by it's name. Useful for the Announcements and blog-style forums.
|
|
*
|
|
* @Given /^I add a new topic to "(?P<forum_name_string>(?:[^"]|\\")*)" forum with:$/
|
|
* @param string $forumname
|
|
* @param TableNode $table
|
|
*/
|
|
public function i_add_a_new_topic_to_forum_with($forumname, TableNode $table) {
|
|
$this->add_new_discussion($forumname, $table, get_string('addanewtopic', 'forum'));
|
|
}
|
|
|
|
/**
|
|
* Adds a discussion to the forum specified by it's name with the provided table data (usually Subject and Message). The step begins from the forum's course page.
|
|
*
|
|
* @Given /^I add a new discussion to "(?P<forum_name_string>(?:[^"]|\\")*)" forum with:$/
|
|
* @param string $forumname
|
|
* @param TableNode $table
|
|
*/
|
|
public function i_add_a_forum_discussion_to_forum_with($forumname, TableNode $table) {
|
|
$this->add_new_discussion($forumname, $table, get_string('addanewdiscussion', 'forum'));
|
|
}
|
|
|
|
/**
|
|
* Adds a discussion to the forum specified by it's name with the provided table data (usually Subject and Message).
|
|
* The step begins from the forum's course page.
|
|
*
|
|
* @Given /^I add a new discussion to "(?P<forum_name_string>(?:[^"]|\\")*)" forum inline with:$/
|
|
* @param string $forumname
|
|
* @param TableNode $table
|
|
*/
|
|
public function i_add_a_forum_discussion_to_forum_inline_with($forumname, TableNode $table) {
|
|
$this->add_new_discussion_inline($forumname, $table, get_string('addanewdiscussion', 'forum'));
|
|
}
|
|
|
|
/**
|
|
* Adds a reply to the specified post of the specified forum. The step begins from the forum's page or from the forum's course page.
|
|
*
|
|
* @Given /^I reply "(?P<post_subject_string>(?:[^"]|\\")*)" post from "(?P<forum_name_string>(?:[^"]|\\")*)" forum with:$/
|
|
* @param string $postname The subject of the post
|
|
* @param string $forumname The forum name
|
|
* @param TableNode $table
|
|
*/
|
|
public function i_reply_post_from_forum_with($postsubject, $forumname, TableNode $table) {
|
|
|
|
// Navigate to forum.
|
|
$this->goto_main_post_reply($postsubject);
|
|
|
|
// Fill form and post.
|
|
$this->execute('behat_forms::i_set_the_following_fields_to_these_values', $table);
|
|
|
|
$this->execute('behat_forms::press_button', get_string('posttoforum', 'forum'));
|
|
$this->execute('behat_general::i_wait_to_be_redirected');
|
|
}
|
|
|
|
/**
|
|
* Inpage Reply - adds a reply to the specified post of the specified forum. The step begins from the forum's page or from the forum's course page.
|
|
*
|
|
* @Given /^I reply "(?P<post_subject_string>(?:[^"]|\\")*)" post from "(?P<forum_name_string>(?:[^"]|\\")*)" forum using an inpage reply with:$/
|
|
* @param string $postsubject The subject of the post
|
|
* @param string $forumname The forum name
|
|
* @param TableNode $table
|
|
*/
|
|
public function i_reply_post_from_forum_using_an_inpage_reply_with($postsubject, $forumname, TableNode $table) {
|
|
|
|
// Navigate to forum.
|
|
$this->execute('behat_general::click_link', $this->escape($forumname));
|
|
$this->execute('behat_general::click_link', $this->escape($postsubject));
|
|
$this->execute('behat_general::click_link', get_string('reply', 'forum'));
|
|
|
|
// Fill form and post.
|
|
$this->execute('behat_forms::i_set_the_following_fields_to_these_values', $table);
|
|
|
|
$this->execute('behat_forms::press_button', get_string('submit', 'core'));
|
|
}
|
|
|
|
/**
|
|
* Navigates to a particular discussion page
|
|
*
|
|
* @Given /^I navigate to post "(?P<post_subject_string>(?:[^"]|\\")*)" in "(?P<forum_name_string>(?:[^"]|\\")*)" forum$/
|
|
* @param string $postsubject The subject of the post
|
|
* @param string $forumname The forum name
|
|
*/
|
|
public function i_navigate_to_post_in_forum($postsubject, $forumname) {
|
|
|
|
// Navigate to forum discussion.
|
|
$this->execute('behat_general::click_link', $this->escape($forumname));
|
|
$this->execute('behat_general::click_link', $this->escape($postsubject));
|
|
}
|
|
|
|
/**
|
|
* Opens up the action menu for the discussion
|
|
*
|
|
* @Given /^I click on "(?P<post_subject_string>(?:[^"]|\\")*)" action menu$/
|
|
* @param string $discussion The subject of the discussion
|
|
*/
|
|
public function i_click_on_action_menu($discussion) {
|
|
$this->execute('behat_general::i_click_on_in_the', [
|
|
"[data-container='discussion-tools'] [data-toggle='dropdown']", "css_element",
|
|
"//tr[contains(concat(' ', normalize-space(@class), ' '), ' discussion ') and contains(.,'$discussion')]",
|
|
"xpath_element"
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Returns the steps list to add a new discussion to a forum.
|
|
*
|
|
* Abstracts add a new topic and add a new discussion, as depending
|
|
* on the forum type the button string changes.
|
|
*
|
|
* @param string $forumname
|
|
* @param TableNode $table
|
|
* @param string $buttonstr
|
|
*/
|
|
protected function add_new_discussion($forumname, TableNode $table, $buttonstr) {
|
|
|
|
// Navigate to forum.
|
|
$this->execute('behat_general::click_link', $this->escape($forumname));
|
|
$this->execute('behat_general::click_link', $buttonstr);
|
|
$this->execute('behat_forms::press_button', get_string('advanced'));
|
|
|
|
$this->fill_new_discussion_form($table);
|
|
}
|
|
|
|
/**
|
|
* Returns the steps list to add a new discussion to a forum inline.
|
|
*
|
|
* Abstracts add a new topic and add a new discussion, as depending
|
|
* on the forum type the button string changes.
|
|
*
|
|
* @param string $forumname
|
|
* @param TableNode $table
|
|
* @param string $buttonstr
|
|
*/
|
|
protected function add_new_discussion_inline($forumname, TableNode $table, $buttonstr) {
|
|
|
|
// Navigate to forum.
|
|
$this->execute('behat_general::click_link', $this->escape($forumname));
|
|
$this->execute('behat_general::click_link', $buttonstr);
|
|
$this->fill_new_discussion_form($table);
|
|
}
|
|
|
|
/**
|
|
* Fill in the forum's post form and submit. It assumes you've already navigated and enabled the form for view.
|
|
*
|
|
* @param TableNode $table
|
|
* @throws coding_exception
|
|
*/
|
|
protected function fill_new_discussion_form(TableNode $table) {
|
|
// Fill form and post.
|
|
$this->execute('behat_forms::i_set_the_following_fields_to_these_values', $table);
|
|
$this->execute('behat_forms::press_button', get_string('posttoforum', 'forum'));
|
|
$this->execute('behat_general::i_wait_to_be_redirected');
|
|
}
|
|
|
|
/**
|
|
* Go to the default reply to post page.
|
|
* This is used instead of navigating through 4-5 different steps and to solve issues where JS would be required to click
|
|
* on the advanced button
|
|
*
|
|
* @param $postsubject
|
|
* @throws coding_exception
|
|
* @throws dml_exception
|
|
* @throws moodle_exception
|
|
*/
|
|
protected function goto_main_post_reply($postsubject) {
|
|
global $DB;
|
|
$post = $DB->get_record("forum_posts", array("subject" => $postsubject), 'id', MUST_EXIST);
|
|
$url = new moodle_url('/mod/forum/post.php', ['reply' => $post->id]);
|
|
$this->getSession()->visit($this->locate_path($url->out_as_local_url(false)));
|
|
}
|
|
}
|
|
|