Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 3.9.x will end* 10 May 2021 (12 months).
  • Bug fixes for security issues in 3.9.x will end* 8 May 2023 (36 months).
  • PHP version: minimum PHP 7.2.0 Note: minimum PHP version has increased since Moodle 3.8. PHP 7.3.x and 7.4.x are supported too.

Differences Between: [Versions 39 and 311] [Versions 39 and 400] [Versions 39 and 401] [Versions 39 and 402] [Versions 39 and 403]

   1  <?php
   2  // This file is part of Moodle - http://moodle.org/
   3  //
   4  // Moodle is free software: you can redistribute it and/or modify
   5  // it under the terms of the GNU General Public License as published by
   6  // the Free Software Foundation, either version 3 of the License, or
   7  // (at your option) any later version.
   8  //
   9  // Moodle is distributed in the hope that it will be useful,
  10  // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12  // GNU General Public License for more details.
  13  //
  14  // You should have received a copy of the GNU General Public License
  15  // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
  16  
  17  /**
  18   * Self enrol external PHPunit tests
  19   *
  20   * @package   enrol_self
  21   * @copyright 2013 Rajesh Taneja <rajesh@moodle.com>
  22   * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  23   * @since     Moodle 2.6
  24   */
  25  
  26  defined('MOODLE_INTERNAL') || die();
  27  
  28  global $CFG;
  29  
  30  require_once($CFG->dirroot . '/webservice/tests/helpers.php');
  31  require_once($CFG->dirroot . '/enrol/self/externallib.php');
  32  
  33  class enrol_self_external_testcase extends externallib_advanced_testcase {
  34  
  35      /**
  36       * Test get_instance_info
  37       */
  38      public function test_get_instance_info() {
  39          global $DB;
  40  
  41          $this->resetAfterTest(true);
  42  
  43          // Check if self enrolment plugin is enabled.
  44          $selfplugin = enrol_get_plugin('self');
  45          $this->assertNotEmpty($selfplugin);
  46  
  47          $studentrole = $DB->get_record('role', array('shortname'=>'student'));
  48          $this->assertNotEmpty($studentrole);
  49  
  50          $coursedata = new stdClass();
  51          $coursedata->visible = 0;
  52          $course = self::getDataGenerator()->create_course($coursedata);
  53  
  54          // Add enrolment methods for course.
  55          $instanceid1 = $selfplugin->add_instance($course, array('status' => ENROL_INSTANCE_ENABLED,
  56                                                                  'name' => 'Test instance 1',
  57                                                                  'customint6' => 1,
  58                                                                  'roleid' => $studentrole->id));
  59          $instanceid2 = $selfplugin->add_instance($course, array('status' => ENROL_INSTANCE_DISABLED,
  60                                                                  'customint6' => 1,
  61                                                                  'name' => 'Test instance 2',
  62                                                                  'roleid' => $studentrole->id));
  63  
  64          $instanceid3 = $selfplugin->add_instance($course, array('status' => ENROL_INSTANCE_ENABLED,
  65                                                                  'roleid' => $studentrole->id,
  66                                                                  'customint6' => 1,
  67                                                                  'name' => 'Test instance 3',
  68                                                                  'password' => 'test'));
  69  
  70          $enrolmentmethods = $DB->get_records('enrol', array('courseid' => $course->id, 'status' => ENROL_INSTANCE_ENABLED));
  71          $this->assertCount(3, $enrolmentmethods);
  72  
  73          $this->setAdminUser();
  74          $instanceinfo1 = enrol_self_external::get_instance_info($instanceid1);
  75          $instanceinfo1 = external_api::clean_returnvalue(enrol_self_external::get_instance_info_returns(), $instanceinfo1);
  76  
  77          $this->assertEquals($instanceid1, $instanceinfo1['id']);
  78          $this->assertEquals($course->id, $instanceinfo1['courseid']);
  79          $this->assertEquals('self', $instanceinfo1['type']);
  80          $this->assertEquals('Test instance 1', $instanceinfo1['name']);
  81          $this->assertTrue($instanceinfo1['status']);
  82          $this->assertFalse(isset($instanceinfo1['enrolpassword']));
  83  
  84          $instanceinfo2 = enrol_self_external::get_instance_info($instanceid2);
  85          $instanceinfo2 = external_api::clean_returnvalue(enrol_self_external::get_instance_info_returns(), $instanceinfo2);
  86          $this->assertEquals($instanceid2, $instanceinfo2['id']);
  87          $this->assertEquals($course->id, $instanceinfo2['courseid']);
  88          $this->assertEquals('self', $instanceinfo2['type']);
  89          $this->assertEquals('Test instance 2', $instanceinfo2['name']);
  90          $this->assertEquals(get_string('canntenrol', 'enrol_self'), $instanceinfo2['status']);
  91          $this->assertFalse(isset($instanceinfo2['enrolpassword']));
  92  
  93          $instanceinfo3 = enrol_self_external::get_instance_info($instanceid3);
  94          $instanceinfo3 = external_api::clean_returnvalue(enrol_self_external::get_instance_info_returns(), $instanceinfo3);
  95          $this->assertEquals($instanceid3, $instanceinfo3['id']);
  96          $this->assertEquals($course->id, $instanceinfo3['courseid']);
  97          $this->assertEquals('self', $instanceinfo3['type']);
  98          $this->assertEquals('Test instance 3', $instanceinfo3['name']);
  99          $this->assertTrue($instanceinfo3['status']);
 100          $this->assertEquals(get_string('password', 'enrol_self'), $instanceinfo3['enrolpassword']);
 101  
 102          // Try to retrieve information using a normal user for a hidden course.
 103          $user = self::getDataGenerator()->create_user();
 104          $this->setUser($user);
 105          try {
 106              enrol_self_external::get_instance_info($instanceid3);
 107          } catch (moodle_exception $e) {
 108              $this->assertEquals('coursehidden', $e->errorcode);
 109          }
 110      }
 111  
 112      /**
 113       * Test enrol_user
 114       */
 115      public function test_enrol_user() {
 116          global $DB;
 117  
 118          self::resetAfterTest(true);
 119  
 120          $user = self::getDataGenerator()->create_user();
 121          self::setUser($user);
 122  
 123          $course1 = self::getDataGenerator()->create_course();
 124          $course2 = self::getDataGenerator()->create_course(array('groupmode' => SEPARATEGROUPS, 'groupmodeforce' => 1));
 125          $user1 = self::getDataGenerator()->create_user();
 126          $user2 = self::getDataGenerator()->create_user();
 127          $user3 = self::getDataGenerator()->create_user();
 128          $user4 = self::getDataGenerator()->create_user();
 129  
 130          $context1 = context_course::instance($course1->id);
 131          $context2 = context_course::instance($course2->id);
 132  
 133          $selfplugin = enrol_get_plugin('self');
 134          $studentrole = $DB->get_record('role', array('shortname' => 'student'));
 135          $instance1id = $selfplugin->add_instance($course1, array('status' => ENROL_INSTANCE_ENABLED,
 136                                                                  'name' => 'Test instance 1',
 137                                                                  'customint6' => 1,
 138                                                                  'roleid' => $studentrole->id));
 139          $instance2id = $selfplugin->add_instance($course2, array('status' => ENROL_INSTANCE_DISABLED,
 140                                                                  'customint6' => 1,
 141                                                                  'name' => 'Test instance 2',
 142                                                                  'roleid' => $studentrole->id));
 143          $instance1 = $DB->get_record('enrol', array('id' => $instance1id), '*', MUST_EXIST);
 144          $instance2 = $DB->get_record('enrol', array('id' => $instance2id), '*', MUST_EXIST);
 145  
 146          self::setUser($user1);
 147  
 148          // Self enrol me.
 149          $result = enrol_self_external::enrol_user($course1->id);
 150          $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
 151  
 152          self::assertTrue($result['status']);
 153          self::assertEquals(1, $DB->count_records('user_enrolments', array('enrolid' => $instance1->id)));
 154          self::assertTrue(is_enrolled($context1, $user1));
 155  
 156          // Add password.
 157          $instance2->password = 'abcdef';
 158          $DB->update_record('enrol', $instance2);
 159  
 160          // Try instance not enabled.
 161          try {
 162              enrol_self_external::enrol_user($course2->id);
 163          } catch (moodle_exception $e) {
 164              self::assertEquals('canntenrol', $e->errorcode);
 165          }
 166  
 167          // Enable the instance.
 168          $selfplugin->update_status($instance2, ENROL_INSTANCE_ENABLED);
 169  
 170          // Try not passing a key.
 171          $result = enrol_self_external::enrol_user($course2->id);
 172          $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
 173          self::assertFalse($result['status']);
 174          self::assertCount(1, $result['warnings']);
 175          self::assertEquals('4', $result['warnings'][0]['warningcode']);
 176  
 177          // Try passing an invalid key.
 178          $result = enrol_self_external::enrol_user($course2->id, 'invalidkey');
 179          $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
 180          self::assertFalse($result['status']);
 181          self::assertCount(1, $result['warnings']);
 182          self::assertEquals('4', $result['warnings'][0]['warningcode']);
 183  
 184          // Try passing an invalid key with hint.
 185          $selfplugin->set_config('showhint', true);
 186          $result = enrol_self_external::enrol_user($course2->id, 'invalidkey');
 187          $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
 188          self::assertFalse($result['status']);
 189          self::assertCount(1, $result['warnings']);
 190          self::assertEquals('3', $result['warnings'][0]['warningcode']);
 191  
 192          // Everything correct, now.
 193          $result = enrol_self_external::enrol_user($course2->id, 'abcdef');
 194          $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
 195  
 196          self::assertTrue($result['status']);
 197          self::assertEquals(1, $DB->count_records('user_enrolments', array('enrolid' => $instance2->id)));
 198          self::assertTrue(is_enrolled($context2, $user1));
 199  
 200          // Try group password now, other user.
 201          $instance2->customint1 = 1;
 202          $instance2->password = 'zyx';
 203          $DB->update_record('enrol', $instance2);
 204  
 205          $group1 = $this->getDataGenerator()->create_group(array('courseid' => $course2->id));
 206          $group2 = $this->getDataGenerator()->create_group(array('courseid' => $course2->id, 'enrolmentkey' => 'zyx'));
 207  
 208          self::setUser($user2);
 209          // Try passing and invalid key for group.
 210          $result = enrol_self_external::enrol_user($course2->id, 'invalidkey');
 211          $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
 212          self::assertFalse($result['status']);
 213          self::assertCount(1, $result['warnings']);
 214          self::assertEquals('2', $result['warnings'][0]['warningcode']);
 215  
 216          // Now, everything ok.
 217          $result = enrol_self_external::enrol_user($course2->id, 'zyx');
 218          $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
 219  
 220          self::assertTrue($result['status']);
 221          self::assertEquals(2, $DB->count_records('user_enrolments', array('enrolid' => $instance2->id)));
 222          self::assertTrue(is_enrolled($context2, $user2));
 223  
 224          // Try multiple instances now, multiple errors.
 225          $instance3id = $selfplugin->add_instance($course2, array('status' => ENROL_INSTANCE_ENABLED,
 226                                                                  'customint6' => 1,
 227                                                                  'name' => 'Test instance 2',
 228                                                                  'roleid' => $studentrole->id));
 229          $instance3 = $DB->get_record('enrol', array('id' => $instance3id), '*', MUST_EXIST);
 230          $instance3->password = 'abcdef';
 231          $DB->update_record('enrol', $instance3);
 232  
 233          self::setUser($user3);
 234          $result = enrol_self_external::enrol_user($course2->id, 'invalidkey');
 235          $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
 236          self::assertFalse($result['status']);
 237          self::assertCount(2, $result['warnings']);
 238  
 239          // Now, everything ok.
 240          $result = enrol_self_external::enrol_user($course2->id, 'zyx');
 241          $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
 242          self::assertTrue($result['status']);
 243          self::assertTrue(is_enrolled($context2, $user3));
 244  
 245          // Now test passing an instance id.
 246          self::setUser($user4);
 247          $result = enrol_self_external::enrol_user($course2->id, 'abcdef', $instance3id);
 248          $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
 249          self::assertTrue($result['status']);
 250          self::assertTrue(is_enrolled($context2, $user3));
 251          self::assertCount(0, $result['warnings']);
 252          self::assertEquals(1, $DB->count_records('user_enrolments', array('enrolid' => $instance3->id)));
 253      }
 254  }