diff options
author | Valentin Popov <info@valentineus.link> | 2018-06-12 09:28:29 +0300 |
---|---|---|
committer | Valentin Popov <info@valentineus.link> | 2018-06-12 09:28:29 +0300 |
commit | 5470099f403478dff3c396c2af98508ccc16ea72 (patch) | |
tree | 6d3b197f48101a14b464c7283c8ea1fb8ed87bc2 /tests | |
parent | a9dfd6144d8b7b389c8bf78adebda763428293a0 (diff) | |
parent | fb6a7d6bd166ab5fa0e4fabc532d75c1a95176ad (diff) | |
download | tool_apisiteadmins-5470099f403478dff3c396c2af98508ccc16ea72.tar.xz tool_apisiteadmins-5470099f403478dff3c396c2af98508ccc16ea72.zip |
Merge branch 'develop'
Diffstat (limited to 'tests')
-rw-r--r-- | tests/api_test.php | 132 | ||||
-rw-r--r-- | tests/external_test.php | 131 |
2 files changed, 263 insertions, 0 deletions
diff --git a/tests/api_test.php b/tests/api_test.php new file mode 100644 index 0000000..8155545 --- /dev/null +++ b/tests/api_test.php @@ -0,0 +1,132 @@ +<?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/>. + +/** + * Test 'tool_apisiteadmins' class. + * + * @copyright 2018 "Valentin Popov" <info@valentineus.link> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + * @package tool_apisiteadmins + */ + +defined('MOODLE_INTERNAL') || die(); + +global $CFG; + +require_once(__DIR__ . "/../lib.php"); + +/** + * Test 'tool_apisiteadmins' class. + * + * @category phpunit + * @group tool_apisiteadmins + * @copyright 2018 "Valentin Popov" <info@valentineus.link> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + * @package tool_apisiteadmins + */ +class tool_apisiteadmins_api_testcase extends advanced_testcase { + public function test_adding_and_deleting_administrator() { + $this->resetAfterTest(true); + + $user = $this->getDataGenerator()->create_user(); + + /* Adds a user to the list */ + tool_apisiteadmins::add_user($user->id); + $this->assertArrayHasKey($user->id, get_admins()); + $this->assertCount(2, get_admins()); + + /* Re-adds the user to the list */ + tool_apisiteadmins::add_user($user->id); + $this->assertArrayHasKey($user->id, get_admins()); + $this->assertCount(2, get_admins()); + + /* Removes the user from the list */ + tool_apisiteadmins::remove_user($user->id); + $this->assertArrayNotHasKey($user->id, get_admins()); + $this->assertCount(1, get_admins()); + + /* Removes a remote user from the list */ + tool_apisiteadmins::remove_user($user->id); + $this->assertArrayNotHasKey($user->id, get_admins()); + $this->assertCount(1, get_admins()); + } + + /** + * @depends test_adding_and_deleting_administrator + */ + public function test_changing_main_administrator() { + $this->resetAfterTest(true); + + $user1 = $this->getDataGenerator()->create_user(); + $user2 = $this->getDataGenerator()->create_user(); + + /* Adds users to the list */ + tool_apisiteadmins::add_user($user1->id); + tool_apisiteadmins::add_user($user2->id); + $this->assertArrayHasKey($user1->id, get_admins()); + $this->assertArrayHasKey($user2->id, get_admins()); + $this->assertCount(3, get_admins()); + + /* Sets first user main */ + tool_apisiteadmins::set_main($user1->id); + $this->assertEquals($user1, get_admin()); + + /* Sets second user main */ + tool_apisiteadmins::set_main($user2->id); + $this->assertEquals($user2, get_admin()); + } + + /** + * @depends test_adding_and_deleting_administrator + */ + public function test_deleting_all_administrators() { + $this->resetAfterTest(true); + + $this->assertCount(1, get_admins()); + $user = get_admin(); + + /* Removes a single administrator */ + tool_apisiteadmins::remove_user($user->id); + $this->assertCount(1, get_admins()); + $this->assertEquals($user, get_admin()); + } + + /** + * @depends test_adding_and_deleting_administrator + */ + public function test_exception_adding_check() { + $this->expectException(moodle_exception::class); + $this->resetAfterTest(true); + + $userid = mt_rand(99, 999); + + /* Adds a non-existent user */ + tool_apisiteadmins::add_user($userid); + } + + /** + * @depends test_adding_and_deleting_administrator + */ + public function test_exception_removal_check() { + $this->expectException(moodle_exception::class); + $this->resetAfterTest(true); + + $userid = mt_rand(99, 999); + + /* Removes a non-existent user */ + tool_apisiteadmins::remove_user($userid); + } +} diff --git a/tests/external_test.php b/tests/external_test.php new file mode 100644 index 0000000..83c58c5 --- /dev/null +++ b/tests/external_test.php @@ -0,0 +1,131 @@ +<?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/>. + +/** + * Test 'tool_apisiteadmins_external' class. + * + * @copyright 2018 "Valentin Popov" <info@valentineus.link> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + * @package tool_apisiteadmins + */ + +defined('MOODLE_INTERNAL') || die(); + +global $CFG; + +require_once(__DIR__ . "/../externallib.php"); + +/** + * Test tool_apisiteadmins_external class. + * + * @category phpunit + * @group tool_apisiteadmins + * @copyright 2018 "Valentin Popov" <info@valentineus.link> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + * @package tool_apisiteadmins + */ +class tool_apisiteadmins_external_testcase extends advanced_testcase { + public function test_adding_and_deleting_administrator() { + $this->resetAfterTest(true); + $this->setAdminUser(); + + $user = $this->getDataGenerator()->create_user(); + + /* Adds a user to the list */ + $result = tool_apisiteadmins_external::add_to_administrators($user->id); + $result = external_api::clean_returnvalue(tool_apisiteadmins_external::add_to_administrators_returns(), $result); + $this->assertArrayHasKey($user->id, get_admins()); + $this->assertCount(2, get_admins()); + $this->assertTrue($result); + + /* Removes the user from the list */ + $result = tool_apisiteadmins_external::remove_from_administrators($user->id); + $result = external_api::clean_returnvalue(tool_apisiteadmins_external::remove_from_administrators_returns(), $result); + $this->assertArrayNotHasKey($user->id, get_admins()); + $this->assertCount(1, get_admins()); + $this->assertTrue($result); + } + + /** + * @depends test_adding_and_deleting_administrator + */ + public function test_changing_main_administrator() { + $this->resetAfterTest(true); + $this->setAdminUser(); + + $user1 = $this->getDataGenerator()->create_user(); + $user2 = $this->getDataGenerator()->create_user(); + + /* Adds users to the list */ + tool_apisiteadmins_external::add_to_administrators($user1->id); + tool_apisiteadmins_external::add_to_administrators($user2->id); + $this->assertArrayHasKey($user1->id, get_admins()); + $this->assertArrayHasKey($user2->id, get_admins()); + $this->assertCount(3, get_admins()); + + /* Changes the primary administrator */ + $result = tool_apisiteadmins_external::change_main_administrator($user1->id); + $result = external_api::clean_returnvalue(tool_apisiteadmins_external::change_main_administrator_returns(), $result); + $this->assertEquals($user1, get_admin()); + $this->assertTrue($result); + + /* Changes the primary administrator */ + $result = tool_apisiteadmins_external::change_main_administrator($user2->id); + $result = external_api::clean_returnvalue(tool_apisiteadmins_external::change_main_administrator_returns(), $result); + $this->assertEquals($user2, get_admin()); + $this->assertTrue($result); + } + + /** + * @depends test_adding_and_deleting_administrator + * @depends test_changing_main_administrator + */ + public function test_getting_list_administrators() { + $this->resetAfterTest(true); + $this->setAdminUser(); + + $user1 = $this->getDataGenerator()->create_user(); + $user2 = $this->getDataGenerator()->create_user(); + + /* Adds users to the list */ + tool_apisiteadmins_external::add_to_administrators($user1->id); + tool_apisiteadmins_external::add_to_administrators($user2->id); + $this->assertArrayHasKey($user1->id, get_admins()); + $this->assertArrayHasKey($user2->id, get_admins()); + $this->assertCount(3, get_admins()); + + /* Gets the list of administrators */ + $result = tool_apisiteadmins_external::get_list_administrators(); + $result = external_api::clean_returnvalue(tool_apisiteadmins_external::get_list_administrators_returns(), $result); + $this->assertArraySubset(array("id" => $user1->id), $result[1]); + $this->assertArraySubset(array("id" => $user2->id), $result[2]); + $this->assertCount(3, $result); + + /* Changes the primary administrator */ + tool_apisiteadmins_external::change_main_administrator($user1->id); + $result = tool_apisiteadmins_external::get_main_administrator(); + $result = external_api::clean_returnvalue(tool_apisiteadmins_external::get_main_administrator_returns(), $result); + $this->assertArraySubset(array("id" => $user1->id), $result[0]); + $this->assertCount(1, $result); + + /* Changes the primary administrator */ + tool_apisiteadmins_external::change_main_administrator($user2->id); + $result = tool_apisiteadmins_external::get_main_administrator(); + $result = external_api::clean_returnvalue(tool_apisiteadmins_external::get_main_administrator_returns(), $result); + $this->assertArraySubset(array("id" => $user2->id), $result[0]); + $this->assertCount(1, $result); + } +} |