mirror of
https://github.com/phabelio/PHP-Parser.git
synced 2024-12-12 09:09:41 +01:00
3701e02d32
Now the lexer is injected only once when creating the parser. Instead of $parser = new PHPParser_Parser; $parser->parse(new PHPParser_Lexer($code)); $parser->parse(new PHPParser_Lexer($code2)); you write: $parser = new PHPParser_Parser(new PHPParser_Lexer); $parser->parse($code); $parser->parse($code2);
101 lines
3.5 KiB
PHP
101 lines
3.5 KiB
PHP
<?php
|
|
|
|
class PHPParser_Tests_LexerTest extends PHPUnit_Framework_TestCase
|
|
{
|
|
/** @var PHPParser_Lexer */
|
|
protected $lexer;
|
|
|
|
protected function setUp() {
|
|
$this->lexer = new PHPParser_Lexer;
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideTestError
|
|
*/
|
|
public function testError($code, $message) {
|
|
try {
|
|
$this->lexer->startLexing($code);
|
|
} catch (PHPParser_Error $e) {
|
|
$this->assertEquals($message, $e->getMessage());
|
|
|
|
return;
|
|
}
|
|
|
|
$this->fail('Expected PHPParser_Error');
|
|
}
|
|
|
|
public function provideTestError() {
|
|
return array(
|
|
array('<?php /*', 'Unterminated comment on line 1'),
|
|
array('<?php ' . "\1", 'Unexpected character "' . "\1" . '" (ASCII 1) on unknown line'),
|
|
array('<?php ' . "\0", 'Unexpected null byte on unknown line'),
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideTestLex
|
|
*/
|
|
public function testLex($code, $tokens) {
|
|
$this->lexer->startLexing($code);
|
|
while ($id = $this->lexer->getNextToken($value, $line, $docComment)) {
|
|
$token = array_shift($tokens);
|
|
|
|
$this->assertEquals($token[0], $id);
|
|
$this->assertEquals($token[1], $value);
|
|
$this->assertEquals($token[2], $line);
|
|
$this->assertEquals($token[3], $docComment);
|
|
}
|
|
}
|
|
|
|
public function provideTestLex() {
|
|
return array(
|
|
// tests conversion of closing PHP tag and drop of whitespace, comments and opening tags
|
|
array(
|
|
'<?php tokens // ?>plaintext',
|
|
array(
|
|
array(PHPParser_Parser::T_STRING, 'tokens', 1, null),
|
|
array(ord(';'), '?>', 1, null),
|
|
array(PHPParser_Parser::T_INLINE_HTML, 'plaintext', 1, null),
|
|
)
|
|
),
|
|
// tests line numbers
|
|
array(
|
|
'<?php' . "\n" . '$ token /** doc' . "\n" . 'comment */ $',
|
|
array(
|
|
array(ord('$'), '$', 2, null),
|
|
array(PHPParser_Parser::T_STRING, 'token', 2, null),
|
|
array(ord('$'), '$', 3, '/** doc' . "\n" . 'comment */')
|
|
)
|
|
),
|
|
// tests doccomment extraction
|
|
array(
|
|
'<?php /** docComment 1 *//** docComment 2 */ token',
|
|
array(
|
|
array(PHPParser_Parser::T_STRING, 'token', 1, '/** docComment 2 */'),
|
|
)
|
|
),
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideTestHaltCompiler
|
|
*/
|
|
public function testHandleHaltCompiler($code, $remaining) {
|
|
$this->lexer->startLexing($code);
|
|
|
|
while (PHPParser_Parser::T_HALT_COMPILER !== $this->lexer->getNextToken());
|
|
|
|
$this->assertEquals($this->lexer->handleHaltCompiler(), $remaining);
|
|
$this->assertEquals(0, $this->lexer->getNextToken());
|
|
}
|
|
|
|
public function provideTestHaltCompiler() {
|
|
return array(
|
|
array('<?php ... __halt_compiler();Remaining Text', 'Remaining Text'),
|
|
array('<?php ... __halt_compiler ( ) ;Remaining Text', 'Remaining Text'),
|
|
array('<?php ... __halt_compiler() ?>Remaining Text', 'Remaining Text'),
|
|
//array('<?php ... __halt_compiler();' . "\0", "\0"),
|
|
//array('<?php ... __halt_compiler /* */ ( ) ;Remaining Text', 'Remaining Text'),
|
|
);
|
|
}
|
|
} |