Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 3.11.x will end 14 Nov 2022 (12 months plus 6 months extension).
  • Bug fixes for security issues in 3.11.x will end 13 Nov 2023 (18 months plus 12 months extension).
  • PHP version: minimum PHP 7.3.0 Note: minimum PHP version has increased since Moodle 3.10. PHP 7.4.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 filtered_userlist. < * < * @package tool_dataprivacy < * @copyright 2018 Andrew Nicols <andrew@nicols.co.uk> < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later < */
> namespace tool_dataprivacy;
/** * Unit tests for the filtered_userlist. * * @package tool_dataprivacy * @copyright 2018 Andrew Nicols <andrew@nicols.co.uk> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */
< class tool_dataprivacy_filtered_userlist_testcase extends advanced_testcase {
> class filtered_userlist_test extends \advanced_testcase {
/** * Test the apply_expired_contexts_filters function with arange of options. * * @dataProvider apply_expired_contexts_filters_provider * @param array $initial The set of userids in the initial filterlist. * @param array $expired The set of userids considered as expired. * @param array $unexpired The set of userids considered as unexpired. * @param array $expected The expected values. */ public function test_apply_expired_contexts_filters(array $initial, array $expired, array $unexpired, array $expected) { $userlist = $this->getMockBuilder(\tool_dataprivacy\filtered_userlist::class) ->disableOriginalConstructor()
< ->setMethods(null)
> ->onlyMethods([])
->getMock(); $rc = new \ReflectionClass(\tool_dataprivacy\filtered_userlist::class); $rcm = $rc->getMethod('set_userids'); $rcm->setAccessible(true); $rcm->invoke($userlist, $initial); $userlist->apply_expired_context_filters($expired, $unexpired); $filtered = $userlist->get_userids(); sort($expected); sort($filtered); $this->assertEquals($expected, $filtered); } /** * Data provider for the apply_expired_contexts_filters function. * * @return array */ public function apply_expired_contexts_filters_provider() : array { return [ // Entire list should be preserved. 'No overrides' => [ 'users' => [1, 2, 3, 4, 5], 'expired' => [], 'unexpired' => [], [1, 2, 3, 4, 5], ], // The list should be filtered to only keep the expired users. 'Expired only' => [ 'users' => [1, 2, 3, 4, 5], 'expired' => [2, 3, 4], 'unexpired' => [], 'expected' => [2, 3, 4], ], // The list should be filtered to remove any unexpired users. 'Unexpired only' => [ 'users' => [1, 2, 3, 4, 5], 'expired' => [], 'unexpired' => [1, 5], 'expected' => [2, 3, 4], ], // The list should be filtered to only keep expired users who are not on the unexpired list. 'Combination of expired and unexpired' => [ 'users' => [1, 2, 3, 4, 5], 'expired' => [1, 2, 3], 'unexpired' => [1, 5], 'expected' => [2, 3], ], ]; } }