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

namespace tool_courserating\privacy;

use core_privacy\local\request\writer;
use core_privacy\local\request\approved_contextlist;
use tool_courserating\api;
use core_privacy\local\request\approved_userlist;
use tool_courserating\local\models\flag;
use tool_courserating\local\models\rating;

/**
 * Tests for privacy provider class
 *
 * @package     tool_courserating
 * @covers      \tool_courserating\privacy\provider
 * @copyright   2022 Marina Glancy <marina.glancy@gmail.com>
 * @license     https://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
final class provider_test extends \core_privacy\tests\provider_testcase {

    /**
     * Overriding setUp() function to always reset after tests.
     */
    public function setUp(): void {
        $this->resetAfterTest(true);
        set_config(\tool_courserating\constants::SETTING_RATINGMODE,
            \tool_courserating\constants::RATEBY_ANYTIME, 'tool_courserating');
    }

    /**
     * Test for provider::get_contexts_for_userid().
     */
    public function test_get_contexts_for_userid(): void {
        global $DB;

        $user = $this->getDataGenerator()->create_user();
        $course = $this->getDataGenerator()->create_course();
        $this->setUser($user);
        \tool_courserating\api::set_rating($course->id, (object)['rating' => 5]);

        $this->setAdminUser();

        $contextlist = provider::get_contexts_for_userid($user->id);
        $contexts = $contextlist->get_contexts();
        $this->assertCount(1, $contexts);

        $courseids = array_column($contexts, 'instanceid');
        $this->assertEqualsCanonicalizing([$course->id], $courseids);
    }

    /**
     * Test for provider::export_user_data().
     */
    public function test_export_user_data(): void {

        [$user, $course] = $this->setup_test_scenario_data();
        $coursectx = \context_course::instance($course->id);
        $this->setAdminUser();

        // Test the User's retrieved contextlist contains two contexts.
        $contextlist = provider::get_contexts_for_userid($user->id);
        $contexts = $contextlist->get_contexts();
        $this->assertCount(1, $contexts);

        // Add a system, course category and course context to the approved context list.
        $systemctx = \context_system::instance();
        $approvedcontextids = [
            $systemctx->id,
            $coursectx->id,
        ];

        // Retrieve the User's tool_cohortroles data.
        $approvedcontextlist = new approved_contextlist($user, 'tool_courserating', $approvedcontextids);
        provider::export_user_data($approvedcontextlist);

        // Test the tool_cohortroles data is exported at the system context level.
        $writer = writer::with_context($systemctx);
        $this->assertFalse($writer->has_any_data());
        // Test the tool_cohortroles data is not exported at the course context level.
        $writer = writer::with_context($coursectx);
        $this->assertTrue($writer->has_any_data());
        $this->assertNotEmpty($writer->get_data(['Course ratings', $course->shortname]));
    }

    /**
     * Set up scenario data
     *
     * @return array
     */
    protected function setup_test_scenario_data() {
        $user1 = $this->getDataGenerator()->create_user();
        $user2 = $this->getDataGenerator()->create_user();
        $course = $this->getDataGenerator()->create_course(['shortname' => 'c1']);
        $this->setUser($user2);
        $r = \tool_courserating\api::set_rating($course->id, (object)['rating' => 5]);
        $this->setUser($user1);
        \tool_courserating\api::set_rating($course->id, (object)['rating' => 4]);
        api::flag_review($r->get('id'));
        return [$user1, $course];
    }

    /**
     * Test for provider::delete_data_for_all_users_in_context().
     */
    public function test_delete_data_for_all_users_in_context(): void {
        global $DB;

        [$user, $course] = $this->setup_test_scenario_data();
        $coursectx = \context_course::instance($course->id);
        $this->setAdminUser();

        provider::delete_data_for_all_users_in_context($coursectx);
        $this->assertEmpty($DB->get_records(rating::TABLE));
        $this->assertEmpty($DB->get_records(flag::TABLE));
    }

    /**
     * Test for provider::delete_data_for_user().
     */
    public function test_delete_data_for_user(): void {
        global $DB;

        [$user, $course] = $this->setup_test_scenario_data();
        $coursectx = \context_course::instance($course->id);
        $this->setAdminUser();

        // Test the User's retrieved contextlist contains two contexts.
        $contextlist = provider::get_contexts_for_userid($user->id);
        $contexts = $contextlist->get_contexts();
        $this->assertCount(1, $contexts);

        $approvedcontextlist = new approved_contextlist($user, 'tool_courserating', [$coursectx->id]);
        provider::delete_data_for_user($approvedcontextlist);
    }

    /**
     * Test that only users within a course context are fetched.
     */
    public function test_get_users_in_context(): void {
        $component = 'tool_courserating';

        [$user, $course] = $this->setup_test_scenario_data();
        $coursectx = \context_course::instance($course->id);
        $this->setAdminUser();

        $userlist = new \core_privacy\local\request\userlist($coursectx, $component);
        provider::get_users_in_context($userlist);
        $this->assertCount(2, $userlist);
        $this->assertTrue(in_array($user->id, $userlist->get_userids()));
    }

    /**
     * Test that data for users in approved userlist is deleted.
     */
    public function test_delete_data_for_users(): void {
        $component = 'tool_courserating';

        [$user, $course] = $this->setup_test_scenario_data();
        $coursectx = \context_course::instance($course->id);
        $this->setAdminUser();

        $userlist1 = new \core_privacy\local\request\userlist($coursectx, $component);
        provider::get_users_in_context($userlist1);
        $this->assertCount(2, $userlist1);
        $this->assertTrue(in_array($user->id, $userlist1->get_userids()));
        $userids = $userlist1->get_userids();

        $approvedlist1 = new approved_userlist($coursectx, $component, $userids);
        provider::delete_data_for_users($approvedlist1);

        $userlist1 = new \core_privacy\local\request\userlist($coursectx, $component);
        provider::get_users_in_context($userlist1);
        $this->assertCount(0, $userlist1);
    }

}