1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-22 13:51:54 +01:00
psalm/tests/TypeParseTest.php

399 lines
8.9 KiB
PHP
Raw Normal View History

<?php
namespace Psalm\Tests;
2016-11-02 02:29:00 -04:00
use Psalm\Type;
class TypeParseTest extends TestCase
{
/**
* @return void
*/
public function setUp()
{
2018-03-20 20:19:26 -04:00
//parent::setUp();
}
2018-03-22 17:55:36 -04:00
/**
* @return void
*/
public function testThisToStatic()
{
$this->assertSame('static', (string) Type::parseString('$this'));
}
/**
* @return void
*/
public function testThisToStaticUnion()
{
$this->assertSame('static|A', (string) Type::parseString('$this|A'));
}
2017-01-13 14:07:23 -05:00
/**
* @return void
*/
public function testIntOrString()
{
2017-05-26 20:05:57 -04:00
$this->assertSame('int|string', (string) Type::parseString('int|string'));
}
2018-03-22 22:28:06 -04:00
/**
* @return void
*/
public function testBracketedIntOrString()
{
$this->assertSame('int|string', (string) Type::parseString('(int|string)'));
}
2018-03-20 20:19:26 -04:00
/**
* @return void
*/
public function testBoolOrIntOrString()
{
$this->assertSame('bool|int|string', (string) Type::parseString('bool|int|string'));
}
2017-11-20 00:32:40 -05:00
/**
* @return void
*/
public function testNullable()
{
$this->assertSame('null|string', (string) Type::parseString('?string'));
}
2017-01-13 14:07:23 -05:00
/**
* @return void
*/
public function testArray()
{
2017-05-26 20:05:57 -04:00
$this->assertSame('array<int, int>', (string) Type::parseString('array<int, int>'));
$this->assertSame('array<int, string>', (string) Type::parseString('array<int, string>'));
$this->assertSame('array<int, static>', (string) Type::parseString('array<int, static>'));
2018-03-20 20:19:26 -04:00
}
/**
* @return void
*/
public function testArrayWithSingleArg()
{
$this->assertSame('array<mixed, int>', (string) Type::parseString('array<int>'));
}
/**
* @return void
*/
public function testArrayWithNestedSingleArg()
{
$this->assertSame('array<mixed, array<mixed, int>>', (string) Type::parseString('array<array<int>>'));
}
/**
* @return void
*/
public function testArrayWithUnion()
{
2017-05-26 20:05:57 -04:00
$this->assertSame('array<int|string, string>', (string) Type::parseString('array<int|string, string>'));
}
2017-01-13 14:07:23 -05:00
/**
* @return void
*/
public function testGeneric()
{
2017-05-26 20:05:57 -04:00
$this->assertSame('B<int>', (string) Type::parseString('B<int>'));
}
/**
* @return void
*/
public function testIntersection()
{
$this->assertSame('I1&I2', (string) Type::parseString('I1&I2'));
}
2018-03-22 17:55:36 -04:00
/**
* @return void
*/
public function testIntersectionOrNull()
{
$this->assertSame('I1&I2|null', (string) Type::parseString('I1&I2|null'));
}
/**
* @return void
*/
public function testNullOrIntersection()
{
$this->assertSame('null|I1&I2', (string) Type::parseString('null|I1&I2'));
}
/**
* @return void
*/
public function testInteratorAndTraversable()
{
$this->assertSame('Iterator<int>&Traversable', (string) Type::parseString('Iterator<int>&Traversable'));
}
/**
* @return void
*/
public function testTraversableAndIteratorOrNull()
{
$this->assertSame(
'Traversable&Iterator<int>|null',
(string) Type::parseString('Traversable&Iterator<int>|null')
);
}
2017-01-13 14:07:23 -05:00
/**
* @return void
*/
2018-03-20 20:19:26 -04:00
public function testPhpDocSimpleArray()
2016-10-29 20:57:03 -04:00
{
2017-05-26 20:05:57 -04:00
$this->assertSame('array<mixed, A>', (string) Type::parseString('A[]'));
2018-03-20 20:19:26 -04:00
}
/**
* @return void
*/
public function testPhpDocUnionArray()
{
2017-05-26 20:05:57 -04:00
$this->assertSame('array<mixed, A|B>', (string) Type::parseString('(A|B)[]'));
2018-03-20 20:19:26 -04:00
}
/**
* @return void
*/
public function testPhpDocMultiDimensionalArray()
{
2017-05-26 20:05:57 -04:00
$this->assertSame('array<mixed, array<mixed, A>>', (string) Type::parseString('A[][]'));
2018-03-20 20:19:26 -04:00
}
/**
* @return void
*/
public function testPhpDocMultidimensionalUnionArray()
{
2017-05-26 20:05:57 -04:00
$this->assertSame('array<mixed, array<mixed, A|B>>', (string) Type::parseString('(A|B)[][]'));
2018-03-20 20:19:26 -04:00
}
/**
* @return void
*/
public function testPhpDocObjectLikeArray()
{
$this->assertSame(
'array<mixed, array{b:bool, d:string}>',
(string) Type::parseString('array{b:bool,d:string}[]')
);
}
2018-03-20 20:19:26 -04:00
/**
* @return void
*/
public function testPhpDocUnionOfArrays()
{
2017-05-26 20:05:57 -04:00
$this->assertSame('array<mixed, A|B>', (string) Type::parseString('A[]|B[]'));
2018-03-20 20:19:26 -04:00
}
/**
* @return void
*/
public function testPhpDocUnionOfArraysOrObject()
{
2017-05-26 20:05:57 -04:00
$this->assertSame('array<mixed, A|B>|C', (string) Type::parseString('A[]|B[]|C'));
2016-10-29 20:57:03 -04:00
}
/**
* @return void
*/
public function testPsalmOnlyAtomic()
{
$this->assertSame('class-string', (string) Type::parseString('class-string'));
}
2017-10-12 14:02:06 -04:00
/**
* @expectedException \Psalm\Exception\TypeParseTreeException
*
* @return void
*/
public function testInvalidType()
{
Type::parseString('array(A)');
}
2018-03-22 22:28:06 -04:00
/**
* @expectedException \Psalm\Exception\TypeParseTreeException
*
* @return void
*/
public function testBracketedUnionAndIntersection()
{
Type::parseString('(A|B)&C');
}
2017-01-13 14:07:23 -05:00
/**
* @return void
*/
2018-03-20 20:19:26 -04:00
public function testObjectLikeWithSimpleArgs()
{
2017-05-26 20:05:57 -04:00
$this->assertSame('array{a:int, b:string}', (string) Type::parseString('array{a:int, b:string}'));
2018-03-20 20:19:26 -04:00
}
/**
* @return void
*/
public function testObjectLikeWithUnionArgs()
{
2017-05-26 20:05:57 -04:00
$this->assertSame(
2016-11-13 11:24:25 -05:00
'array{a:int|string, b:string}',
2016-11-02 02:29:00 -04:00
(string) Type::parseString('array{a:int|string, b:string}')
);
2018-03-20 20:19:26 -04:00
}
2016-11-02 02:29:00 -04:00
2018-03-20 20:19:26 -04:00
/**
* @return void
*/
public function testObjectLikeWithGenericArgs()
{
2017-05-26 20:05:57 -04:00
$this->assertSame(
2016-11-13 11:24:25 -05:00
'array{a:array<int, string|int>, b:string}',
2016-11-02 02:29:00 -04:00
(string) Type::parseString('array{a:array<int, string|int>, b:string}')
);
2018-03-20 20:19:26 -04:00
}
2018-03-20 20:19:26 -04:00
/**
* @return void
*/
public function testObjectLikeWithIntKeysAndUnionArgs()
{
$this->assertSame(
'array{0:stdClass|null}',
(string)Type::parseString('array{stdClass|null}')
);
2018-03-20 20:19:26 -04:00
}
2018-03-20 20:19:26 -04:00
/**
* @return void
*/
public function testObjectLikeWithIntKeysAndGenericArgs()
{
$this->assertSame(
'array{0:array<mixed, mixed>}',
(string)Type::parseString('array{array}')
);
$this->assertSame(
'array{0:array<int, string>}',
(string)Type::parseString('array{array<int, string>}')
);
}
/**
* @return void
*/
public function testObjectLikeOptional()
{
$this->assertSame(
'array{a:int, b?:int}',
(string)Type::parseString('array{a:int, b?:int}')
);
}
/**
* @return void
*/
public function testCallable()
{
$this->assertSame(
'callable(int, string) : void',
(string)Type::parseString('callable(int, string) : void')
);
}
/**
* @return void
*/
public function testCallableWithUnionLastType()
{
$this->assertSame(
'callable(int, int|string) : void',
(string)Type::parseString('callable(int, int|string) : void')
);
}
/**
* @return void
*/
public function testCallableWithVariadic()
{
$this->assertSame(
'callable(int, string...) : void',
(string)Type::parseString('callable(int, string...) : void')
);
}
/**
* @expectedException \Psalm\Exception\TypeParseTreeException
*
* @return void
*/
public function testCallableWithBadVariadic()
{
Type::parseString('callable(int, ...string) : void');
}
/**
* @expectedException \Psalm\Exception\TypeParseTreeException
*
* @return void
*/
public function testCallableWithAnotherBadVariadic()
{
Type::parseString('callable(int, string..) : void');
}
/**
* @expectedException \Psalm\Exception\TypeParseTreeException
*
* @return void
*/
public function testCallableWithVariadicAndDefault()
{
Type::parseString('callable(int, string...=) : void');
}
/**
* @expectedException \Psalm\Exception\TypeParseTreeException
*
* @return void
*/
public function testBadVariadic()
{
Type::parseString('string...');
}
/**
* @return void
*/
public function testCallableWithDefault()
{
$this->assertSame(
'callable(int, string=) : void',
(string)Type::parseString('callable(int, string=) : void')
);
}
/**
* @return void
*/
public function testCallableWithoutReturn()
{
$this->assertSame(
'callable(int, string)',
(string)Type::parseString('callable(int, string)')
);
}
}