aboutsummaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorValentin Popov <info@valentineus.link>2019-05-06 04:45:35 +0300
committerValentin Popov <info@valentineus.link>2019-05-06 04:47:03 +0300
commiteb4b9b69f862df8ba23cafc8cd5e4a887baa02f0 (patch)
treee112a43f17173e02eada16b8d85ea4c4adc9cb4d /tests
parentbde135499d1fe0ca67a1f50fea79848cbdb370ea (diff)
downloadlocal_webhooks-eb4b9b69f862df8ba23cafc8cd5e4a887baa02f0.tar.xz
local_webhooks-eb4b9b69f862df8ba23cafc8cd5e4a887baa02f0.zip
Added worked a class observer
Signed-off-by: Valentin Popov <info@valentineus.link>
Diffstat (limited to 'tests')
-rw-r--r--tests/task_test.php89
1 files changed, 88 insertions, 1 deletions
diff --git a/tests/task_test.php b/tests/task_test.php
index dc9d42f..1fe9bc2 100644
--- a/tests/task_test.php
+++ b/tests/task_test.php
@@ -64,7 +64,7 @@ final class local_webhooks_task_testcase extends advanced_testcase {
$record->status = false;
$record->token = '967b2286-0874-4938-b088-efdbcf8a79bc';
- $record->id = api::create_service($record);
+ api::create_service($record);
$task = new notify();
$task->set_custom_data(['eventname' => '\core\event\course_viewed']);
@@ -108,4 +108,91 @@ final class local_webhooks_task_testcase extends advanced_testcase {
self::assertEquals($record->id, $element['service']->id);
self::assertEquals($record->token, $element['data']['token']);
}
+
+ /**
+ * Testing count creating tasks.
+ *
+ * @throws \coding_exception
+ * @throws \dml_exception
+ */
+ public function test_observer_multiple() {
+ $generator = self::getDataGenerator();
+ curl::mock_response('{}');
+ $this->resetAfterTest();
+
+ $record = new record();
+ $record->events = ['\core\event\course_created'];
+ $record->header = 'application/json';
+ $record->name = 'Example name';
+ $record->point = 'http://example.org/';
+ $record->status = true;
+ $record->token = '967b2286-0874-4938-b088-efdbcf8a79bc';
+
+ api::create_service($record);
+
+ $total = random_int(5, 20);
+ for ($i = 0; $i < $total; $i++) {
+ $generator->create_course();
+ }
+
+ $debug = [];
+ foreach (manager::get_adhoc_tasks(notify::class) as $event) {
+ if (!is_object($event)) {
+ continue;
+ }
+
+ /** @var \local_webhooks\task\notify $event */
+ $event->execute();
+
+ if (isset($event->debug) && is_array($event->debug)) {
+ $debug[] = array_merge(...$event->debug);
+ }
+ }
+
+ self::assertCount($total, $debug);
+ }
+
+ /**
+ * Testing structure a creating task.
+ *
+ * @throws \coding_exception
+ * @throws \dml_exception
+ */
+ public function test_observer_single() {
+ $generator = self::getDataGenerator();
+ curl::mock_response('{}');
+ $this->resetAfterTest();
+
+ $record = new record();
+ $record->events = ['\core\event\course_created'];
+ $record->header = 'application/json';
+ $record->name = 'Example name';
+ $record->point = 'http://example.org/';
+ $record->status = true;
+ $record->token = '967b2286-0874-4938-b088-efdbcf8a79bc';
+
+ api::create_service($record);
+
+ $course = $generator->create_course();
+
+ $debug = [];
+ foreach (manager::get_adhoc_tasks(notify::class) as $event) {
+ if (!is_object($event)) {
+ continue;
+ }
+
+ /** @var \local_webhooks\task\notify $event */
+ $event->execute();
+
+ if (isset($event->debug) && is_array($event->debug)) {
+ $debug[] = array_merge(...$event->debug);
+ }
+ }
+
+ self::assertCount(1, $debug);
+ $element = array_shift($debug);
+
+ self::assertInternalType('array', $element['data']);
+ self::assertEquals($course->id, $element['data']['courseid']);
+ }
} \ No newline at end of file