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 core\router\parameters;

use core\exception\not_found_exception;
use core\router\schema\referenced_object;
use core\tests\router\route_testcase;
use GuzzleHttp\Psr7\ServerRequest;
use stdClass;

/**
 * Tests for the User Path parameter.
 *
 * @package    core
 * @copyright  Andrew Lyons <andrew@nicols.co.uk>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 * @covers     \core\router\parameters\path_user
 */
final class path_user_test extends route_testcase {
    public function test_current_user(): void {
        $this->resetAfterTest();

        $user = $this->getDataGenerator()->create_user();
        $this->setUser($user);
        $context = \core\context\user::instance($user->id);

        $param = new path_user();
        $newrequest = $param->add_attributes_for_parameter_value(
            new ServerRequest('GET', '/user'),
            'current',
        );

        $this->assertInstanceOf(stdClass::class, $newrequest->getAttribute('user'));
        $this->assertInstanceOf(\core\context\user::class, $newrequest->getAttribute('usercontext'));

        $this->assertEquals($user->id, $newrequest->getAttribute('user')->id);
        $this->assertEquals($context->id, $newrequest->getAttribute('usercontext')->id);
    }

    public function test_user_id(): void {
        $this->resetAfterTest();

        $user = $this->getDataGenerator()->create_user();
        $context = \core\context\user::instance($user->id);

        $param = new path_user();
        $newrequest = $param->add_attributes_for_parameter_value(
            new ServerRequest('GET', '/user'),
            $user->id,
        );

        $this->assertInstanceOf(stdClass::class, $newrequest->getAttribute('user'));
        $this->assertInstanceOf(\core\context\user::class, $newrequest->getAttribute('usercontext'));

        $this->assertEquals($user->id, $newrequest->getAttribute('user')->id);
        $this->assertEquals($context->id, $newrequest->getAttribute('usercontext')->id);
    }

    public function test_user_idnumber(): void {
        $this->resetAfterTest();

        $user = $this->getDataGenerator()->create_user((object) [
            'idnumber' => '000117-user',
        ]);
        $context = \core\context\user::instance($user->id);

        $param = new path_user();
        $newrequest = $param->add_attributes_for_parameter_value(
            new ServerRequest('GET', '/user'),
            "idnumber:{$user->idnumber}",
        );

        $this->assertInstanceOf(stdClass::class, $newrequest->getAttribute('user'));
        $this->assertInstanceOf(\core\context\user::class, $newrequest->getAttribute('usercontext'));

        $this->assertEquals($user->id, $newrequest->getAttribute('user')->id);
        $this->assertEquals($context->id, $newrequest->getAttribute('usercontext')->id);
    }

    public function test_username(): void {
        $this->resetAfterTest();

        $user = $this->getDataGenerator()->create_user();
        $context = \core\context\user::instance($user->id);

        $param = new path_user();
        $newrequest = $param->add_attributes_for_parameter_value(
            new ServerRequest('GET', '/user'),
            "username:{$user->username}",
        );

        $this->assertInstanceOf(stdClass::class, $newrequest->getAttribute('user'));
        $this->assertInstanceOf(\core\context\user::class, $newrequest->getAttribute('usercontext'));

        $this->assertEquals($user->id, $newrequest->getAttribute('user')->id);
        $this->assertEquals($context->id, $newrequest->getAttribute('usercontext')->id);
    }

    public function test_validation(): void {
        $this->resetAfterTest();

        $user = $this->getDataGenerator()->create_user();
        $context = \core\context\user::instance($user->id);

        $request = $this->create_route(
            '/user/{user}',
            "/user/username:{$user->username}",
        );
        $route = $this->get_slim_route_from_request($request);

        $param = new path_user();
        $newrequest = $param->validate($request, $route);

        $this->assertInstanceOf(stdClass::class, $newrequest->getAttribute('user'));
        $this->assertInstanceOf(\core\context\user::class, $newrequest->getAttribute('usercontext'));

        $this->assertEquals($user->id, $newrequest->getAttribute('user')->id);
        $this->assertEquals($context->id, $newrequest->getAttribute('usercontext')->id);
    }

    /**
     * Tests for when a course was not found.
     *
     * @dataProvider invalid_course_provider
     * @param string $searchkey
     */
    public function test_course_not_found(string $searchkey): void {
        $param = new path_user();
        $request = new ServerRequest('GET', '/user');

        $this->expectException(not_found_exception::class);
        $param->add_attributes_for_parameter_value($request, $searchkey);
    }

    /**
     * Data provider for test_course_not_found.
     */
    public static function invalid_course_provider(): array {
        return [
            'id' => ['999999'],
            'idnumber' => ['idnumber:999999'],
            'name' => ['username:999999'],
            'random string' => ['ksdjflajsdfkjaf:jkladjg9pomadbs902po3'],
        ];
    }

    public function test_schema(): void {
        $param = new path_user();
        $api = new \core\router\schema\specification();
        $api->add_component($param);
        $result = $param->get_openapi_schema($api);

        // Should be a reference.
        $this->assertInstanceOf(referenced_object::class, $param);

        $schema = $this->get_api_component_schema($api, $param);
        $this->assertIsObject($schema);
        $this->assertIsObject($schema->schema);
        $this->assertObjectHasProperty('pattern', $schema->schema);

        // We do provide some examples here. Make sure they're valid per the regexp.
        $this->assertIsArray($schema->examples);
        foreach ($schema->examples as $example) {
            $this->assertMatchesRegularExpression("/{$schema->schema->pattern}/", $example->value);
        }

        // Some deliberately invalid ones.
        $this->assertDoesNotMatchRegularExpression("/{$schema->schema->pattern}/", 'id');
        $this->assertDoesNotMatchRegularExpression("/{$schema->schema->pattern}/", 'id:1');
        $this->assertDoesNotMatchRegularExpression("/{$schema->schema->pattern}/", 'id;1');
        $this->assertDoesNotMatchRegularExpression("/{$schema->schema->pattern}/", 'idnumber');
        $this->assertDoesNotMatchRegularExpression("/{$schema->schema->pattern}/", 'idnumber:');
        $this->assertDoesNotMatchRegularExpression("/{$schema->schema->pattern}/", 'idnumber;12344');
        $this->assertDoesNotMatchRegularExpression("/{$schema->schema->pattern}/", 'name');
        $this->assertDoesNotMatchRegularExpression("/{$schema->schema->pattern}/", 'name:');
        $this->assertDoesNotMatchRegularExpression("/{$schema->schema->pattern}/", 'name;12345');
        $this->assertDoesNotMatchRegularExpression("/{$schema->schema->pattern}/", 'shortname');
        $this->assertDoesNotMatchRegularExpression("/{$schema->schema->pattern}/", 'shortname:12345');
    }
}