. namespace core; use zip_archive; defined('MOODLE_INTERNAL') || die(); global $CFG; require_once($CFG->libdir . '/filestorage/zip_archive.php'); /** * Unit tests for /lib/filestorage/zip_archive.php. * * @package core * @copyright 2020 Université Rennes 2 {@link https://www.univ-rennes2.fr} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class filestorage_zip_archive_test extends \advanced_testcase { /** * Test mangle_pathname() method. * * @dataProvider pathname_provider * * @param string $string Parameter sent to mangle_pathname method. * @param string $expected Expected return value. */ public function test_mangle_pathname($string, $expected) { $ziparchive = new zip_archive(); $method = new \ReflectionMethod('zip_archive', 'mangle_pathname'); $method->setAccessible(true); $result = $method->invoke($ziparchive, $string); $this->assertSame($expected, $result); } /** * Provide some tested pathnames and expected results. * * @return array Array of tested pathnames and expected results. */ public function pathname_provider() { return [ // Test a string. ['my file.pdf', 'my file.pdf'], // Test a string with MS separator. ['c:\temp\my file.pdf', 'c:/temp/my file.pdf'], // Test a string with 2 consecutive dots. ['my file..pdf', 'my file.pdf'], // Test a string with 3 consecutive dots. ['my file...pdf', 'my file.pdf'], // Test a string beginning with leading slash. ['/tmp/my file.pdf', 'tmp/my file.pdf'], // Test some path traversal attacks. ['../../../../../etc/passwd', 'etc/passwd'], ['../', ''], ['.../...//', ''], ['.', ''], ]; } }