Skip to content

Commit

Permalink
Merge branch 'MDL-61928' of git://github.com/timhunt/moodle
Browse files Browse the repository at this point in the history
  • Loading branch information
junpataleta committed Apr 18, 2018
2 parents 2babce1 + 1872cfc commit 11bc487
Show file tree
Hide file tree
Showing 4 changed files with 114 additions and 5 deletions.
2 changes: 1 addition & 1 deletion lib/formslib.php
Expand Up @@ -2894,7 +2894,7 @@ function startForm(&$form){
$formid = $form->getAttribute('id');
parent::startForm($form);
if ($form->isFrozen()){
$this->_formTemplate = "\n<div class=\"mform frozen\">\n{content}\n</div>";
$this->_formTemplate = "\n<div id=\"$formid\" class=\"mform frozen\">\n{collapsebtns}\n{content}\n</div>";
} else {
$this->_formTemplate = "\n<form{attributes}>\n\t<div style=\"display: none;\">{hidden}</div>\n{collapsebtns}\n{content}\n</form>";
$this->_hiddenHtml .= $form->_pageparams;
Expand Down
13 changes: 9 additions & 4 deletions lib/tests/behat/behat_forms.php
Expand Up @@ -117,11 +117,16 @@ protected function expand_all_fields() {
// so, we will use the reduced timeout as it is a common task and we should save time.
try {

// Expand fieldsets link.
$xpath = "//div[@class='collapsible-actions']" .
"/descendant::a[contains(concat(' ', @class, ' '), ' collapseexpand ')]" .
// Expand all fieldsets link - which will only be there if there is more than one collapsible section.
$expandallxpath = "//div[@class='collapsible-actions']" .
"//a[contains(concat(' ', @class, ' '), ' collapseexpand ')]" .
"[not(contains(concat(' ', @class, ' '), ' collapse-all '))]";
$collapseexpandlink = $this->find('xpath', $xpath, false, false, self::REDUCED_TIMEOUT);
// Else, look for the first expand fieldset link.
$expandonlysection = "//legend[@class='ftoggler']" .
"//a[contains(concat(' ', @class, ' '), ' fheader ') and @aria-expanded = 'false']";

$collapseexpandlink = $this->find('xpath', $expandallxpath . '|' . $expandonlysection,
false, false, self::REDUCED_TIMEOUT);
$collapseexpandlink->click();

} catch (ElementNotFoundException $e) {
Expand Down
34 changes: 34 additions & 0 deletions lib/tests/behat/readonlyform.feature
@@ -0,0 +1,34 @@
@core
Feature: Read-only forms should work
In order to use certain forms on large Moodle installations
As a user
Relevant featuers of non-editable forms should still work

@javascript
Scenario: Shortforms expand collapsing should work for read-only forms - one-section form
Given the following "courses" exist:
| fullname | shortname | format |
| Course 1 | C1 | topics |
And the following "activities" exist:
| activity | name | intro | course | idnumber |
| label | L1 | <a href="../lib/tests/fixtures/readonlyform.php?sections=1">Fixture link</a> | C1 | label1 |
And I log in as "admin"
And I am on "Course 1" course homepage
And I follow "Fixture link"
When I expand all fieldsets
Then the field "Name" matches value "Important information"

@javascript
Scenario: Shortforms expand collapsing should work for read-only forms - two-section form
Given the following "courses" exist:
| fullname | shortname | format |
| Course 1 | C1 | topics |
And the following "activities" exist:
| activity | name | intro | course | idnumber |
| label | L1 | <a href="../lib/tests/fixtures/readonlyform.php?sections=2">Fixture link</a> | C1 | label1 |
And I log in as "admin"
And I am on "Course 1" course homepage
And I follow "Fixture link"
When I expand all fieldsets
Then the field "Name" matches value "Important information"
Then the field "Other" matches value "Other information"
70 changes: 70 additions & 0 deletions lib/tests/fixtures/readonlyform.php
@@ -0,0 +1,70 @@
<?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/>.

/**
* Fixture for testing the functionality of read-only forms.
*
* @package core
* @copyright 2018 The Open University
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/

require_once(__DIR__ . '/../../../config.php');
require_once($CFG->libdir . '/formslib.php');

$sections = optional_param('sections', 2, PARAM_INT);
require_login();


/**
* The form used for testing.
*/
class test_read_only_form extends moodleform {
protected function definition() {
$mform = $this->_form;

$sections = $this->_customdata;

$mform->addElement('header', 'sectionheader', 'First section');

$mform->addElement('text', 'name', 'Name');
$mform->setDefault('name', 'Important information');
$mform->setType('name', PARAM_RAW);

$mform->setExpanded('sectionheader', false);

if ($sections > 1) {
$mform->addElement('header', 'secondsection', 'Other section header');

$mform->addElement('text', 'other', 'Other');
$mform->setDefault('other', 'Other information');
$mform->setType('other', PARAM_RAW);

$mform->setExpanded('secondsection', false);
}

$this->add_action_buttons();
}
}

$PAGE->set_context(context_system::instance());
$PAGE->set_url('/lib/tests/fixtures/readonlyform.php');

$form = new test_read_only_form(null, $sections, 'post', '', null, false); // The false here is $editable.

echo $OUTPUT->header();
echo $form->render();
echo $OUTPUT->footer();

0 comments on commit 11bc487

Please sign in to comment.