Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 4.1.x will end 13 November 2023 (12 months).
  • Bug fixes for security issues in 4.1.x will end 10 November 2025 (36 months).
  • PHP version: minimum PHP 7.4.0 Note: minimum PHP version has increased since Moodle 4.0. PHP 8.0.x is supported too.
<?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/>.

< /** < * Unit tests for the mod_quiz_display_options class. < * < * @package mod_scorm < * @category phpunit < * @copyright 2013 Dan Marsden < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later < */ <
> namespace mod_scorm;
defined('MOODLE_INTERNAL') || die(); global $CFG; require_once($CFG->dirroot . '/mod/scorm/locallib.php');
<
/** * Unit tests for {@link mod_scorm}. *
> * @package mod_scorm * @copyright 2013 Dan Marsden > * @category test
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */
< class mod_scorm_validatepackage_testcase extends advanced_testcase {
> class validatepackage_test extends \advanced_testcase {
/** * Convenience to take a fixture test file and create a stored_file. * * @param string $filepath * @return stored_file */ protected function create_stored_file_from_path($filepath) {
< $syscontext = context_system::instance();
> $syscontext = \context_system::instance();
$filerecord = array( 'contextid' => $syscontext->id, 'component' => 'mod_scorm', 'filearea' => 'unittest', 'itemid' => 0, 'filepath' => '/', 'filename' => basename($filepath) ); $fs = get_file_storage(); return $fs->create_file_from_pathname($filerecord, $filepath); } public function test_validate_package() { global $CFG; $this->resetAfterTest(true); $filename = "validscorm.zip";
< $file = $this->create_stored_file_from_path($CFG->dirroot.'/mod/scorm/tests/packages/'.$filename, file_archive::OPEN);
> $file = $this->create_stored_file_from_path($CFG->dirroot.'/mod/scorm/tests/packages/'.$filename, \file_archive::OPEN);
$errors = scorm_validate_package($file); $this->assertEmpty($errors); $filename = "validaicc.zip";
< $file = $this->create_stored_file_from_path($CFG->dirroot.'/mod/scorm/tests/packages/'.$filename, file_archive::OPEN);
> $file = $this->create_stored_file_from_path($CFG->dirroot.'/mod/scorm/tests/packages/'.$filename, \file_archive::OPEN);
$errors = scorm_validate_package($file); $this->assertEmpty($errors); $filename = "invalid.zip";
< $file = $this->create_stored_file_from_path($CFG->dirroot.'/mod/scorm/tests/packages/'.$filename, file_archive::OPEN);
> $file = $this->create_stored_file_from_path($CFG->dirroot.'/mod/scorm/tests/packages/'.$filename, \file_archive::OPEN);
$errors = scorm_validate_package($file); $this->assertArrayHasKey('packagefile', $errors); if (isset($errors['packagefile'])) { $this->assertEquals(get_string('nomanifest', 'scorm'), $errors['packagefile']); } $filename = "badscorm.zip";
< $file = $this->create_stored_file_from_path($CFG->dirroot.'/mod/scorm/tests/packages/'.$filename, file_archive::OPEN);
> $file = $this->create_stored_file_from_path($CFG->dirroot.'/mod/scorm/tests/packages/'.$filename, \file_archive::OPEN);
$errors = scorm_validate_package($file); $this->assertArrayHasKey('packagefile', $errors); if (isset($errors['packagefile'])) { $this->assertEquals(get_string('badimsmanifestlocation', 'scorm'), $errors['packagefile']); } } }