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\schema\objects;

use core\param;
use core\router\schema\referenced_object;
use core\router\schema\specification;
use core\tests\router\route_testcase;

/**
 * Tests for the an array of other objects.
 *
 * @package    core
 * @copyright  2023 Andrew Lyons <andrew@nicols.co.uk>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 * @covers     \core\router\schema\objects\array_of_things
 * @covers     \core\router\schema\objects\type_base
 * @covers     \core\router\schema\openapi_base
 */
final class array_of_things_test extends route_testcase {
    public function test_referenced_object(): void {
        $object = new class ( // phpcs:ignore
            thingtype: 'integer',
            content: [
                'example' => new schema_object(content: []),
            ],
        ) extends array_of_things implements referenced_object {
        };

        $schema = $object->get_openapi_description(new specification());
        $this->assertObjectNotHasProperty('$ref', $schema);
        $this->assertObjectHasProperty('type', $schema);
        $this->assertEquals('object', $schema->type);
        $this->assertObjectNotHasProperty('properties', $schema);
        $this->assertObjectHasProperty('additionalProperties', $schema);
        $this->assertArrayHasKey('type', $schema->additionalProperties);
        $this->assertEquals('integer', $schema->additionalProperties['type']);

        $reference = $object->get_openapi_schema(new specification());
        $this->assertObjectNotHasProperty('type', $reference);
        $this->assertObjectHasProperty('$ref', $reference);
    }

    public function test_referenced_object_typebase(): void {
        $object = new class ( // phpcs:ignore
            thingtype: new scalar_type(param::INT),
        ) extends array_of_things implements referenced_object {
        };

        $schema = $object->get_openapi_description(new specification());
        $this->assertArrayHasKey('$ref', $schema->additionalProperties);

        $reference = $object->get_openapi_schema(new specification());
        $this->assertObjectNotHasProperty('type', $reference);
        $this->assertObjectHasProperty('$ref', $reference);
    }

    public function test_basics(): void {
        $object = new array_of_things(
            thingtype: 'integer',
        );

        $schema = $object->get_openapi_description(new specification());
        $this->assertEquals((object) [
            'type' => 'object',
            'additionalProperties' => [
                'type' => 'integer',
            ],
        ], $schema);
    }


    /**
     * Test tha the validate_data method successfully validates content.
     *
     * @dataProvider successful_validation_provider
     * @param param|string|type_base|null $valueparamtype
     * @param mixed $data
     */
    public function test_validation_success(
        param|string|type_base|null $valueparamtype,
        mixed $data,
    ): void {
        $object = new array_of_things(
            $valueparamtype,
        );

        $result = $object->validate_data($data);
        $this->assertEquals($data, $result);
    }

    /**
     * Data provider for test_validation_success.
     *
     * @return array
     */
    public static function successful_validation_provider(): array {
        return [
            [
                param::INT,
                [
                    'example' => 123,
                    'other' => 321,
                    'more' => 5634543456543456,
                ],
            ],
            [
                'int',
                [
                    'example' => 123,
                    'other' => 321,
                    'more' => 5634543456543456,
                ],
            ],
            [
                new scalar_type(param::INT),
                [
                    'example' => 123,
                    'other' => 321,
                    'more' => 5634543456543456,
                ],
            ],
            [
                null,
                [
                    'example' => 123,
                    'other' => 321,
                    'more' => 'This is a string',
                ],
            ],
        ];
    }

    /**
     * Test tha the validate_data method throws an exception when the data is invalid.
     *
     * @dataProvider failed_validation_provider
     * @param param|string|type_base|null $valueparamtype
     * @param mixed $data
     */
    public function test_validation_failures(
        param|string|type_base|null $valueparamtype,
        mixed $data,
    ): void {
        $object = new array_of_things(
            $valueparamtype,
        );

        $this->expectException(\invalid_parameter_exception::class);
        $object->validate_data($data);
    }

    /**
     * Data provider for test_validation_failures.
     *
     * @return array
     */
    public static function failed_validation_provider(): array {
        return [
            [
                'int',
                [
                    'example' => 123,
                    'other' => 'threetwoone',
                ],
            ],
            [
                new scalar_type(param::INT),
                [
                    'example' => 123,
                    'other' => 'threetwoone',
                ],
            ],
            [
                param::INT,
                [
                    'example' => 123,
                    'other' => 'threetwoone',
                ],
            ],
            [
                param::INT,
                'string',
            ],
        ];
    }
}