mirror of
https://github.com/danog/psalm.git
synced 2025-01-22 13:51:54 +01:00
263 lines
5.8 KiB
PHP
263 lines
5.8 KiB
PHP
<?php
|
|
namespace Psalm\Tests;
|
|
|
|
use PhpParser\ParserFactory;
|
|
use PHPUnit_Framework_TestCase;
|
|
use Psalm\Checker\FileChecker;
|
|
use Psalm\Type;
|
|
|
|
class TypeCombinationTest extends PHPUnit_Framework_TestCase
|
|
{
|
|
/** @var \PhpParser\Parser */
|
|
protected static $parser;
|
|
|
|
/** @var \Psalm\Checker\ProjectChecker */
|
|
protected $project_checker;
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public static function setUpBeforeClass()
|
|
{
|
|
self::$parser = (new ParserFactory)->create(ParserFactory::PREFER_PHP7);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function setUp()
|
|
{
|
|
FileChecker::clearCache();
|
|
$this->project_checker = new \Psalm\Checker\ProjectChecker();
|
|
}
|
|
|
|
/**
|
|
* @param string $string
|
|
* @return Type\Atomic
|
|
*/
|
|
private static function getAtomic($string)
|
|
{
|
|
return array_values(Type::parseString($string)->types)[0];
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testIntOrString()
|
|
{
|
|
$this->assertEquals(
|
|
'int|string',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('int'),
|
|
self::getAtomic('string')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testArrayOfIntOrString()
|
|
{
|
|
$this->assertEquals(
|
|
'array<mixed, int|string>',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('array<int>'),
|
|
self::getAtomic('array<string>')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testArrayOfIntOrAlsoString()
|
|
{
|
|
$this->assertEquals(
|
|
'array<mixed, int>|string',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('array<int>'),
|
|
self::getAtomic('string')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testEmptyArrays()
|
|
{
|
|
$this->assertEquals(
|
|
'array<empty, empty>',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('array<empty,empty>'),
|
|
self::getAtomic('array<empty,empty>')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testArrayStringOrEmptyArray()
|
|
{
|
|
$this->assertEquals(
|
|
'array<mixed, string>',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('array<empty>'),
|
|
self::getAtomic('array<string>')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testArrayMixedOrString()
|
|
{
|
|
$this->assertEquals(
|
|
'array<mixed, mixed>',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('array<mixed>'),
|
|
self::getAtomic('array<string>')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testArrayMixedOrStringKeys()
|
|
{
|
|
$this->assertEquals(
|
|
'array<mixed, string>',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('array<int|string,string>'),
|
|
self::getAtomic('array<mixed,string>')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testArrayMixedOrEmpty()
|
|
{
|
|
$this->assertEquals(
|
|
'array<mixed, mixed>',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('array<empty>'),
|
|
self::getAtomic('array<mixed>')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testArrayBigCombination()
|
|
{
|
|
$this->assertEquals(
|
|
'array<mixed, int|float|string>',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('array<int|float>'),
|
|
self::getAtomic('array<string>')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testFalseDestruction()
|
|
{
|
|
$this->assertEquals(
|
|
'bool',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('false'),
|
|
self::getAtomic('bool')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testOnlyFalse()
|
|
{
|
|
$this->assertEquals(
|
|
'bool',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('false')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testFalseFalseDestruction()
|
|
{
|
|
$this->assertEquals(
|
|
'bool',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('false'),
|
|
self::getAtomic('false')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testAAndAOfB()
|
|
{
|
|
$this->assertEquals(
|
|
'A<mixed>',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('A'),
|
|
self::getAtomic('A<B>')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testCombineObjectType()
|
|
{
|
|
$this->assertEquals(
|
|
'array{a:int, b:string}',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('array{a:int}'),
|
|
self::getAtomic('array{b:string}')
|
|
])
|
|
);
|
|
|
|
$this->assertEquals(
|
|
'array{a:int|string, b:string}',
|
|
(string) Type::combineTypes([
|
|
self::getAtomic('array{a:int}'),
|
|
self::getAtomic('array{a:string,b:string}')
|
|
])
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testMultipleValuedArray()
|
|
{
|
|
$stmts = self::$parser->parse('<?php
|
|
class A {}
|
|
class B {}
|
|
$var = [];
|
|
$var[] = new A();
|
|
$var[] = new B();
|
|
');
|
|
|
|
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
|
|
$file_checker->visitAndAnalyzeMethods();
|
|
}
|
|
}
|