1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-22 13:51:54 +01:00
psalm/tests/Internal/Codebase/ClassLikesTest.php
Maximilian Bösing d4559f5ba3
qa: add failing test regarding recursive alias resolving
Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com>
2021-08-18 16:18:44 +02:00

51 lines
1.4 KiB
PHP

<?php
declare(strict_types=1);
namespace Psalm\Tests\Internal\Codebase;
use Psalm\Internal\Codebase\ClassLikes;
use Psalm\Internal\Provider\ClassLikeStorageProvider;
use Psalm\Storage\ClassLikeStorage;
use Psalm\Tests\TestCase;
final class ClassLikesTest extends TestCase
{
/**
* @var ClassLikes
*/
private $classlikes;
/**
* @var ClassLikeStorageProvider
*/
private $storage_provider;
public function setUp(): void
{
parent::setUp();
$this->classlikes = $this->project_analyzer->getCodebase()->classlikes;
$this->storage_provider = $this->project_analyzer->getCodebase()->classlike_storage_provider;
}
public function testWillDetectClassImplementingAliasedInterface(): void
{
$this->classlikes->addClassAlias('Foo', 'bar');
$classStorage = new ClassLikeStorage('Baz');
$classStorage->class_implements['bar'] = 'Bar';
$this->storage_provider->addMore(['baz' => $classStorage]);
self::assertTrue($this->classlikes->classImplements('Baz', 'Foo'));
}
public function testWillResolveAliasedAliases(): void
{
$this->classlikes->addClassAlias('Foo', 'bar');
$this->classlikes->addClassAlias('Bar', 'baz');
$this->classlikes->addClassAlias('Baz', 'qoo');
self::assertSame('Foo', $this->classlikes->getUnAliasedName('Qoo'));
}
}