mirrored from git://git.moodle.org/moodle.git
/
h5p_clean_orphaned_records_task_test.php
85 lines (73 loc) · 3.12 KB
/
h5p_clean_orphaned_records_task_test.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
<?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/>.
/**
* Class containing unit tests for the task to clean orphaned h5p records.
*
* @package core
* @copyright 2021 Ilya Tregubov <ilya@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*
*/
class h5p_clean_orphaned_records_task_test extends advanced_testcase {
/**
* Test task execution
*
* return void
*/
public function test_task_execution(): void {
global $CFG, $DB;
$this->resetAfterTest();
$this->setAdminUser();
// Create a course.
$course = $this->getDataGenerator()->create_course();
$params = [
'course' => $course->id,
'packagefilepath' => $CFG->dirroot.'/h5p/tests/fixtures/greeting-card-887.h5p',
'introformat' => 1
];
// Create h5pactivity.
$activity = $this->getDataGenerator()->create_module('h5pactivity', $params);
$activity->filename = 'greeting-card-887.h5p';
$context = context_module::instance($activity->cmid);
// Create a fake deploy H5P file.
$generator = $this->getDataGenerator()->get_plugin_generator('core_h5p');
$generator->create_export_file($activity->filename, $context->id,
'mod_h5pactivity', 'package');
// Delete activity.
course_delete_module($activity->cmid);
$orphanedh5psql = "SELECT h5p.id, h5p.pathnamehash
FROM {h5p} h5p
LEFT JOIN {files} f ON f.pathnamehash = h5p.pathnamehash
WHERE f.pathnamehash IS NULL";
$orphanedh5p = $DB->get_records_sql($orphanedh5psql);
$this->assertEquals(1, count($orphanedh5p));
$h5pid = end($orphanedh5p)->id;
$orphanedfilessql = "SELECT id
FROM {files}
WHERE itemid = :h5pid
AND filearea = 'content'
AND component = 'core_h5p'";
$orphanedfiles = $DB->get_records_sql($orphanedfilessql, ['h5pid' => $h5pid]);
$this->assertEquals(3, count($orphanedfiles));
// Execute task.
$task = new \core\task\h5p_clean_orphaned_records_task();
$task->execute();
$orphanedh5p = $DB->get_record_sql($orphanedh5psql);
$this->assertFalse($orphanedh5p);
$orphanedfiles = $DB->get_record_sql($orphanedfilessql, ['h5pid' => $h5pid]);
$this->assertFalse($orphanedfiles);
}
}