/**
  * Test get_instance_info
  */
 public function test_get_instance_info()
 {
     global $DB;
     $this->resetAfterTest(true);
     // Check if self enrolment plugin is enabled.
     $selfplugin = enrol_get_plugin('self');
     $this->assertNotEmpty($selfplugin);
     $studentrole = $DB->get_record('role', array('shortname' => 'student'));
     $this->assertNotEmpty($studentrole);
     $coursedata = new stdClass();
     $coursedata->visible = 0;
     $course = self::getDataGenerator()->create_course($coursedata);
     // Add enrolment methods for course.
     $instanceid1 = $selfplugin->add_instance($course, array('status' => ENROL_INSTANCE_ENABLED, 'name' => 'Test instance 1', 'customint6' => 1, 'roleid' => $studentrole->id));
     $instanceid2 = $selfplugin->add_instance($course, array('status' => ENROL_INSTANCE_DISABLED, 'customint6' => 1, 'name' => 'Test instance 2', 'roleid' => $studentrole->id));
     $instanceid3 = $selfplugin->add_instance($course, array('status' => ENROL_INSTANCE_ENABLED, 'roleid' => $studentrole->id, 'customint6' => 1, 'name' => 'Test instance 3', 'password' => 'test'));
     $enrolmentmethods = $DB->get_records('enrol', array('courseid' => $course->id, 'status' => ENROL_INSTANCE_ENABLED));
     $this->assertCount(3, $enrolmentmethods);
     $this->setAdminUser();
     $instanceinfo1 = enrol_self_external::get_instance_info($instanceid1);
     $instanceinfo1 = external_api::clean_returnvalue(enrol_self_external::get_instance_info_returns(), $instanceinfo1);
     $this->assertEquals($instanceid1, $instanceinfo1['id']);
     $this->assertEquals($course->id, $instanceinfo1['courseid']);
     $this->assertEquals('self', $instanceinfo1['type']);
     $this->assertEquals('Test instance 1', $instanceinfo1['name']);
     $this->assertTrue($instanceinfo1['status']);
     $this->assertFalse(isset($instanceinfo1['enrolpassword']));
     $instanceinfo2 = enrol_self_external::get_instance_info($instanceid2);
     $instanceinfo2 = external_api::clean_returnvalue(enrol_self_external::get_instance_info_returns(), $instanceinfo2);
     $this->assertEquals($instanceid2, $instanceinfo2['id']);
     $this->assertEquals($course->id, $instanceinfo2['courseid']);
     $this->assertEquals('self', $instanceinfo2['type']);
     $this->assertEquals('Test instance 2', $instanceinfo2['name']);
     $this->assertEquals(get_string('canntenrol', 'enrol_self'), $instanceinfo2['status']);
     $this->assertFalse(isset($instanceinfo2['enrolpassword']));
     $instanceinfo3 = enrol_self_external::get_instance_info($instanceid3);
     $instanceinfo3 = external_api::clean_returnvalue(enrol_self_external::get_instance_info_returns(), $instanceinfo3);
     $this->assertEquals($instanceid3, $instanceinfo3['id']);
     $this->assertEquals($course->id, $instanceinfo3['courseid']);
     $this->assertEquals('self', $instanceinfo3['type']);
     $this->assertEquals('Test instance 3', $instanceinfo3['name']);
     $this->assertTrue($instanceinfo3['status']);
     $this->assertEquals(get_string('password', 'enrol_self'), $instanceinfo3['enrolpassword']);
     // Try to retrieve information using a normal user for a hidden course.
     $user = self::getDataGenerator()->create_user();
     $this->setUser($user);
     try {
         enrol_self_external::get_instance_info($instanceid3);
     } catch (moodle_exception $e) {
         $this->assertEquals('coursehidden', $e->errorcode);
     }
 }
 /**
  * Test get_instance_info
  */
 public function test_get_instance_info()
 {
     global $DB;
     $this->resetAfterTest(true);
     // Check if self enrolment plugin is enabled.
     $selfplugin = enrol_get_plugin('self');
     $this->assertNotEmpty($selfplugin);
     $studentrole = $DB->get_record('role', array('shortname' => 'student'));
     $this->assertNotEmpty($studentrole);
     $course = self::getDataGenerator()->create_course();
     // Add enrolment methods for course.
     $instanceid1 = $selfplugin->add_instance($course, array('status' => ENROL_INSTANCE_ENABLED, 'name' => 'Test instance 1', 'customint6' => 1, 'roleid' => $studentrole->id));
     $instanceid2 = $selfplugin->add_instance($course, array('status' => ENROL_INSTANCE_DISABLED, 'customint6' => 1, 'name' => 'Test instance 2', 'roleid' => $studentrole->id));
     $instanceid3 = $selfplugin->add_instance($course, array('status' => ENROL_INSTANCE_ENABLED, 'roleid' => $studentrole->id, 'customint6' => 1, 'name' => 'Test instance 3', 'password' => 'test'));
     $enrolmentmethods = $DB->get_records('enrol', array('courseid' => $course->id, 'status' => ENROL_INSTANCE_ENABLED));
     $this->assertCount(3, $enrolmentmethods);
     $instanceinfo1 = enrol_self_external::get_instance_info($instanceid1);
     $this->assertEquals($instanceid1, $instanceinfo1['id']);
     $this->assertEquals($course->id, $instanceinfo1['courseid']);
     $this->assertEquals('self', $instanceinfo1['type']);
     $this->assertEquals('Test instance 1', $instanceinfo1['name']);
     $this->assertTrue($instanceinfo1['status']);
     $this->assertFalse(isset($instanceinfo1['enrolpassword']));
     $instanceinfo2 = enrol_self_external::get_instance_info($instanceid2);
     $this->assertEquals($instanceid2, $instanceinfo2['id']);
     $this->assertEquals($course->id, $instanceinfo2['courseid']);
     $this->assertEquals('self', $instanceinfo2['type']);
     $this->assertEquals('Test instance 2', $instanceinfo2['name']);
     $this->assertEquals(get_string('canntenrol', 'enrol_self'), $instanceinfo2['status']);
     $this->assertFalse(isset($instanceinfo2['enrolpassword']));
     $instanceinfo3 = enrol_self_external::get_instance_info($instanceid3);
     $this->assertEquals($instanceid3, $instanceinfo3['id']);
     $this->assertEquals($course->id, $instanceinfo3['courseid']);
     $this->assertEquals('self', $instanceinfo3['type']);
     $this->assertEquals('Test instance 3', $instanceinfo3['name']);
     $this->assertTrue($instanceinfo3['status']);
     $this->assertEquals(get_string('password', 'enrol_self'), $instanceinfo3['enrolpassword']);
 }
