Proyectos de Subversion Moodle

Rev

Autoría | Ultima modificación | Ver Log |

<?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/>.

declare(strict_types=1);

namespace core\plugininfo;

use advanced_testcase;

/**
 * Unit tests for the editor plugininfo class
 *
 * @package     core
 * @covers      \core\plugininfo\editor
 * @copyright   2023 Andrew Lyons <andrew@nicols.co.uk>
 * @license     http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class editor_test extends advanced_testcase {

    /**
     * Test that editor::get_enabled_plugins() returns the correct list of enabled plugins.
     */
    public function test_get_enabled_plugins(): void {
        $this->resetAfterTest();

        // All plugins are enabled by default.
        $plugins = editor::get_enabled_plugins();
        $this->assertArrayHasKey('tiny', $plugins);
        $this->assertArrayHasKey('textarea', $plugins);

        // Disable tiny.
        editor::enable_plugin('textarea', 0);

        $plugins = editor::get_enabled_plugins();
        $this->assertArrayHasKey('tiny', $plugins);
        $this->assertArrayNotHasKey('textarea', $plugins);
    }

    /**
     * Test that editor::enable_plugin set to disable all plugins will leave the textarea enabled.
     */
    public function test_enable_plugin_all(): void {
        $this->resetAfterTest();

        // All plugins are enabled by default.
        $plugins = editor::get_enabled_plugins();
        foreach ($plugins as $plugin) {
            editor::enable_plugin($plugin, 0);
        }

        $plugins = editor::get_enabled_plugins();
        $this->assertCount(1, $plugins);
        $this->assertArrayHasKey('textarea', $plugins);
    }

    /**
     * Ensure that plugintype_supports_ordering() returns true.
     */
    public function test_plugintype_supports_ordering(): void {
        $this->assertTrue(editor::plugintype_supports_ordering());
    }

    /**
     * Ensure that get_sorted_plugins() returns the correct list of plugins.
     *
     * @dataProvider get_sorted_plugins_provider
     * @param string $texteditors The $CFG->texteditors value to use as a base
     * @param bool $enabledonly
     * @param array $expected The expected order
     */
    public function test_get_sorted_plugins(
        string $texteditors,
        bool $enabledonly,
        array $expected,
    ): void {
        global $CFG;
        $this->resetAfterTest(true);

        $CFG->texteditors = $texteditors;
        $this->assertSame(
            $expected,
            array_keys(editor::get_sorted_plugins($enabledonly)),
        );
    }

    /**
     * Data provider for the get_sorted_plugins tests.
     *
     * @return array
     */
    public function get_sorted_plugins_provider(): array {
        $pluginmanager = \core_plugin_manager::instance();
        $allplugins = array_keys($pluginmanager->get_plugins_of_type('editor'));

        // Disabled editors are listed alphabetically at the end.
        $getorder = function (array $plugins) use ($allplugins) {
            return array_merge(
                $plugins,
                array_diff($allplugins, array_values($plugins)),
            );
        };
        return [
            [
                'texteditors' => 'textarea,tiny',
                'enabledonly' => true,
                'expected' => [
                    'textarea',
                    'tiny',
                ],
            ],
            [
                'texteditors' => 'tiny,textarea',
                'enabledonly' => true,
                'expected' => [
                    'tiny',
                    'textarea',
                ],
            ],
            [
                'texteditors' => 'tiny',
                'enabledonly' => true,
                'expected' => [
                    'tiny',
                ],
            ],
            'Phantom values are removed from the list' => [
                'texteditors' => 'fakeeditor',
                'enabledonly' => true,
                'expected' => [
                ],
            ],
            [
                'texteditors' => 'textarea,tiny',
                'enabledonly' => false,
                'expected' => $getorder([
                    'textarea',
                    'tiny',
                ]),
            ],
            [
                'texteditors' => 'tiny',
                'enabledonly' => false,
                'expected' => $getorder([
                    'tiny',
                ]),
            ],
        ];
    }

    /**
     * Ensure that change_plugin_order() changes the order of the plugins.
     *
     * @dataProvider change_plugin_order_provider
     * @param string $texteditors
     * @param string $pluginname
     * @param int $direction
     * @param array $neworder
     * @param string $newtexteditors
     */
    public function test_change_plugin_order(
        string $texteditors,
        string $pluginname,
        int $direction,
        array $neworder,
        string $newtexteditors,
    ): void {
        global $CFG;
        $this->resetAfterTest(true);

        $CFG->texteditors = $texteditors;
        editor::change_plugin_order($pluginname, $direction);

        $this->assertSame(
            $neworder,
            array_keys(editor::get_sorted_plugins()),
        );
        $this->assertSame($newtexteditors, $CFG->texteditors);
    }

    /**
     * Data provider fro the change_plugin_order() tests.
     *
     * @return array
     */
    public function change_plugin_order_provider(): array {
        $pluginmanager = \core_plugin_manager::instance();
        $allplugins = array_keys($pluginmanager->get_plugins_of_type('editor'));

        // Disabled editors are listed alphabetically at the end.
        $getorder = function (array $plugins) use ($allplugins) {
            return array_merge(
                $plugins,
                array_diff($allplugins, array_values($plugins)),
            );
        };
        return [
            [
                'texteditors' => 'textarea,tiny',
                'pluginname' => 'textarea',
                'direction' => base::MOVE_DOWN,
                'expected' => $getorder([
                    'tiny',
                    'textarea',
                ]),
                'newtexteditors' => 'tiny,textarea',
            ],
            [
                'texteditors' => 'textarea,tiny',
                'pluginname' => 'tiny',
                'direction' => base::MOVE_DOWN,
                // Tiny is already at the bottom of the enabled plugins.
                'expected' => $getorder([
                    'textarea',
                    'tiny',
                ]),
                'newtexteditors' => 'textarea,tiny',
            ],
            [
                'texteditors' => 'textarea,tiny',
                'pluginname' => 'atto',
                'direction' => base::MOVE_DOWN,
                // Atto is not enabled. No change expected.
                'expected' => $getorder([
                    'textarea',
                    'tiny',
                ]),
                'newtexteditors' => 'textarea,tiny',
            ],
            [
                'texteditors' => 'textarea,tiny',
                'pluginname' => 'tiny',
                'direction' => base::MOVE_UP,
                'expected' => $getorder([
                    'tiny',
                    'textarea',
                ]),
                'newtexteditors' => 'tiny,textarea',
            ],
            [
                'texteditors' => 'textarea,tiny',
                'pluginname' => 'tiny',
                'direction' => base::MOVE_UP,
                // Tiny is already at the top of the enabled plugins.
                'expected' => $getorder([
                    'tiny',
                    'textarea',
                ]),
                'newtexteditors' => 'tiny,textarea',
            ],
            [
                'texteditors' => 'textarea,tiny',
                'pluginname' => 'atto',
                'direction' => base::MOVE_UP,
                // Atto is not enabled. No change expected.
                'expected' => $getorder([
                    'textarea',
                    'tiny',
                ]),
                'newtexteditors' => 'textarea,tiny',
            ],
            [
                'texteditors' => 'textarea,tiny',
                'pluginname' => 'atto',
                'direction' => base::MOVE_UP,
                // Atto is not enabled. No change expected.
                'expected' => $getorder([
                    'textarea',
                    'tiny',
                ]),
                'newtexteditors' => 'textarea,tiny',
            ],
            [
                'texteditors' => 'textarea,tiny',
                'pluginname' => 'fakeeditor',
                'direction' => base::MOVE_UP,
                // The fakeeditor plugin does not exist. No change expected.
                'expected' => $getorder([
                    'textarea',
                    'tiny',
                ]),
                'newtexteditors' => 'textarea,tiny',
            ],
        ];
    }
}