moodle/course/tests/course_image_cache_test.php
Eloy Lafuente (stronk7) 01148a0816
MDL-81522 phpunit: Add missing void return type to all tests
While this change is not 100% required now, it's good habit
and we are checking for it since Moodle 4.4.

All the changes in this commit have been applied automatically
using the moodle.PHPUnit.TestReturnType sniff and are, exclusively
adding the ": void" return types when missing.
2024-06-11 11:55:07 +02:00

172 lines
7.2 KiB
PHP

<?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/>.
namespace core_course;
use context_user;
use context_course;
use ReflectionMethod;
use cache_definition;
use core_course\cache\course_image;
/**
* Functional test for class course_image
*
* @package core
* @subpackage course
* @author Dmitrii Metelkin <dmitriim@catalyst-au.net>
* @copyright 2021 Catalyst IT
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class course_image_cache_test extends \advanced_testcase {
/**
* Initial setup.
*/
protected function setUp(): void {
global $CFG;
parent::setUp();
$this->resetAfterTest();
$this->setAdminUser();
// Allow multiple overview files.
$CFG->courseoverviewfileslimit = 3;
}
/**
* Helper method to create a draft area for current user and fills it with fake files
*
* @param array $files array of files that need to be added to filearea, filename => filecontents
* @return int draftid for the filearea
*/
protected function fill_draft_area(array $files): int {
global $USER;
$draftid = file_get_unused_draft_itemid();
foreach ($files as $filename => $filecontents) {
// Add actual file there.
$filerecord = [
'component' => 'user',
'filearea' => 'draft',
'contextid' => context_user::instance($USER->id)->id, 'itemid' => $draftid,
'filename' => $filename, 'filepath' => '/'
];
$fs = get_file_storage();
$fs->create_file_from_string($filerecord, $filecontents);
}
return $draftid;
}
/**
* A helper method to generate expected file URL.
*
* @param \stdClass $course Course object.
* @param string $filename File name.
* @return string
*/
protected function build_expected_course_image_url(\stdClass $course, string $filename): string {
$contextid = context_course::instance($course->id)->id;
return 'https://www.example.com/moodle/pluginfile.php/' . $contextid. '/course/overviewfiles/' . $filename;
}
/**
* Test exception if try to get an image for non existing course.
*/
public function test_getting_data_if_course_is_not_exist(): void {
$this->expectException('dml_missing_record_exception');
$this->expectExceptionMessageMatches("/Can't find data record in database table course./");
$this->assertFalse(\cache::make('core', 'course_image')->get(999));
}
/**
* Test get_image_url_from_overview_files when no summary files in the course.
*/
public function test_get_image_url_from_overview_files_return_null_if_no_summary_files_in_the_course(): void {
$method = new ReflectionMethod(course_image::class, 'get_image_url_from_overview_files');
$cache = course_image::get_instance_for_cache(new cache_definition());
// Create course without files.
$course = $this->getDataGenerator()->create_course();
$this->assertNull($method->invokeArgs($cache, [$course]));
}
/**
* Test get_image_url_from_overview_files when no summary images in the course.
*/
public function test_get_image_url_from_overview_files_returns_null_if_no_summary_images_in_the_course(): void {
$method = new ReflectionMethod(course_image::class, 'get_image_url_from_overview_files');
$cache = course_image::get_instance_for_cache(new cache_definition());
// Create course without image files.
$draftid2 = $this->fill_draft_area(['filename2.zip' => 'Test file contents2']);
$course2 = $this->getDataGenerator()->create_course(['overviewfiles_filemanager' => $draftid2]);
$this->assertNull($method->invokeArgs($cache, [$course2]));
}
/**
* Test get_image_url_from_overview_files when no summary images in the course.
*/
public function test_get_image_url_from_overview_files_returns_url_if_there_is_a_summary_image(): void {
$method = new ReflectionMethod(course_image::class, 'get_image_url_from_overview_files');
$cache = course_image::get_instance_for_cache(new cache_definition());
// Create course without one image.
$draftid1 = $this->fill_draft_area(['filename1.jpg' => file_get_contents(__DIR__ . '/fixtures/image.jpg')]);
$course1 = $this->getDataGenerator()->create_course(['overviewfiles_filemanager' => $draftid1]);
$expected = $this->build_expected_course_image_url($course1, 'filename1.jpg');
$this->assertEquals($expected, $method->invokeArgs($cache, [$course1]));
}
/**
* Test get_image_url_from_overview_files when several summary images in the course.
*/
public function test_get_image_url_from_overview_files_returns_url_of_the_first_image_if_there_are_many_summary_images(): void {
$method = new ReflectionMethod(course_image::class, 'get_image_url_from_overview_files');
$cache = course_image::get_instance_for_cache(new cache_definition());
// Create course with two image files.
$draftid1 = $this->fill_draft_area([
'filename1.jpg' => file_get_contents(__DIR__ . '/fixtures/image.jpg'),
'filename2.jpg' => file_get_contents(__DIR__ . '/fixtures/image.jpg'),
]);
$course1 = $this->getDataGenerator()->create_course(['overviewfiles_filemanager' => $draftid1]);
$expected = $this->build_expected_course_image_url($course1, 'filename1.jpg');
$this->assertEquals($expected, $method->invokeArgs($cache, [$course1]));
}
/**
* Test get_image_url_from_overview_files when several summary files in the course.
*/
public function test_get_image_url_from_overview_files_returns_url_of_the_first_image_if_there_are_many_summary_files(): void {
$method = new ReflectionMethod(course_image::class, 'get_image_url_from_overview_files');
$cache = course_image::get_instance_for_cache(new cache_definition());
// Create course with two image files and one zip file.
$draftid1 = $this->fill_draft_area([
'filename1.zip' => 'Test file contents2',
'filename2.jpg' => file_get_contents(__DIR__ . '/fixtures/image.jpg'),
'filename3.jpg' => file_get_contents(__DIR__ . '/fixtures/image.jpg'),
]);
$course1 = $this->getDataGenerator()->create_course(['overviewfiles_filemanager' => $draftid1]);
$expected = $this->build_expected_course_image_url($course1, 'filename2.jpg');
$this->assertEquals($expected, $method->invokeArgs($cache, [$course1]));
}
}