Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 3.9.x will end* 10 May 2021 (12 months).
  • Bug fixes for security issues in 3.9.x will end* 8 May 2023 (36 months).
  • PHP version: minimum PHP 7.2.0 Note: minimum PHP version has increased since Moodle 3.8. PHP 7.3.x and 7.4.x are 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/>.

< /** < * Test for core_media_player_native. < * < * @package core < * @category test < * @copyright 2019 Ruslan Kabalin < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later < */
> namespace core; > > use media_test_native_plugin;
defined('MOODLE_INTERNAL') || die(); require_once(__DIR__ . '/fixtures/testable_core_media_player_native.php'); /** * Test for core_media_player_native. * * @package core * @category test * @covers \core_media_player_native * @copyright 2019 Ruslan Kabalin * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */
< class core_media_player_native_testcase extends advanced_testcase {
> class core_media_player_native_test extends \advanced_testcase {
/** * Pre-test setup. */
< public function setUp() {
> public function setUp(): void {
parent::setUp(); $this->resetAfterTest(); } /** * Test method get_supported_extensions */ public function test_get_supported_extensions() { global $CFG; require_once($CFG->libdir . '/filelib.php'); $nativeextensions = file_get_typegroup('extension', ['html_video', 'html_audio']); // Make sure that the list of extensions from the setting is exactly the same. $player = new media_test_native_plugin(); $this->assertEmpty(array_diff($player->get_supported_extensions(), $nativeextensions)); $this->assertEmpty(array_diff($nativeextensions, $player->get_supported_extensions())); } /** * Test method list_supported_urls */ public function test_list_supported_urls() { global $CFG; require_once($CFG->libdir . '/filelib.php'); $nativeextensions = file_get_typegroup('extension', ['html_video', 'html_audio']); // Create list of URLs for each extension. $urls = array_map(function($ext){
< return new moodle_url('http://example.org/video.' . $ext);
> return new \moodle_url('http://example.org/video.' . $ext);
}, $nativeextensions); // Make sure that the list of supported URLs is not filtering permitted extensions. $player = new media_test_native_plugin(); $this->assertCount(count($urls), $player->list_supported_urls($urls)); } /** * Test method get_attribute */ public function test_get_attribute() { $urls = [
< new moodle_url('http://example.org/some_filename.mp4'), < new moodle_url('http://example.org/some_filename_hires.mp4'),
> new \moodle_url('http://example.org/some_filename.mp4'), > new \moodle_url('http://example.org/some_filename_hires.mp4'),
]; $player = new media_test_native_plugin(); // We are using fixture embed method directly as content generator. $title = 'Some Filename Video'; $content = $player->embed($urls, $title, 0, 0, []);
< $this->assertRegExp('~title="' . $title . '"~', $content);
> $this->assertMatchesRegularExpression('~title="' . $title . '"~', $content);
$this->assertEquals($title, media_test_native_plugin::get_attribute($content, 'title')); } /** * Test methods add_attributes and remove_attributes */ public function test_add_remove_attributes() { $urls = [
< new moodle_url('http://example.org/some_filename.mp4'), < new moodle_url('http://example.org/some_filename_hires.mp4'),
> new \moodle_url('http://example.org/some_filename.mp4'), > new \moodle_url('http://example.org/some_filename_hires.mp4'),
]; $player = new media_test_native_plugin(); // We are using fixture embed method directly as content generator. $title = 'Some Filename Video'; $content = $player->embed($urls, $title, 0, 0, []); // Add attributes. $content = media_test_native_plugin::add_attributes($content, ['preload' => 'none', 'controls' => 'true']);
< $this->assertRegExp('~title="' . $title . '"~', $content); < $this->assertRegExp('~preload="none"~', $content); < $this->assertRegExp('~controls="true"~', $content);
> $this->assertMatchesRegularExpression('~title="' . $title . '"~', $content); > $this->assertMatchesRegularExpression('~preload="none"~', $content); > $this->assertMatchesRegularExpression('~controls="true"~', $content);
// Change existing attribute. $content = media_test_native_plugin::add_attributes($content, ['controls' => 'false']);
< $this->assertRegExp('~title="' . $title . '"~', $content); < $this->assertRegExp('~preload="none"~', $content); < $this->assertRegExp('~controls="false"~', $content);
> $this->assertMatchesRegularExpression('~title="' . $title . '"~', $content); > $this->assertMatchesRegularExpression('~preload="none"~', $content); > $this->assertMatchesRegularExpression('~controls="false"~', $content);
// Remove attributes. $content = media_test_native_plugin::remove_attributes($content, ['title']);
< $this->assertNotRegExp('~title="' . $title . '"~', $content); < $this->assertRegExp('~preload="none"~', $content); < $this->assertRegExp('~controls="false"~', $content);
> $this->assertDoesNotMatchRegularExpression('~title="' . $title . '"~', $content); > $this->assertMatchesRegularExpression('~preload="none"~', $content); > $this->assertMatchesRegularExpression('~controls="false"~', $content);
// Remove another one. $content = media_test_native_plugin::remove_attributes($content, ['preload']);
< $this->assertNotRegExp('~title="' . $title . '"~', $content); < $this->assertNotRegExp('~preload="none"~', $content); < $this->assertRegExp('~controls="false"~', $content);
> $this->assertDoesNotMatchRegularExpression('~title="' . $title . '"~', $content); > $this->assertDoesNotMatchRegularExpression('~preload="none"~', $content); > $this->assertMatchesRegularExpression('~controls="false"~', $content);
} /** * Test method replace_sources */ public function test_replace_sources() { $urls = [
< new moodle_url('http://example.org/some_filename.mp4'), < new moodle_url('http://example.org/some_filename_hires.mp4'),
> new \moodle_url('http://example.org/some_filename.mp4'), > new \moodle_url('http://example.org/some_filename_hires.mp4'),
]; $player = new media_test_native_plugin(); // We are using fixture embed method directly as content generator. $title = 'Some Filename Video'; $content = $player->embed($urls, $title, 0, 0, []); // Test sources present.
< $this->assertContains('<source src="http://example.org/some_filename.mp4" />', $content); < $this->assertContains('<source src="http://example.org/some_filename_hires.mp4" />', $content);
> $this->assertStringContainsString('<source src="http://example.org/some_filename.mp4" />', $content); > $this->assertStringContainsString('<source src="http://example.org/some_filename_hires.mp4" />', $content);
// Change sources. $newsource = '<source src="http://example.org/new_filename.mp4" />'; $content = media_test_native_plugin::replace_sources($content, $newsource);
< $this->assertContains($newsource, $content); < $this->assertNotContains('<source src="http://example.org/some_filename.mp4" />', $content); < $this->assertNotContains('<source src="http://example.org/some_filename_hires.mp4" />', $content);
> $this->assertStringContainsString($newsource, $content); > $this->assertStringNotContainsString('<source src="http://example.org/some_filename.mp4" />', $content); > $this->assertStringNotContainsString('<source src="http://example.org/some_filename_hires.mp4" />', $content);
} }