|
12 | 12 | */
|
13 | 13 | final class SpecificityCalculatorTest extends TestCase
|
14 | 14 | {
|
| 15 | + protected function tearDown(): void |
| 16 | + { |
| 17 | + SpecificityCalculator::clearCache(); |
| 18 | + } |
| 19 | + |
15 | 20 | /**
|
16 | 21 | * @return array<string, array{0: non-empty-string, 1: int<0, max>}>
|
17 | 22 | */
|
@@ -42,4 +47,48 @@ public function calculateReturnsSpecificityForProvidedSelector(
|
42 | 47 | ): void {
|
43 | 48 | self::assertSame($expectedSpecificity, SpecificityCalculator::calculate($selector));
|
44 | 49 | }
|
| 50 | + |
| 51 | + /** |
| 52 | + * @test |
| 53 | + * |
| 54 | + * @param non-empty-string $selector |
| 55 | + * @param int<0, max> $expectedSpecificity |
| 56 | + * |
| 57 | + * @dataProvider provideSelectorsAndSpecificities |
| 58 | + */ |
| 59 | + public function calculateAfterClearingCacheReturnsSpecificityForProvidedSelector( |
| 60 | + string $selector, |
| 61 | + int $expectedSpecificity |
| 62 | + ): void { |
| 63 | + SpecificityCalculator::clearCache(); |
| 64 | + |
| 65 | + self::assertSame($expectedSpecificity, SpecificityCalculator::calculate($selector)); |
| 66 | + } |
| 67 | + |
| 68 | + /** |
| 69 | + * @test |
| 70 | + */ |
| 71 | + public function calculateCalledTwoTimesReturnsSameSpecificityForProvidedSelector(): void |
| 72 | + { |
| 73 | + $selector = '#test .help'; |
| 74 | + |
| 75 | + $firstResult = SpecificityCalculator::calculate($selector); |
| 76 | + $secondResult = SpecificityCalculator::calculate($selector); |
| 77 | + |
| 78 | + self::assertSame($firstResult, $secondResult); |
| 79 | + } |
| 80 | + |
| 81 | + /** |
| 82 | + * @test |
| 83 | + */ |
| 84 | + public function calculateCalledReturnsSameSpecificityForProvidedSelectorBeforeAndAfterClearingCache(): void |
| 85 | + { |
| 86 | + $selector = '#test .help'; |
| 87 | + |
| 88 | + $firstResult = SpecificityCalculator::calculate($selector); |
| 89 | + SpecificityCalculator::clearCache(); |
| 90 | + $secondResult = SpecificityCalculator::calculate($selector); |
| 91 | + |
| 92 | + self::assertSame($firstResult, $secondResult); |
| 93 | + } |
45 | 94 | }
|
0 commit comments