/
UnusedViewsRuleTest.php
64 lines (55 loc) · 1.86 KB
/
UnusedViewsRuleTest.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
<?php
namespace Rules;
use NunoMaduro\Larastan\Collectors\UsedEmailViewCollector;
use NunoMaduro\Larastan\Collectors\UsedRouteFacadeViewCollector;
use NunoMaduro\Larastan\Collectors\UsedViewFacadeMakeCollector;
use NunoMaduro\Larastan\Collectors\UsedViewFunctionCollector;
use NunoMaduro\Larastan\Collectors\UsedViewInAnotherViewCollector;
use NunoMaduro\Larastan\Collectors\UsedViewMakeCollector;
use NunoMaduro\Larastan\Rules\UnusedViewsRule;
use NunoMaduro\Larastan\Support\ViewFileHelper;
use PHPStan\Rules\Rule;
use PHPStan\Testing\RuleTestCase;
/** @extends RuleTestCase<UnusedViewsRule> */
class UnusedViewsRuleTest extends RuleTestCase
{
protected function getRule(): Rule
{
$viewFileHelper = new ViewFileHelper([__DIR__.'/../Application/resources/views'], $this->getFileHelper());
return new UnusedViewsRule(new UsedViewInAnotherViewCollector(
$this->getContainer()->getService('currentPhpVersionSimpleDirectParser'),
$viewFileHelper,
), $viewFileHelper);
}
protected function getCollectors(): array
{
return [
new UsedViewFunctionCollector,
new UsedEmailViewCollector,
new UsedViewMakeCollector,
new UsedViewFacadeMakeCollector,
new UsedRouteFacadeViewCollector,
];
}
protected function setUp(): void
{
parent::setUp();
// This is a workaround for a weird PHPStan container cache issue.
require __DIR__.'/../../bootstrap.php';
}
public function testRule(): void
{
$this->analyse([__DIR__.'/Data/FooController.php'], [
[
'This view is not used in the project.',
00,
],
]);
}
public static function getAdditionalConfigFiles(): array
{
return [
__DIR__.'/../../extension.neon',
];
}
}