1
0
mirror of https://github.com/danog/psalm.git synced 2024-11-27 04:45:20 +01:00
psalm/tests/TypeParseTest.php

89 lines
2.6 KiB
PHP
Raw Normal View History

<?php
namespace Psalm\Tests;
use PhpParser\ParserFactory;
use PHPUnit_Framework_TestCase;
2016-11-02 07:29:00 +01:00
use Psalm\Type;
class TypeParseTest extends PHPUnit_Framework_TestCase
{
/** @var \PhpParser\Parser */
2016-11-02 07:29:00 +01:00
protected static $parser;
/** @var \Psalm\Checker\ProjectChecker */
protected $project_checker;
2017-01-13 20:07:23 +01:00
/**
* @return void
*/
public static function setUpBeforeClass()
{
2016-11-02 07:29:00 +01:00
self::$parser = (new ParserFactory)->create(ParserFactory::PREFER_PHP7);
}
2017-01-13 20:07:23 +01:00
/**
* @return \Psalm\Type\Atomic
*/
private static function getAtomic($string)
{
return array_values(Type::parseString($string)->types)[0];
}
2017-01-13 20:07:23 +01:00
/**
* @return void
*/
public function testIntOrString()
{
$this->assertEquals('int|string', (string) Type::parseString('int|string'));
}
2017-01-13 20:07:23 +01:00
/**
* @return void
*/
public function testArray()
{
2016-11-13 17:24:25 +01:00
$this->assertEquals('array<int, int>', (string) Type::parseString('array<int, int>'));
$this->assertEquals('array<int, string>', (string) Type::parseString('array<int, string>'));
$this->assertEquals('array<int, static>', (string) Type::parseString('array<int, static>'));
$this->assertEquals('array<int|string, string>', (string) Type::parseString('array<int|string, string>'));
}
2017-01-13 20:07:23 +01:00
/**
* @return void
*/
public function testGeneric()
{
$this->assertEquals('B<int>', (string) Type::parseString('B<int>'));
}
2017-01-13 20:07:23 +01:00
/**
* @return void
*/
2016-10-30 02:57:03 +02:00
public function testPhpDocStyle()
{
2016-11-13 17:24:25 +01:00
$this->assertEquals('array<mixed, A>', (string) Type::parseString('A[]'));
$this->assertEquals('array<mixed, A|B>', (string) Type::parseString('(A|B)[]'));
$this->assertEquals('array<mixed, array<mixed, A>>', (string) Type::parseString('A[][]'));
$this->assertEquals('array<mixed, array<mixed, A|B>>', (string) Type::parseString('(A|B)[][]'));
2016-11-20 08:52:34 +01:00
$this->assertEquals('array<mixed, A|B>', (string) Type::parseString('A[]|B[]'));
$this->assertEquals('array<mixed, A|B>|C', (string) Type::parseString('A[]|B[]|C'));
2016-10-30 02:57:03 +02:00
}
2017-01-13 20:07:23 +01:00
/**
* @return void
*/
public function testObjectLike()
{
2016-11-13 17:24:25 +01:00
$this->assertEquals('array{a:int, b:string}', (string) Type::parseString('array{a:int, b:string}'));
2016-11-02 07:29:00 +01:00
$this->assertEquals(
2016-11-13 17:24:25 +01:00
'array{a:int|string, b:string}',
2016-11-02 07:29:00 +01:00
(string) Type::parseString('array{a:int|string, b:string}')
);
$this->assertEquals(
2016-11-13 17:24:25 +01:00
'array{a:array<int, string|int>, b:string}',
2016-11-02 07:29:00 +01:00
(string) Type::parseString('array{a:array<int, string|int>, b:string}')
);
}
}