mirror of
https://github.com/nikic/PHP-Parser.git
synced 2025-01-17 15:18:17 +01:00
b7e6361536
- "global" -> remove unused "use" statements - "phpunit" -> fix "@covers" comments - "phpunit" -> replace "->will($this->returnValue()" with "->willReturn()" - "UseTest.php" -> add missing namespace - "composer.json" -> use "autoload-dev" - remove -> "require_once" usage in the tests (use autoload-dev via composer.json) -> most of the changes are done automatically by "https://github.com/rectorphp/rector"
105 lines
3.5 KiB
PHP
105 lines
3.5 KiB
PHP
<?php declare(strict_types=1);
|
|
|
|
namespace PhpParser;
|
|
|
|
class ErrorTest extends \PHPUnit\Framework\TestCase
|
|
{
|
|
public function testConstruct() {
|
|
$attributes = [
|
|
'startLine' => 10,
|
|
'endLine' => 11,
|
|
];
|
|
$error = new Error('Some error', $attributes);
|
|
|
|
$this->assertSame('Some error', $error->getRawMessage());
|
|
$this->assertSame($attributes, $error->getAttributes());
|
|
$this->assertSame(10, $error->getStartLine());
|
|
$this->assertSame(11, $error->getEndLine());
|
|
$this->assertSame('Some error on line 10', $error->getMessage());
|
|
|
|
return $error;
|
|
}
|
|
|
|
/**
|
|
* @depends testConstruct
|
|
*/
|
|
public function testSetMessageAndLine(Error $error) {
|
|
$error->setRawMessage('Some other error');
|
|
$this->assertSame('Some other error', $error->getRawMessage());
|
|
|
|
$error->setStartLine(15);
|
|
$this->assertSame(15, $error->getStartLine());
|
|
$this->assertSame('Some other error on line 15', $error->getMessage());
|
|
}
|
|
|
|
public function testUnknownLine() {
|
|
$error = new Error('Some error');
|
|
|
|
$this->assertSame(-1, $error->getStartLine());
|
|
$this->assertSame(-1, $error->getEndLine());
|
|
$this->assertSame('Some error on unknown line', $error->getMessage());
|
|
}
|
|
|
|
/** @dataProvider provideTestColumnInfo */
|
|
public function testColumnInfo($code, $startPos, $endPos, $startColumn, $endColumn) {
|
|
$error = new Error('Some error', [
|
|
'startFilePos' => $startPos,
|
|
'endFilePos' => $endPos,
|
|
]);
|
|
|
|
$this->assertTrue($error->hasColumnInfo());
|
|
$this->assertSame($startColumn, $error->getStartColumn($code));
|
|
$this->assertSame($endColumn, $error->getEndColumn($code));
|
|
|
|
}
|
|
|
|
public function provideTestColumnInfo() {
|
|
return [
|
|
// Error at "bar"
|
|
["<?php foo bar baz", 10, 12, 11, 13],
|
|
["<?php\nfoo bar baz", 10, 12, 5, 7],
|
|
["<?php foo\nbar baz", 10, 12, 1, 3],
|
|
["<?php foo bar\nbaz", 10, 12, 11, 13],
|
|
["<?php\r\nfoo bar baz", 11, 13, 5, 7],
|
|
// Error at "baz"
|
|
["<?php foo bar baz", 14, 16, 15, 17],
|
|
["<?php foo bar\nbaz", 14, 16, 1, 3],
|
|
// Error at string literal
|
|
["<?php foo 'bar\nbaz' xyz", 10, 18, 11, 4],
|
|
["<?php\nfoo 'bar\nbaz' xyz", 10, 18, 5, 4],
|
|
["<?php foo\n'\nbarbaz\n'\nxyz", 10, 19, 1, 1],
|
|
// Error over full string
|
|
["<?php", 0, 4, 1, 5],
|
|
["<?\nphp", 0, 5, 1, 3],
|
|
];
|
|
}
|
|
|
|
public function testNoColumnInfo() {
|
|
$error = new Error('Some error', 3);
|
|
|
|
$this->assertFalse($error->hasColumnInfo());
|
|
try {
|
|
$error->getStartColumn('');
|
|
$this->fail('Expected RuntimeException');
|
|
} catch (\RuntimeException $e) {
|
|
$this->assertSame('Error does not have column information', $e->getMessage());
|
|
}
|
|
try {
|
|
$error->getEndColumn('');
|
|
$this->fail('Expected RuntimeException');
|
|
} catch (\RuntimeException $e) {
|
|
$this->assertSame('Error does not have column information', $e->getMessage());
|
|
}
|
|
}
|
|
|
|
public function testInvalidPosInfo() {
|
|
$this->expectException(\RuntimeException::class);
|
|
$this->expectExceptionMessage('Invalid position information');
|
|
$error = new Error('Some error', [
|
|
'startFilePos' => 10,
|
|
'endFilePos' => 11,
|
|
]);
|
|
$error->getStartColumn('code');
|
|
}
|
|
}
|