aboutsummaryrefslogtreecommitdiff
path: root/tests/lib_test.php
diff options
context:
space:
mode:
authorValentin Popov <info@valentineus.link>2019-05-05 23:35:18 +0300
committerValentin Popov <info@valentineus.link>2019-05-06 03:27:01 +0300
commit4806fad728116cbd6b440eb285fcbcc867a62b84 (patch)
tree0b36003ecb7885d97fab5cab1d268890c52f8a79 /tests/lib_test.php
parent654eade42b8a088a08f2de4111aa2abfda6c7f45 (diff)
downloadlocal_webhooks-4806fad728116cbd6b440eb285fcbcc867a62b84.tar.xz
local_webhooks-4806fad728116cbd6b440eb285fcbcc867a62b84.zip
Did a deep refactoring main class in the plugin
Signed-off-by: Valentin Popov <info@valentineus.link>
Diffstat (limited to 'tests/lib_test.php')
-rw-r--r--tests/lib_test.php341
1 files changed, 0 insertions, 341 deletions
diff --git a/tests/lib_test.php b/tests/lib_test.php
deleted file mode 100644
index b813658..0000000
--- a/tests/lib_test.php
+++ /dev/null
@@ -1,341 +0,0 @@
-<?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/>.
-
-defined('MOODLE_INTERNAL') || die();
-
-global $CFG;
-
-require_once($CFG->dirroot . '/local/webhooks/lib.php');
-
-use local_webhooks\local\local_webhooks_record as stdRecord;
-
-/**
- * Class local_webhooks_lib_testcase
- *
- * @copyright 2019 'Valentin Popov' <info@valentineus.link>
- * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
- */
-final class local_webhooks_lib_testcase extends advanced_testcase {
- /**
- * Testing creation of the service.
- *
- * @group local_webhooks
- *
- * @throws \dml_exception
- * @throws \moodle_exception
- */
- public function test_adding() {
- global $DB;
-
- $this->resetAfterTest();
-
- $record = new stdRecord();
- $record->header = 'application/json';
- $record->name = 'Example name';
- $record->point = 'http://example.org/';
- $record->status = true;
- $record->token = '967b2286-0874-4938-b088-efdbcf8a79bc';
- $record->events = [
- '\core\event\course_created',
- '\core\event\course_deleted',
- '\core\event\course_updated',
- '\core\event\course_viewed',
- ];
-
- $record->id = local_webhooks_api::create_service($record);
-
- $events = $DB->get_records(LW_TABLE_EVENTS);
- $services = $DB->get_records(LW_TABLE_SERVICES);
-
- self::assertCount(1, $services);
- $service = array_shift($services);
-
- self::assertEquals($record->header, $service->header);
- self::assertEquals($record->id, $service->id);
- self::assertEquals($record->name, $service->name);
- self::assertEquals($record->point, $service->point);
- self::assertEquals($record->status, (bool) $service->status);
- self::assertEquals($record->token, $service->token);
-
- self::assertCount(count($record->events), $events);
- foreach ($events as $event) {
- self::assertContains($event->name, $record->events);
- self::assertEquals($record->id, $event->serviceid);
- }
- }
-
- /**
- * Test deletion of the service.
- *
- * @group local_webhooks
- *
- * @throws \dml_exception
- * @throws \moodle_exception
- */
- public function test_deleting() {
- global $DB;
-
- $this->resetAfterTest();
-
- $record = new stdRecord();
- $record->header = 'application/json';
- $record->name = 'Example name';
- $record->point = 'http://example.org/';
- $record->status = true;
- $record->token = '967b2286-0874-4938-b088-efdbcf8a79bc';
- $record->events = [
- '\core\event\course_created',
- '\core\event\course_deleted',
- '\core\event\course_updated',
- '\core\event\course_viewed',
- ];
-
- $record->id = local_webhooks_api::create_service($record);
- self::assertTrue(local_webhooks_api::delete_service($record->id));
- self::assertCount(0, $DB->get_records(LW_TABLE_EVENTS));
- self::assertCount(0, $DB->get_records(LW_TABLE_SERVICES));
- }
-
- /**
- * Testing get to a service.
- *
- * @throws \dml_exception
- * @throws \moodle_exception
- */
- public function test_get_service() {
- $this->resetAfterTest();
-
- $record = new stdRecord();
- $record->header = 'application/json';
- $record->name = 'Example name';
- $record->point = 'http://example.org/';
- $record->status = true;
- $record->token = '967b2286-0874-4938-b088-efdbcf8a79bc';
- $record->events = [
- '\core\event\course_created',
- '\core\event\course_deleted',
- '\core\event\course_updated',
- '\core\event\course_viewed',
- ];
-
- $record->id = local_webhooks_api::create_service($record);
- $service = local_webhooks_api::get_service($record->id);
-
- self::assertEquals($record->header, $service->header);
- self::assertEquals($record->id, $service->id);
- self::assertEquals($record->name, $service->name);
- self::assertEquals($record->point, $service->point);
- self::assertEquals($record->status, (bool) $service->status);
- self::assertEquals($record->token, $service->token);
-
- self::assertInternalType('array', $service->events);
- self::assertCount(count($record->events), $service->events);
- foreach ($service->events as $event) {
- self::assertContains($event, $record->events);
- }
- }
-
- /**
- * Testing get to the list services.
- *
- * @throws \dml_exception
- * @throws \moodle_exception
- */
- public function test_get_services() {
- $this->resetAfterTest();
-
- $record = new stdRecord();
- $record->header = 'application/json';
- $record->name = 'Example name';
- $record->point = 'http://example.org/';
- $record->status = true;
- $record->token = '967b2286-0874-4938-b088-efdbcf8a79bc';
- $record->events = [
- '\core\event\course_created',
- '\core\event\course_deleted',
- '\core\event\course_updated',
- '\core\event\course_viewed',
- ];
-
- $ids = [];
- $total = random_int(5, 20);
- for ($i = 0; $i < $total; $i++) {
- $ids[] = local_webhooks_api::create_service($record);
- }
-
- $services = local_webhooks_api::get_services();
- self::assertCount(count($ids), $services);
-
- foreach ($services as $service) {
- self::assertContains($service->id, $ids);
- self::assertEquals($record->header, $service->header);
- self::assertEquals($record->name, $service->name);
- self::assertEquals($record->point, $service->point);
- self::assertEquals($record->status, $service->status);
- self::assertEquals($record->token, $service->token);
-
- self::assertInternalType('array', $service->events);
- self::assertCount(count($record->events), $service->events);
- foreach ($service->events as $event) {
- self::assertContains($event, $record->events);
- }
- }
- }
-
- /**
- * Testing get to the list services by event name.
- *
- * @throws \dml_exception
- * @throws \moodle_exception
- */
- public function test_get_services_by_event() {
- $this->resetAfterTest();
-
- $record = new stdRecord();
- $record->header = 'application/json';
- $record->name = 'Example name';
- $record->point = 'http://example.org/';
- $record->status = true;
- $record->token = '967b2286-0874-4938-b088-efdbcf8a79bc';
- $record->events = [
- '\core\event\course_created',
- '\core\event\course_deleted',
- '\core\event\course_updated',
- '\core\event\course_viewed',
- ];
-
- $ids = [];
- $total = random_int(5, 20);
- for ($i = 0; $i < $total; $i++) {
- $ids[] = local_webhooks_api::create_service($record);
- }
-
- $eventname = $record->events[random_int(1, count($record->events) - 1)];
- $services = local_webhooks_api::get_services_by_event($eventname);
- self::assertCount(count($ids), $services);
-
- foreach ($services as $service) {
- self::assertContains($service->id, $ids);
- self::assertEquals($record->header, $service->header);
- self::assertEquals($record->name, $service->name);
- self::assertEquals($record->point, $service->point);
- self::assertEquals($record->status, $service->status);
- self::assertEquals($record->token, $service->token);
-
- self::assertInternalType('array', $service->events);
- self::assertCount(count($record->events), $service->events);
- foreach ($service->events as $event) {
- self::assertContains($event, $record->events);
- }
- }
- }
-
- /**
- * Testing get to the list services with conditions.
- *
- * @throws \dml_exception
- * @throws \moodle_exception
- */
- public function test_get_services_with_conditions() {
- $this->resetAfterTest();
-
- $record = new stdRecord();
- $record->header = 'application/json';
- $record->status = true;
- $record->token = '967b2286-0874-4938-b088-efdbcf8a79bc';
- $record->events = [
- '\core\event\course_created',
- '\core\event\course_deleted',
- '\core\event\course_updated',
- '\core\event\course_viewed',
- ];
-
- $total = random_int(5, 20);
- for ($i = 0; $i < $total; $i++) {
- $record->name = 'Example name #' . $i;
- $record->point = 'http://example.org/test_' . $i;
- local_webhooks_api::create_service($record);
- }
-
- self::assertCount(1, local_webhooks_api::get_services([
- 'name' => 'Example name #' . random_int(1, $total),
- ]));
-
- $limit = random_int(1, $total);
- self::assertCount($limit, local_webhooks_api::get_services([], 1, $limit));
- }
-
- /**
- * Testing of the service update.
- *
- * @group local_webhooks
- *
- * @throws \dml_exception
- * @throws \moodle_exception
- */
- public function test_updating() {
- global $DB;
-
- $this->resetAfterTest();
-
- $record1 = new stdRecord();
- $record1->header = 'application/json';
- $record1->name = 'Example name';
- $record1->point = 'http://example.org/';
- $record1->status = true;
- $record1->token = '967b2286-0874-4938-b088-efdbcf8a79bc';
- $record1->events = [
- '\core\event\course_created',
- '\core\event\course_deleted',
- '\core\event\course_updated',
- '\core\event\course_viewed',
- ];
-
- $record2 = new stdRecord();
- $record2->header = 'application/x-www-form-urlencoded';
- $record2->name = 'New name';
- $record2->point = 'http://domain.local/example';
- $record2->status = false;
- $record2->token = 'add62250-2f03-49a9-97c4-6cd73a79e83b';
- $record2->events = [
- '\core\event\calendar_event_created',
- '\core\event\calendar_event_deleted',
- '\core\event\calendar_event_updated',
- ];
-
- $record2->id = local_webhooks_api::create_service($record1);
- self::assertTrue(local_webhooks_api::update_service($record2));
-
- $events = $DB->get_records(LW_TABLE_EVENTS);
- $services = $DB->get_records(LW_TABLE_SERVICES);
-
- self::assertCount(1, $services);
- $service = array_shift($services);
-
- self::assertEquals($record2->header, $service->header);
- self::assertEquals($record2->id, $service->id);
- self::assertEquals($record2->name, $service->name);
- self::assertEquals($record2->point, $service->point);
- self::assertEquals($record2->status, (bool) $service->status);
- self::assertEquals($record2->token, $service->token);
-
- self::assertCount(count($record2->events), $events);
- foreach ($events as $event) {
- self::assertContains($event->name, $record2->events);
- self::assertEquals($record2->id, $event->serviceid);
- }
- }
-} \ No newline at end of file