|  | 
|  | 1 | +<?php | 
|  | 2 | + | 
|  | 3 | +declare(strict_types=1); | 
|  | 4 | + | 
|  | 5 | +namespace Arkitect\Tests\Unit\Expressions\Boolean; | 
|  | 6 | + | 
|  | 7 | +use Arkitect\Analyzer\ClassDescription; | 
|  | 8 | +use Arkitect\Analyzer\FullyQualifiedClassName; | 
|  | 9 | +use Arkitect\Expression\Boolean\Not; | 
|  | 10 | +use Arkitect\Expression\ForClasses\IsInterface; | 
|  | 11 | +use Arkitect\Rules\Violations; | 
|  | 12 | +use PHPUnit\Framework\TestCase; | 
|  | 13 | + | 
|  | 14 | +class NotTest extends TestCase | 
|  | 15 | +{ | 
|  | 16 | +    public function test_it_should_return_violation_error(): void | 
|  | 17 | +    { | 
|  | 18 | +        $isNotInterface = new Not(new IsInterface()); | 
|  | 19 | +        $classDescription = new ClassDescription( | 
|  | 20 | +            FullyQualifiedClassName::fromString('HappyIsland'), | 
|  | 21 | +            [], | 
|  | 22 | +            [], | 
|  | 23 | +            null, | 
|  | 24 | +            false, | 
|  | 25 | +            false, | 
|  | 26 | +            true, | 
|  | 27 | +            false, | 
|  | 28 | +            false | 
|  | 29 | +        ); | 
|  | 30 | +        $because = 'we want to add this rule for our software'; | 
|  | 31 | +        $violationError = $isNotInterface->describe($classDescription, $because)->toString(); | 
|  | 32 | + | 
|  | 33 | +        $violations = new Violations(); | 
|  | 34 | +        $isNotInterface->evaluate($classDescription, $violations, $because); | 
|  | 35 | +        self::assertNotEquals(0, $violations->count()); | 
|  | 36 | + | 
|  | 37 | +        $this->assertEquals('must NOT (HappyIsland should be an interface) because we want to add this rule for our software', $violationError); | 
|  | 38 | +    } | 
|  | 39 | + | 
|  | 40 | +    public function test_it_should_return_true_if_is_not_interface(): void | 
|  | 41 | +    { | 
|  | 42 | +        $isNotInterface = new Not(new IsInterface()); | 
|  | 43 | +        $classDescription = new ClassDescription( | 
|  | 44 | +            FullyQualifiedClassName::fromString('HappyIsland'), | 
|  | 45 | +            [], | 
|  | 46 | +            [], | 
|  | 47 | +            null, | 
|  | 48 | +            false, | 
|  | 49 | +            false, | 
|  | 50 | +            false, | 
|  | 51 | +            false, | 
|  | 52 | +            false | 
|  | 53 | +        ); | 
|  | 54 | +        $because = 'we want to add this rule for our software'; | 
|  | 55 | +        $violations = new Violations(); | 
|  | 56 | +        $isNotInterface->evaluate($classDescription, $violations, $because); | 
|  | 57 | +        self::assertEquals(0, $violations->count()); | 
|  | 58 | +    } | 
|  | 59 | +} | 
0 commit comments