PHP Classes

File: tests/ReflectionFunctionsTest.php

Recommend this page to a friend!
  Classes of Rodolfo Berrios Arce   Parameter   tests/ReflectionFunctionsTest.php   Download  
File: tests/ReflectionFunctionsTest.php
Role: Class source
Content type: text/plain
Description: Class source
Class: Parameter
Validate function parameters with PHP attributes
Author: By
Last change:
Date: 15 days ago
Size: 3,727 bytes
 

Contents

Class file image Download
<?php

/*
 * This file is part of Chevere.
 *
 * (c) Rodolfo Berrios <[email protected]>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

declare(strict_types=1);

namespace
Chevere\Tests;

use
Chevere\Parameter\Attributes\IntAttr;
use
Chevere\Parameter\Attributes\ReturnAttr;
use
InvalidArgumentException;
use
PHPUnit\Framework\Attributes\DataProvider;
use
PHPUnit\Framework\TestCase;
use
ReflectionFunction;
use
ReflectionMethod;
use function
Chevere\Parameter\arguments;
use function
Chevere\Parameter\bool;
use function
Chevere\Parameter\reflectionToParameters;
use function
Chevere\Parameter\reflectionToReturn;

final class
ReflectionFunctionsTest extends TestCase
{
    public function
testAnonClassReturn(): void
   
{
       
$class = new class() {
           
#[ReturnAttr(
               
new IntAttr(min: 100)
            )]
            public function
wea(int $base): int
           
{
                return
10 * $base;
            }
        };
       
$reflection = new ReflectionMethod($class, 'wea');
       
$return = reflectionToReturn($reflection);
       
$object = new $class();
       
$object->wea(1);
       
$this->expectException(InvalidArgumentException::class);
       
$this->expectExceptionMessage('Argument value provided `10` is less than `100`');
       
$return($object->wea(1));
    }

    public function
testAnonClassParameters(): void
   
{
       
$class = new class() {
            public function
wea(
               
#[IntAttr(accept: [1, 10, 100])]
               
int $base = 1
           
): void {
            }
        };
       
$reflection = new ReflectionMethod($class, 'wea');
       
$parameters = reflectionToParameters($reflection);
       
$object = new $class();
       
$object->wea(1);
       
$this->expectException(InvalidArgumentException::class);
       
$this->expectExceptionMessage('[base]: Argument value provided `0` is not an accepted value in `[1,10,100]`');
       
arguments($parameters, [
           
'base' => 0,
        ]);
    }

    public function
testAnonFunctionReturn(): void
   
{
       
$function =
           
#[ReturnAttr(
               
new IntAttr(min: 1000)
            )]
            function (
int $base): int {
                return
10 * $base;
            };
       
$reflection = new ReflectionFunction($function);
       
$return = reflectionToReturn($reflection);
       
$function(10);
       
$this->expectException(InvalidArgumentException::class);
       
$this->expectExceptionMessage('Argument value provided `100` is less than `1000`');
       
$return($function(10));
    }

    public static function
dataProviderFunctionToReturnUses(): array
    {
        return [
            [
'Chevere\Tests\src\usesAttr'],
            [
'Chevere\Tests\src\noUsesAttr'],
        ];
    }

   
#[DataProvider('dataProviderFunctionToReturnUses')]
   
public function testFunctionToReturnUses(string $function): void
   
{
       
$this->expectNotToPerformAssertions();
       
$reflection = new ReflectionFunction($function);
       
$return = reflectionToReturn($reflection);
       
$return->assertCompatible(bool());
    }

    public function
testWithDefaultError(): void
   
{
       
$function = 'Chevere\Tests\src\withDefaultError';
       
$reflection = new ReflectionFunction($function);
       
$this->expectException(InvalidArgumentException::class);
       
$this->expectExceptionMessage(
            <<<PLAIN
Unable to use default value for parameter `int` in `Chevere\Tests\src\withDefaultError`: Argument value provided `1` is less than `2`
PLAIN
        );
       
reflectionToParameters($reflection);
    }
}