Proyectos de Subversion Moodle

Rev

Rev 11 | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 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
 * Events tests.
19
 *
20
 * @package mod_data
21
 * @category test
22
 * @copyright 2014 Mark Nelson <markn@moodle.com>
23
 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
24
 */
25
 
26
namespace mod_data\event;
27
 
28
use mod_data\local\importer\preset_existing_importer;
29
use mod_data\manager;
30
use mod_data\preset;
31
 
1441 ariadna 32
final class events_test extends \advanced_testcase {
1 efrain 33
 
34
    /**
35
     * Test set up.
36
     *
37
     * This is executed before running any test in this file.
38
     */
39
    public function setUp(): void {
1441 ariadna 40
        parent::setUp();
1 efrain 41
        $this->resetAfterTest();
42
    }
43
 
44
    /**
45
     * Test the field created event.
46
     */
11 efrain 47
    public function test_field_created(): void {
1 efrain 48
        $this->setAdminUser();
49
 
50
        // Create a course we are going to add a data module to.
51
        $course = $this->getDataGenerator()->create_course();
52
 
53
        // The generator used to create a data module.
54
        $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
55
 
56
        // Create a data module.
57
        $data = $generator->create_instance(array('course' => $course->id));
58
 
59
        // Now we want to create a field.
60
        $field = data_get_field_new('text', $data);
61
        $fielddata = new \stdClass();
62
        $fielddata->name = 'Test';
63
        $fielddata->description = 'Test description';
64
        $field->define_field($fielddata);
65
 
66
        // Trigger and capture the event for creating a field.
67
        $sink = $this->redirectEvents();
68
        $field->insert_field();
69
        $events = $sink->get_events();
70
        $event = reset($events);
71
 
72
        // Check that the event data is valid.
73
        $this->assertInstanceOf('\mod_data\event\field_created', $event);
74
        $this->assertEquals(\context_module::instance($data->cmid), $event->get_context());
75
        $url = new \moodle_url('/mod/data/field.php', array('d' => $data->id));
76
        $this->assertEquals($url, $event->get_url());
77
    }
78
 
79
    /**
80
     * Test the field updated event.
81
     */
11 efrain 82
    public function test_field_updated(): void {
1 efrain 83
        $this->setAdminUser();
84
 
85
        // Create a course we are going to add a data module to.
86
        $course = $this->getDataGenerator()->create_course();
87
 
88
        // The generator used to create a data module.
89
        $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
90
 
91
        // Create a data module.
92
        $data = $generator->create_instance(array('course' => $course->id));
93
 
94
        // Now we want to create a field.
95
        $field = data_get_field_new('text', $data);
96
        $fielddata = new \stdClass();
97
        $fielddata->name = 'Test';
98
        $fielddata->description = 'Test description';
99
        $field->define_field($fielddata);
100
        $field->insert_field();
101
 
102
        // Trigger and capture the event for updating the field.
103
        $sink = $this->redirectEvents();
104
        $field->update_field();
105
        $events = $sink->get_events();
106
        $event = reset($events);
107
 
108
        // Check that the event data is valid.
109
        $this->assertInstanceOf('\mod_data\event\field_updated', $event);
110
        $this->assertEquals(\context_module::instance($data->cmid), $event->get_context());
111
        $url = new \moodle_url('/mod/data/field.php', array('d' => $data->id));
112
        $this->assertEquals($url, $event->get_url());
113
    }
114
 
115
    /**
116
     * Test the field deleted event.
117
     */
11 efrain 118
    public function test_field_deleted(): void {
1 efrain 119
        $this->setAdminUser();
120
 
121
        // Create a course we are going to add a data module to.
122
        $course = $this->getDataGenerator()->create_course();
123
 
124
        // The generator used to create a data module.
125
        $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
126
 
127
        // Create a data module.
128
        $data = $generator->create_instance(array('course' => $course->id));
129
 
130
        // Now we want to create a field.
131
        $field = data_get_field_new('text', $data);
132
        $fielddata = new \stdClass();
133
        $fielddata->name = 'Test';
134
        $fielddata->description = 'Test description';
135
        $field->define_field($fielddata);
136
        $field->insert_field();
137
 
138
        // Trigger and capture the event for deleting the field.
139
        $sink = $this->redirectEvents();
140
        $field->delete_field();
141
        $events = $sink->get_events();
142
        $event = reset($events);
143
 
144
        // Check that the event data is valid.
145
        $this->assertInstanceOf('\mod_data\event\field_deleted', $event);
146
        $this->assertEquals(\context_module::instance($data->cmid), $event->get_context());
147
        $url = new \moodle_url('/mod/data/field.php', array('d' => $data->id));
148
        $this->assertEquals($url, $event->get_url());
149
    }
150
 
151
    /**
152
     * Test the record created event.
153
     */
11 efrain 154
    public function test_record_created(): void {
1 efrain 155
        // Create a course we are going to add a data module to.
156
        $course = $this->getDataGenerator()->create_course();
157
 
158
        // The generator used to create a data module.
159
        $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
160
 
161
        // Create a data module.
162
        $data = $generator->create_instance(array('course' => $course->id));
163
 
164
        // Trigger and capture the event for creating the record.
165
        $sink = $this->redirectEvents();
166
        $recordid = data_add_record($data);
167
        $events = $sink->get_events();
168
        $event = reset($events);
169
 
170
        // Check that the event data is valid.
171
        $this->assertInstanceOf('\mod_data\event\record_created', $event);
172
        $this->assertEquals(\context_module::instance($data->cmid), $event->get_context());
173
        $url = new \moodle_url('/mod/data/view.php', array('d' => $data->id, 'rid' => $recordid));
174
        $this->assertEquals($url, $event->get_url());
175
    }
176
 
177
    /**
178
     * Test the record updated event.
179
     *
180
     * There is no external API for updating a record, so the unit test will simply create
181
     * and trigger the event and ensure the legacy log data is returned as expected.
182
     */
11 efrain 183
    public function test_record_updated(): void {
1 efrain 184
        // Create a course we are going to add a data module to.
185
        $course = $this->getDataGenerator()->create_course();
186
 
187
        // The generator used to create a data module.
188
        $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
189
 
190
        // Create a data module.
191
        $data = $generator->create_instance(array('course' => $course->id));
192
 
193
        // Trigger an event for updating this record.
194
        $event = \mod_data\event\record_updated::create(array(
195
            'objectid' => 1,
196
            'context' => \context_module::instance($data->cmid),
197
            'courseid' => $course->id,
198
            'other' => array(
199
                'dataid' => $data->id
200
            )
201
        ));
202
 
203
        // Trigger and capture the event for updating the data record.
204
        $sink = $this->redirectEvents();
205
        $event->trigger();
206
        $events = $sink->get_events();
207
        $event = reset($events);
208
 
209
        // Check that the event data is valid.
210
        $this->assertInstanceOf('\mod_data\event\record_updated', $event);
211
        $this->assertEquals(\context_module::instance($data->cmid), $event->get_context());
212
        $url = new \moodle_url('/mod/data/view.php', array('d' => $data->id, 'rid' => $event->objectid));
213
        $this->assertEquals($url, $event->get_url());
214
    }
215
 
216
    /**
217
     * Test the record deleted event.
218
     */
11 efrain 219
    public function test_record_deleted(): void {
1 efrain 220
        global $DB;
221
 
222
        // Create a course we are going to add a data module to.
223
        $course = $this->getDataGenerator()->create_course();
224
 
225
        // The generator used to create a data module.
226
        $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
227
 
228
        // Create a data module.
229
        $data = $generator->create_instance(array('course' => $course->id));
230
 
231
        // Now we want to create a field.
232
        $field = data_get_field_new('text', $data);
233
        $fielddata = new \stdClass();
234
        $fielddata->name = 'Test';
235
        $fielddata->description = 'Test description';
236
        $field->define_field($fielddata);
237
        $field->insert_field();
238
 
239
        // Create data record.
240
        $datarecords = new \stdClass();
241
        $datarecords->userid = '2';
242
        $datarecords->dataid = $data->id;
243
        $datarecords->id = $DB->insert_record('data_records', $datarecords);
244
 
245
        // Create data content.
246
        $datacontent = new \stdClass();
247
        $datacontent->fieldid = $field->field->id;
248
        $datacontent->recordid = $datarecords->id;
249
        $datacontent->id = $DB->insert_record('data_content', $datacontent);
250
 
251
        // Trigger and capture the event for deleting the data record.
252
        $sink = $this->redirectEvents();
253
        data_delete_record($datarecords->id, $data, $course->id, $data->cmid);
254
        $events = $sink->get_events();
255
        $event = reset($events);
256
 
257
        // Check that the event data is valid.
258
        $this->assertInstanceOf('\mod_data\event\record_deleted', $event);
259
        $this->assertEquals(\context_module::instance($data->cmid), $event->get_context());
260
        $url = new \moodle_url('/mod/data/view.php', array('d' => $data->id));
261
        $this->assertEquals($url, $event->get_url());
262
    }
263
 
264
    /**
265
     * Test the template viewed event.
266
     *
267
     * There is no external API for viewing templates, so the unit test will simply create
268
     * and trigger the event and ensure the legacy log data is returned as expected.
269
     */
11 efrain 270
    public function test_template_viewed(): void {
1 efrain 271
        // Create a course we are going to add a data module to.
272
        $course = $this->getDataGenerator()->create_course();
273
 
274
        // The generator used to create a data module.
275
        $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
276
 
277
        // Create a data module.
278
        $data = $generator->create_instance(array('course' => $course->id));
279
 
280
        // Trigger an event for updating this record.
281
        $event = \mod_data\event\template_viewed::create(array(
282
            'context' => \context_module::instance($data->cmid),
283
            'courseid' => $course->id,
284
            'other' => array(
285
                'dataid' => $data->id
286
            )
287
        ));
288
 
289
        // Trigger and capture the event for updating the data record.
290
        $sink = $this->redirectEvents();
291
        $event->trigger();
292
        $events = $sink->get_events();
293
        $event = reset($events);
294
 
295
        // Check that the event data is valid.
296
        $this->assertInstanceOf('\mod_data\event\template_viewed', $event);
297
        $this->assertEquals(\context_module::instance($data->cmid), $event->get_context());
298
        $url = new \moodle_url('/mod/data/templates.php', array('d' => $data->id));
299
        $this->assertEquals($url, $event->get_url());
300
    }
301
 
302
    /**
303
     * Test the template updated event.
304
     *
305
     * There is no external API for updating a template, so the unit test will simply create
306
     * and trigger the event and ensure the legacy log data is returned as expected.
307
     */
11 efrain 308
    public function test_template_updated(): void {
1 efrain 309
        // Create a course we are going to add a data module to.
310
        $course = $this->getDataGenerator()->create_course();
311
 
312
        // The generator used to create a data module.
313
        $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
314
 
315
        // Create a data module.
316
        $data = $generator->create_instance(array('course' => $course->id));
317
 
318
        // Trigger an event for updating this record.
319
        $event = \mod_data\event\template_updated::create(array(
320
            'context' => \context_module::instance($data->cmid),
321
            'courseid' => $course->id,
322
            'other' => array(
323
                'dataid' => $data->id,
324
            )
325
        ));
326
 
327
        // Trigger and capture the event for updating the data record.
328
        $sink = $this->redirectEvents();
329
        $event->trigger();
330
        $events = $sink->get_events();
331
        $event = reset($events);
332
 
333
        // Check that the event data is valid.
334
        $this->assertInstanceOf('\mod_data\event\template_updated', $event);
335
        $this->assertEquals(\context_module::instance($data->cmid), $event->get_context());
336
        $url = new \moodle_url('/mod/data/templates.php', array('d' => $data->id));
337
        $this->assertEquals($url, $event->get_url());
338
    }
339
 
340
    /**
341
     * Data provider for build providers for test_needs_mapping and test_set_affected_fields.
342
     *
343
     * @return array[]
344
     */
1441 ariadna 345
    public static function preset_importer_provider(): array {
1 efrain 346
        // Image gallery preset is: ['title' => 'text', 'description' => 'textarea', 'image' => 'picture'];
347
 
348
        $titlefield = new \stdClass();
349
        $titlefield->name = 'title';
350
        $titlefield->type = 'text';
351
 
352
        $descfield = new \stdClass();
353
        $descfield->name = 'description';
354
        $descfield->type = 'textarea';
355
 
356
        $imagefield = new \stdClass();
357
        $imagefield->name = 'image';
358
        $imagefield->type = 'picture';
359
 
360
        $difffield = new \stdClass();
361
        $difffield->name = 'title';
362
        $difffield->type = 'textarea';
363
 
364
        $newfield = new \stdClass();
365
        $newfield->name = 'number';
366
        $newfield->type = 'number';
367
 
368
        return [
369
            'Empty database / Importer with fields' => [
370
                'currentfields' => [],
371
                'newfields' => [$titlefield, $descfield, $imagefield],
372
                'expected' => ['field_created' => 3],
373
            ],
374
            'Database with fields / Empty importer' => [
375
                'currentfields' => [$titlefield, $descfield, $imagefield],
376
                'newfields' => [],
377
                'expected' => ['field_deleted' => 3],
378
            ],
379
            'Fields to create' => [
380
                'currentfields' => [$titlefield, $descfield],
381
                'newfields' => [$titlefield, $descfield, $imagefield],
382
                'expected' => ['field_updated' => 2, 'field_created' => 1],
383
            ],
384
            'Fields to remove' => [
385
                'currentfields' => [$titlefield, $descfield, $imagefield, $difffield],
386
                'newfields' => [$titlefield, $descfield, $imagefield],
387
                'expected' => ['field_updated' => 2, 'field_deleted' => 1],
388
            ],
389
            'Fields to update' => [
390
                'currentfields' => [$difffield, $descfield, $imagefield],
391
                'newfields' => [$titlefield, $descfield, $imagefield],
392
                'expected' => ['field_updated' => 1, 'field_created' => 1, 'field_deleted' => 1],
393
            ],
394
            'Fields to create, remove and update' => [
395
                'currentfields' => [$titlefield, $descfield, $imagefield, $difffield],
396
                'newfields' => [$titlefield, $descfield, $newfield],
397
                'expected' => ['field_updated' => 2, 'field_created' => 1, 'field_deleted' => 2],
398
            ],
399
        ];
400
    }
401
    /**
402
     * Test for needs_mapping method.
403
     *
404
     * @dataProvider preset_importer_provider
405
     *
406
     * @param array $currentfields Fields of the current activity.
407
     * @param array $newfields Fields to be imported.
408
     * @param array $expected Expected events.
409
     */
410
    public function test_importing_events(
411
        array $currentfields,
412
        array $newfields,
413
        array $expected
11 efrain 414
    ): void {
1 efrain 415
 
416
        global $USER;
417
 
418
        $this->resetAfterTest();
419
        $this->setAdminUser();
420
        $plugingenerator = $this->getDataGenerator()->get_plugin_generator('mod_data');
421
 
422
        // Create a course and a database activity.
423
        $course = $this->getDataGenerator()->create_course();
424
        $activity = $this->getDataGenerator()->create_module(manager::MODULE, ['course' => $course]);
425
        // Add current fields to the activity.
426
        foreach ($currentfields as $field) {
427
            $plugingenerator->create_field($field, $activity);
428
        }
429
        $manager = manager::create_from_instance($activity);
430
 
431
        $presetactivity = $this->getDataGenerator()->create_module(manager::MODULE, ['course' => $course]);
432
        // Add current fields to the activity.
433
        foreach ($newfields as $field) {
434
            $plugingenerator->create_field($field, $presetactivity);
435
        }
436
 
437
        $record = (object) [
438
            'name' => 'Testing preset name',
439
            'description' => 'Testing preset description',
440
        ];
441
        $saved = $plugingenerator->create_preset($presetactivity, $record);
442
        $savedimporter = new preset_existing_importer($manager, $USER->id . '/Testing preset name');
443
 
444
        // Trigger and capture the event for deleting the field.
445
        $sink = $this->redirectEvents();
446
        $savedimporter->import(false);
447
        $events = $sink->get_events();
448
 
449
        foreach ($expected as $triggeredevent => $count) {
450
            for ($i = 0; $i < $count; $i++) {
451
                $event = array_shift($events);
452
 
453
                // Check that the event data is valid.
454
                $this->assertInstanceOf('\mod_data\event\\'.$triggeredevent, $event);
455
                $this->assertEquals(\context_module::instance($activity->cmid), $event->get_context());
456
                $this->assertEventContextNotUsed($event);
457
                $url = new \moodle_url('/mod/data/field.php', ['d' => $activity->id]);
458
                $this->assertEquals($url, $event->get_url());
459
            }
460
        }
461
    }
462
}