File: assertContainsOnlyTest.php

package info (click to toggle)
phpunit 12.3.5-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 50,160 kB
  • sloc: php: 101,772; xml: 2,084; makefile: 124; sh: 99
file content (83 lines) | stat: -rw-r--r-- 2,686 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
<?php declare(strict_types=1);
/*
 * This file is part of PHPUnit.
 *
 * (c) Sebastian Bergmann <sebastian@phpunit.de>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */
namespace PHPUnit\Framework;

use function fopen;
use PHPUnit\Framework\Attributes\CoversMethod;
use PHPUnit\Framework\Attributes\DataProvider;
use PHPUnit\Framework\Attributes\IgnorePhpunitDeprecations;
use PHPUnit\Framework\Attributes\Small;
use PHPUnit\Framework\Attributes\TestDox;
use stdClass;

#[CoversMethod(Assert::class, 'assertContainsOnly')]
#[TestDox('assertContainsOnly()')]
#[Small]
#[IgnorePhpunitDeprecations]
final class assertContainsOnlyTest extends TestCase
{
    /**
     * @return non-empty-list<array{0: non-empty-string, 1: iterable}>
     */
    public static function successProvider(): array
    {
        return [
            ['array', [[1, 2, 3]]],
            ['boolean', [true, false]],
            ['bool', [true, false]],
            ['float', [1.0, 2.0, 3.0]],
            ['integer', [1, 2, 3]],
            ['int', [1, 2, 3]],
            ['null', [null]],
            ['numeric', [1, 2.0, '3', '4.0']],
            ['object', [new stdClass]],
            ['resource', [fopen(__FILE__, 'r')]],
            ['scalar', [true, 1.0, 1, 'string']],
            ['string', ['string']],
            [stdClass::class, [new stdClass]],
        ];
    }

    /**
     * @return non-empty-list<array{0: non-empty-string, 1: iterable}>
     */
    public static function failureProvider(): array
    {
        return [
            ['array', [[1, 2, 3], null]],
            ['boolean', [true, false, null]],
            ['bool', [true, false, null]],
            ['float', [1.0, 2.0, 3.0, null]],
            ['integer', [1, 2, 3, null]],
            ['int', [1, 2, 3, null]],
            ['null', [null, 0]],
            ['numeric', [1, 2.0, '3', '4.0', null]],
            ['object', [new stdClass, null]],
            ['resource', [fopen(__FILE__, 'r'), null]],
            ['scalar', [true, 1.0, 1, 'string', null]],
            ['string', ['string', null]],
            [stdClass::class, [new stdClass, null]],
        ];
    }

    #[DataProvider('successProvider')]
    public function testSucceedsWhenConstraintEvaluatesToTrue(string $type, iterable $haystack): void
    {
        $this->assertContainsOnly($type, $haystack);
    }

    #[DataProvider('failureProvider')]
    public function testFailsWhenConstraintEvaluatesToFalse(string $type, iterable $haystack): void
    {
        $this->expectException(AssertionFailedError::class);

        $this->assertContainsOnly($type, $haystack);
    }
}