2020-03-13 17:40:08 +01:00
|
|
|
<?php
|
|
|
|
namespace Psalm\Tests;
|
|
|
|
|
|
|
|
use PHPUnit\Framework\TestCase as BaseTestCase;
|
|
|
|
use Psalm\DocComment;
|
2020-05-28 22:14:41 -04:00
|
|
|
use Psalm\Internal\Scanner\ParsedDocblock;
|
2020-03-13 17:40:08 +01:00
|
|
|
|
|
|
|
class DocCommentTest extends BaseTestCase
|
|
|
|
{
|
|
|
|
public function testNewLineIsAddedBetweenAnnotationsByDefault(): void
|
|
|
|
{
|
2020-05-28 22:14:41 -04:00
|
|
|
$docComment = new ParsedDocblock(
|
2020-07-02 14:55:57 -07:00
|
|
|
'some desc',
|
2020-05-28 22:14:41 -04:00
|
|
|
[
|
|
|
|
'param' =>
|
|
|
|
[
|
|
|
|
2 => 'string $bli',
|
|
|
|
3 => 'int $bla',
|
|
|
|
],
|
|
|
|
'throws' =>
|
|
|
|
[
|
|
|
|
0 => '\Exception',
|
|
|
|
],
|
|
|
|
'return' =>
|
|
|
|
[
|
|
|
|
0 => 'bool',
|
|
|
|
],
|
|
|
|
]
|
|
|
|
);
|
2020-03-13 17:40:08 +01:00
|
|
|
|
|
|
|
$expectedDoc = '/**
|
|
|
|
* some desc
|
|
|
|
*
|
|
|
|
* @param string $bli
|
|
|
|
* @param int $bla
|
|
|
|
*
|
|
|
|
* @throws \Exception
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
';
|
|
|
|
|
2020-05-28 22:14:41 -04:00
|
|
|
$this->assertSame($expectedDoc, $docComment->render(''));
|
2020-03-13 17:40:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testNewLineIsNotAddedBetweenAnnotationsIfDisabled(): void
|
|
|
|
{
|
2020-05-28 22:14:41 -04:00
|
|
|
ParsedDocblock::addNewLineBetweenAnnotations(false);
|
2020-03-13 17:40:08 +01:00
|
|
|
|
2020-05-28 22:14:41 -04:00
|
|
|
$docComment = new ParsedDocblock(
|
2020-07-02 14:55:57 -07:00
|
|
|
'some desc',
|
2020-05-28 22:14:41 -04:00
|
|
|
[
|
|
|
|
'param' =>
|
|
|
|
[
|
|
|
|
2 => 'string $bli',
|
|
|
|
3 => 'int $bla',
|
|
|
|
],
|
|
|
|
'throws' =>
|
|
|
|
[
|
|
|
|
0 => '\Exception',
|
|
|
|
],
|
|
|
|
'return' =>
|
|
|
|
[
|
|
|
|
0 => 'bool',
|
|
|
|
],
|
|
|
|
]
|
|
|
|
);
|
2020-03-13 17:40:08 +01:00
|
|
|
|
|
|
|
$expectedDoc = '/**
|
|
|
|
* some desc
|
|
|
|
*
|
|
|
|
* @param string $bli
|
|
|
|
* @param int $bla
|
|
|
|
* @throws \Exception
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
';
|
|
|
|
|
2020-05-28 22:14:41 -04:00
|
|
|
$this->assertSame($expectedDoc, $docComment->render(''));
|
2020-03-13 17:40:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testNewLineIsAddedBetweenAnnotationsIfEnabled(): void
|
|
|
|
{
|
2020-05-28 22:14:41 -04:00
|
|
|
ParsedDocblock::addNewLineBetweenAnnotations(true);
|
2020-03-13 17:40:08 +01:00
|
|
|
|
2020-05-28 22:14:41 -04:00
|
|
|
$docComment = new ParsedDocblock(
|
2020-07-02 14:55:57 -07:00
|
|
|
'some desc',
|
2020-05-28 22:14:41 -04:00
|
|
|
[
|
|
|
|
'param' =>
|
|
|
|
[
|
|
|
|
2 => 'string $bli',
|
|
|
|
3 => 'int $bla',
|
|
|
|
],
|
|
|
|
'throws' =>
|
|
|
|
[
|
|
|
|
0 => '\Exception',
|
|
|
|
],
|
|
|
|
'return' =>
|
|
|
|
[
|
|
|
|
0 => 'bool',
|
|
|
|
],
|
|
|
|
]
|
|
|
|
);
|
2020-03-13 17:40:08 +01:00
|
|
|
|
|
|
|
$expectedDoc = '/**
|
|
|
|
* some desc
|
|
|
|
*
|
|
|
|
* @param string $bli
|
|
|
|
* @param int $bla
|
|
|
|
*
|
|
|
|
* @throws \Exception
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
';
|
|
|
|
|
2020-05-28 22:14:41 -04:00
|
|
|
$this->assertSame($expectedDoc, $docComment->render(''));
|
2020-03-13 17:40:08 +01:00
|
|
|
}
|
2020-07-02 14:55:57 -07:00
|
|
|
|
|
|
|
public function testParsingRoundtrip(): void
|
|
|
|
{
|
|
|
|
ParsedDocblock::addNewLineBetweenAnnotations(true);
|
|
|
|
|
|
|
|
$expectedDoc = '/**
|
|
|
|
* some desc
|
|
|
|
*
|
|
|
|
* @param string $bli
|
|
|
|
* @param int $bla
|
|
|
|
*
|
|
|
|
* @throws \Exception
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
';
|
|
|
|
$docComment = DocComment::parsePreservingLength(
|
|
|
|
new \PhpParser\Comment\Doc($expectedDoc)
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertSame($expectedDoc, $docComment->render(''));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testParsingWithIndentation(): void
|
|
|
|
{
|
|
|
|
ParsedDocblock::addNewLineBetweenAnnotations(true);
|
|
|
|
|
|
|
|
$expectedDoc = '/**
|
|
|
|
* some desc
|
|
|
|
*
|
|
|
|
* @param string $bli
|
|
|
|
* @param int $bla
|
|
|
|
*
|
|
|
|
* @throws \Exception
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
';
|
|
|
|
$docComment = DocComment::parsePreservingLength(
|
|
|
|
new \PhpParser\Comment\Doc($expectedDoc)
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertSame($expectedDoc, $docComment->render(' '));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testParsingWithCommonPrefixes(): void
|
|
|
|
{
|
|
|
|
ParsedDocblock::addNewLineBetweenAnnotations(true);
|
|
|
|
|
|
|
|
$expectedDoc = '/**
|
|
|
|
* some self-referential desc with " * @return bool
|
|
|
|
* " as part of it.
|
|
|
|
*
|
|
|
|
* @param string $bli
|
|
|
|
* @param string $bli_this_suffix_is_kept
|
|
|
|
* @param int $bla
|
|
|
|
*
|
|
|
|
* @throws \Exception
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
';
|
|
|
|
$docComment = DocComment::parsePreservingLength(
|
|
|
|
new \PhpParser\Comment\Doc($expectedDoc)
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertSame($expectedDoc, $docComment->render(''));
|
|
|
|
}
|
2020-03-13 17:40:08 +01:00
|
|
|
}
|