respect-validation/tests/unit/Validators/FileTest.php
Henrique Moody 7c681fec66
Fix SPDX headers in all files
I ran the `bin/console spdx --fix` with different strategies for
different files. For most of the core classes, since they've been
drastically rebuilt, I've run it with the `git-blame` strategy, for for
the `src/Validators`, in which the API changed completely but the logic
remains the same, I use the `git-log` strategy.
2026-02-03 15:23:23 +01:00

56 lines
1.6 KiB
PHP

<?php
/*
* SPDX-License-Identifier: MIT
* SPDX-FileCopyrightText: (c) Respect Project Contributors
* SPDX-FileContributor: Alexandre Gomes Gaigalas <alganet@gmail.com>
* SPDX-FileContributor: Danilo Correa <danilosilva87@gmail.com>
* SPDX-FileContributor: Henrique Moody <henriquemoody@gmail.com>
*/
declare(strict_types=1);
namespace Respect\Validation\Validators;
use PHPUnit\Framework\Attributes\CoversClass;
use PHPUnit\Framework\Attributes\Group;
use Respect\Validation\Test\RuleTestCase;
use SplFileInfo;
use SplFileObject;
use stdClass;
use const PHP_INT_MAX;
#[Group('validator')]
#[CoversClass(File::class)]
final class FileTest extends RuleTestCase
{
/** @return iterable<array{File, mixed}> */
public static function providerForValidInput(): iterable
{
$sut = new File();
return [
'filename' => [$sut, __FILE__],
'SplFileInfo' => [$sut, new SplFileInfo(self::fixture('valid-image.png'))],
'SplFileObject' => [$sut, new SplFileObject(self::fixture('invalid-image.png'))],
];
}
/** @return iterable<array{File, mixed}> */
public static function providerForInvalidInput(): iterable
{
$sut = new File();
return [
'directory' => [$sut, __DIR__],
'object' => [$sut, new stdClass()],
'array' => [$sut, []],
'invalid filename' => [$sut, 'not-a-file-at-all'],
'integer' => [$sut, PHP_INT_MAX],
'float' => [$sut, 1.222],
'boolean true' => [$sut, true],
'boolean false' => [$sut, false],
];
}
}