Exemple #3
0
 /**
  * Test enrol_user
  */
 public function test_enrol_user()
 {
     global $DB;
     self::resetAfterTest(true);
     $user = self::getDataGenerator()->create_user();
     self::setUser($user);
     $course1 = self::getDataGenerator()->create_course();
     $course2 = self::getDataGenerator()->create_course(array('groupmode' => SEPARATEGROUPS, 'groupmodeforce' => 1));
     $user1 = self::getDataGenerator()->create_user();
     $user2 = self::getDataGenerator()->create_user();
     $user3 = self::getDataGenerator()->create_user();
     $user4 = self::getDataGenerator()->create_user();
     $context1 = context_course::instance($course1->id);
     $context2 = context_course::instance($course2->id);
     $selfplugin = enrol_get_plugin('self');
     $studentrole = $DB->get_record('role', array('shortname' => 'student'));
     $instance1id = $selfplugin->add_instance($course1, array('status' => ENROL_INSTANCE_ENABLED, 'name' => 'Test instance 1', 'customint6' => 1, 'roleid' => $studentrole->id));
     $instance2id = $selfplugin->add_instance($course2, array('status' => ENROL_INSTANCE_DISABLED, 'customint6' => 1, 'name' => 'Test instance 2', 'roleid' => $studentrole->id));
     $instance1 = $DB->get_record('enrol', array('id' => $instance1id), '*', MUST_EXIST);
     $instance2 = $DB->get_record('enrol', array('id' => $instance2id), '*', MUST_EXIST);
     self::setUser($user1);
     // Self enrol me.
     $result = enrol_self_external::enrol_user($course1->id);
     $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
     self::assertTrue($result['status']);
     self::assertEquals(1, $DB->count_records('user_enrolments', array('enrolid' => $instance1->id)));
     self::assertTrue(is_enrolled($context1, $user1));
     // Add password.
     $instance2->password = '******';
     $DB->update_record('enrol', $instance2);
     // Try instance not enabled.
     try {
         enrol_self_external::enrol_user($course2->id);
     } catch (moodle_exception $e) {
         self::assertEquals('canntenrol', $e->errorcode);
     }
     // Enable the instance.
     $selfplugin->update_status($instance2, ENROL_INSTANCE_ENABLED);
     // Try not passing a key.
     $result = enrol_self_external::enrol_user($course2->id);
     $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
     self::assertFalse($result['status']);
     self::assertCount(1, $result['warnings']);
     self::assertEquals('4', $result['warnings'][0]['warningcode']);
     // Try passing an invalid key.
     $result = enrol_self_external::enrol_user($course2->id, 'invalidkey');
     $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
     self::assertFalse($result['status']);
     self::assertCount(1, $result['warnings']);
     self::assertEquals('4', $result['warnings'][0]['warningcode']);
     // Try passing an invalid key with hint.
     $selfplugin->set_config('showhint', true);
     $result = enrol_self_external::enrol_user($course2->id, 'invalidkey');
     $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
     self::assertFalse($result['status']);
     self::assertCount(1, $result['warnings']);
     self::assertEquals('3', $result['warnings'][0]['warningcode']);
     // Everything correct, now.
     $result = enrol_self_external::enrol_user($course2->id, 'abcdef');
     $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
     self::assertTrue($result['status']);
     self::assertEquals(1, $DB->count_records('user_enrolments', array('enrolid' => $instance2->id)));
     self::assertTrue(is_enrolled($context2, $user1));
     // Try group password now, other user.
     $instance2->customint1 = 1;
     $instance2->password = '******';
     $DB->update_record('enrol', $instance2);
     $group1 = $this->getDataGenerator()->create_group(array('courseid' => $course2->id));
     $group2 = $this->getDataGenerator()->create_group(array('courseid' => $course2->id, 'enrolmentkey' => 'zyx'));
     self::setUser($user2);
     // Try passing and invalid key for group.
     $result = enrol_self_external::enrol_user($course2->id, 'invalidkey');
     $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
     self::assertFalse($result['status']);
     self::assertCount(1, $result['warnings']);
     self::assertEquals('2', $result['warnings'][0]['warningcode']);
     // Now, everything ok.
     $result = enrol_self_external::enrol_user($course2->id, 'zyx');
     $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
     self::assertTrue($result['status']);
     self::assertEquals(2, $DB->count_records('user_enrolments', array('enrolid' => $instance2->id)));
     self::assertTrue(is_enrolled($context2, $user2));
     // Try multiple instances now, multiple errors.
     $instance3id = $selfplugin->add_instance($course2, array('status' => ENROL_INSTANCE_ENABLED, 'customint6' => 1, 'name' => 'Test instance 2', 'roleid' => $studentrole->id));
     $instance3 = $DB->get_record('enrol', array('id' => $instance3id), '*', MUST_EXIST);
     $instance3->password = '******';
     $DB->update_record('enrol', $instance3);
     self::setUser($user3);
     $result = enrol_self_external::enrol_user($course2->id, 'invalidkey');
     $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
     self::assertFalse($result['status']);
     self::assertCount(2, $result['warnings']);
     // Now, everything ok.
     $result = enrol_self_external::enrol_user($course2->id, 'zyx');
     $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
     self::assertTrue($result['status']);
     self::assertTrue(is_enrolled($context2, $user3));
     // Now test passing an instance id.
     self::setUser($user4);
     $result = enrol_self_external::enrol_user($course2->id, 'abcdef', $instance3id);
     $result = external_api::clean_returnvalue(enrol_self_external::enrol_user_returns(), $result);
     self::assertTrue($result['status']);
     self::assertTrue(is_enrolled($context2, $user3));
     self::assertCount(0, $result['warnings']);
     self::assertEquals(1, $DB->count_records('user_enrolments', array('enrolid' => $instance3->id)));
 }