mirror of
				https://github.com/kevinveenbirkenbach/infinito.git
				synced 2025-11-04 11:17:58 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			220 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			220 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace tests\Integration\Attribut;
 | 
						|
 | 
						|
use PHPUnit\Framework\TestCase;
 | 
						|
 | 
						|
/**
 | 
						|
 * This class is not a "real" integration test.
 | 
						|
 * It just checks if the traits are build up on a valid way
 | 
						|
 * It implements the schema described in.
 | 
						|
 *
 | 
						|
 * @see https://github.com/KevinFrantz/infinito/blob/master/application/symfony/src/Attribut/README.md
 | 
						|
 *
 | 
						|
 * @author kevinfrantz
 | 
						|
 */
 | 
						|
class AttributIntegrationTest extends TestCase
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * @var string The folder of the attributes
 | 
						|
     */
 | 
						|
    const FOLDER = __DIR__.'/../../../src/Attribut';
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var string The namespace of the attributs
 | 
						|
     */
 | 
						|
    const NAMESPACE = 'Infinito\\Attribut';
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var string
 | 
						|
     */
 | 
						|
    const INTERFACE_SUFFIX = 'Interface';
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var string
 | 
						|
     */
 | 
						|
    const ATTRIBUT_SUFFIX = 'Attribut';
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var string
 | 
						|
     */
 | 
						|
    const CONCAT_INTERFACE_SUFFIX = self::ATTRIBUT_SUFFIX.self::INTERFACE_SUFFIX;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var array
 | 
						|
     */
 | 
						|
    const POSSIBLE_METHODS = ['has', 'get', 'set'];
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var array
 | 
						|
     */
 | 
						|
    const NECCESSARY_METHODS = ['get', 'set'];
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param string $file
 | 
						|
     *
 | 
						|
     * @return bool True if it is an interface
 | 
						|
     */
 | 
						|
    private function isInterface(\ReflectionClass $interface): bool
 | 
						|
    {
 | 
						|
        return $interface->isInterface();
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param \ReflectionClass $interface
 | 
						|
     *
 | 
						|
     * @return string
 | 
						|
     */
 | 
						|
    private function getTraitName(\ReflectionClass $interface): string
 | 
						|
    {
 | 
						|
        return substr($interface->getName(), 0, -strlen(self::INTERFACE_SUFFIX));
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param \ReflectionClass $interface
 | 
						|
     */
 | 
						|
    private function validateHasTrait(\ReflectionClass $interface): void
 | 
						|
    {
 | 
						|
        $interfaceName = $interface->getName();
 | 
						|
        $trait = $this->getTraitName($interface);
 | 
						|
        $this->assertTrue(trait_exists($trait), "Trait <<$trait>> for interface <<$interfaceName>> MUST exist!");
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param \ReflectionClass $trait
 | 
						|
     */
 | 
						|
    private function validateHasInterface(\ReflectionClass $trait): void
 | 
						|
    {
 | 
						|
        $traitName = $trait->getName();
 | 
						|
        $interface = $traitName.self::INTERFACE_SUFFIX;
 | 
						|
        $this->assertTrue(interface_exists($interface), "Interface <<$interface>> for trait <<$traitName>> does not exist!");
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param \ReflectionClass $interface
 | 
						|
     *
 | 
						|
     * @return string
 | 
						|
     */
 | 
						|
    private function getAttributName(\ReflectionClass $interface): string
 | 
						|
    {
 | 
						|
        return substr($interface->getShortName(), 0, -strlen(self::CONCAT_INTERFACE_SUFFIX));
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param \ReflectionClass $interface
 | 
						|
     *
 | 
						|
     * @return string
 | 
						|
     */
 | 
						|
    private function getConstantName(\ReflectionClass $interface): string
 | 
						|
    {
 | 
						|
        $name = strtoupper($this->getAttributName($interface));
 | 
						|
 | 
						|
        return $name.'_ATTRIBUT_NAME';
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param \ReflectionClass $interface
 | 
						|
     */
 | 
						|
    private function validateConstants(\ReflectionClass $interface): void
 | 
						|
    {
 | 
						|
        $constants = $interface->getConstants();
 | 
						|
        $constantAmount = count($constants);
 | 
						|
        $this->assertTrue($constantAmount <= 1, 'Just one constant is allowed!');
 | 
						|
        if (1 === $constantAmount) {
 | 
						|
            $this->assertEquals($this->getConstantName($interface), array_keys($constants)[0]);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param \ReflectionClass $interface
 | 
						|
     */
 | 
						|
    private function validateMethods(\ReflectionClass $interface): void
 | 
						|
    {
 | 
						|
        $methods = get_class_methods($interface->getName());
 | 
						|
        $possibleMethods = $this->getPossibleMethods($interface);
 | 
						|
        foreach ($methods as $method) {
 | 
						|
            $this->assertContains($method, $possibleMethods);
 | 
						|
        }
 | 
						|
        $neccessaryMethods = $this->getNeccessaryMethods($interface);
 | 
						|
        foreach ($neccessaryMethods as $neccessaryMethod) {
 | 
						|
            $this->assertContains($neccessaryMethod, $methods);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param \ReflectionClass $interface
 | 
						|
     *
 | 
						|
     * @return array
 | 
						|
     */
 | 
						|
    private function getNeccessaryMethods(\ReflectionClass $interface): array
 | 
						|
    {
 | 
						|
        $possibleMethods = [];
 | 
						|
        $name = $this->getAttributName($interface);
 | 
						|
        foreach (self::NECCESSARY_METHODS as $method) {
 | 
						|
            $possibleMethods[] = $method.$name;
 | 
						|
        }
 | 
						|
 | 
						|
        return $possibleMethods;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param \ReflectionClass $interface
 | 
						|
     *
 | 
						|
     * @return array
 | 
						|
     */
 | 
						|
    private function getPossibleMethods(\ReflectionClass $interface): array
 | 
						|
    {
 | 
						|
        $possibleMethods = [];
 | 
						|
        $name = $this->getAttributName($interface);
 | 
						|
        foreach (self::POSSIBLE_METHODS as $method) {
 | 
						|
            $possibleMethods[] = $method.$name;
 | 
						|
        }
 | 
						|
 | 
						|
        return $possibleMethods;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param string $file
 | 
						|
     *
 | 
						|
     * @return \ReflectionClass
 | 
						|
     */
 | 
						|
    private function getReflectionClass(string $file): \ReflectionClass
 | 
						|
    {
 | 
						|
        $shortName = substr($file, 0, -strlen('.php'));
 | 
						|
        $name = self::NAMESPACE.'\\'.$shortName;
 | 
						|
 | 
						|
        return new \ReflectionClass($name);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param \ReflectionClass $interface
 | 
						|
     */
 | 
						|
    private function validateTraitSchema(\ReflectionClass $interface): void
 | 
						|
    {
 | 
						|
        $trait = $this->getTraitName($interface);
 | 
						|
        $traitMethods = get_class_methods($trait);
 | 
						|
        $interfaceMethods = get_class_methods($interface->getName());
 | 
						|
        foreach ($interfaceMethods as $interfaceMethod) {
 | 
						|
            $this->assertContains($interfaceMethod, $traitMethods);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    public function testFiles(): void
 | 
						|
    {
 | 
						|
        $files = scandir(self::FOLDER);
 | 
						|
        foreach ($files as $file) {
 | 
						|
            if (!in_array($file, ['README.md', '.', '..'])) {
 | 
						|
                $reflection = $this->getReflectionClass($file);
 | 
						|
                if ($this->isInterface($reflection)) {
 | 
						|
                    $this->validateHasTrait($reflection);
 | 
						|
                    $this->validateConstants($reflection);
 | 
						|
                    $this->validateMethods($reflection);
 | 
						|
                    $this->validateTraitSchema($reflection);
 | 
						|
                } else {
 | 
						|
                    $this->validateHasInterface($reflection);
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |