-
-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
TokensTest.php
68 lines (55 loc) · 1.75 KB
/
TokensTest.php
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
<?php
declare(strict_types=1);
/*
* This file is part of PHP CS Fixer.
*
* (c) Fabien Potencier <fabien@symfony.com>
* Dariusz Rumiński <dariusz.ruminski@gmail.com>
*
* This source file is subject to the MIT license that is bundled
* with this source code in the file LICENSE.
*/
namespace PhpCsFixer\Tests\Doctrine\Annotation;
use PhpCsFixer\Doctrine\Annotation\Tokens;
use PhpCsFixer\Tests\TestCase;
use PhpCsFixer\Tokenizer\Token;
/**
* @internal
*
* @covers \PhpCsFixer\Doctrine\Annotation\Tokens
*/
final class TokensTest extends TestCase
{
public function testCreateFromEmptyPhpdocComment(): void
{
$docComment = '/** */';
$token = new Token([T_DOC_COMMENT, $docComment]);
$tokens = Tokens::createFromDocComment($token);
static::assertCount(1, $tokens);
static::assertSame($docComment, $tokens->getCode());
}
/**
* @dataProvider provideOffSetOtherThanTokenCases
*/
public function testOffSetOtherThanToken(string $message, ?string $wrongType): void
{
$docComment = '/** */';
$token = new Token([T_DOC_COMMENT, $docComment]);
$tokens = Tokens::createFromDocComment($token);
$this->expectException(\InvalidArgumentException::class);
$this->expectExceptionMessage($message);
// @phpstan-ignore-next-line as we are testing the type error
$tokens[1] = $wrongType;
}
public function provideOffSetOtherThanTokenCases(): iterable
{
yield [
'Token must be an instance of PhpCsFixer\Doctrine\Annotation\Token, "null" given.',
null,
];
yield [
'Token must be an instance of PhpCsFixer\Doctrine\Annotation\Token, "string" given.',
'foo',
];
}
}