mirror of
https://github.com/phabelio/PHP-Parser.git
synced 2025-01-22 13:21:12 +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);
96 lines
3.7 KiB
PHP
96 lines
3.7 KiB
PHP
<?php
|
|
|
|
class PHPParser_Tests_Lexer_EmulativeTest extends PHPUnit_Framework_TestCase
|
|
{
|
|
/** @var PHPParser_Lexer_Emulative */
|
|
protected $lexer;
|
|
|
|
protected function setUp() {
|
|
$this->lexer = new PHPParser_Lexer_Emulative;
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideTestReplaceKeywords
|
|
*/
|
|
public function testReplaceKeywords($keyword, $expectedToken) {
|
|
$this->lexer->startLexing('<?php ' . $keyword);
|
|
|
|
$this->assertEquals($expectedToken, $this->lexer->getNextToken());
|
|
$this->assertEquals(0, $this->lexer->getNextToken());
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideTestReplaceKeywords
|
|
*/
|
|
public function testNoReplaceKeywordsAfterObjectOperator($keyword) {
|
|
$this->lexer->startLexing('<?php ->' . $keyword);
|
|
|
|
$this->assertEquals(PHPParser_Parser::T_OBJECT_OPERATOR, $this->lexer->getNextToken());
|
|
$this->assertEquals(PHPParser_Parser::T_STRING, $this->lexer->getNextToken());
|
|
$this->assertEquals(0, $this->lexer->getNextToken());
|
|
}
|
|
|
|
public function provideTestReplaceKeywords() {
|
|
return array(
|
|
array('callable', PHPParser_Parser::T_CALLABLE),
|
|
array('insteadof', PHPParser_Parser::T_INSTEADOF),
|
|
array('trait', PHPParser_Parser::T_TRAIT),
|
|
array('__TRAIT__', PHPParser_Parser::T_TRAIT_C),
|
|
array('__DIR__', PHPParser_Parser::T_DIR),
|
|
array('goto', PHPParser_Parser::T_GOTO),
|
|
array('namespace', PHPParser_Parser::T_NAMESPACE),
|
|
array('__NAMESPACE__', PHPParser_Parser::T_NS_C),
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideTestLexNewFeatures
|
|
*/
|
|
public function testLexNewFeatures($code, array $expectedTokens) {
|
|
$this->lexer->startLexing('<?php ' . $code);
|
|
|
|
foreach ($expectedTokens as $expectedToken) {
|
|
list($expectedTokenType, $expectedTokenText) = $expectedToken;
|
|
$this->assertEquals($expectedTokenType, $this->lexer->getNextToken($text));
|
|
$this->assertEquals($expectedTokenText, $text);
|
|
}
|
|
$this->assertEquals(0, $this->lexer->getNextToken());
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideTestLexNewFeatures
|
|
*/
|
|
public function testLeaveStuffAloneInStrings($code) {
|
|
$stringifiedToken = '"' . addcslashes($code, '"\\') . '"';
|
|
$this->lexer->startLexing('<?php ' . $stringifiedToken);
|
|
|
|
$this->assertEquals(PHPParser_Parser::T_CONSTANT_ENCAPSED_STRING, $this->lexer->getNextToken($text));
|
|
$this->assertEquals($stringifiedToken, $text);
|
|
$this->assertEquals(0, $this->lexer->getNextToken());
|
|
}
|
|
|
|
public function provideTestLexNewFeatures() {
|
|
return array(
|
|
array('0b1010110', array(
|
|
array(PHPParser_Parser::T_LNUMBER, '0b1010110'),
|
|
)),
|
|
array('0b10110101010010101101010100101010110101010101011010110', array(
|
|
array(PHPParser_Parser::T_DNUMBER, '0b10110101010010101101010100101010110101010101011010110'),
|
|
)),
|
|
array('\\', array(
|
|
array(PHPParser_Parser::T_NS_SEPARATOR, '\\'),
|
|
)),
|
|
array("<<<'NOWDOC'\nNOWDOC;\n", array(
|
|
array(PHPParser_Parser::T_START_HEREDOC, "<<<'NOWDOC'\n"),
|
|
array(PHPParser_Parser::T_END_HEREDOC, 'NOWDOC'),
|
|
array(ord(';'), ';'),
|
|
)),
|
|
array("<<<'NOWDOC'\nFoobar\nNOWDOC;\n", array(
|
|
array(PHPParser_Parser::T_START_HEREDOC, "<<<'NOWDOC'\n"),
|
|
array(PHPParser_Parser::T_ENCAPSED_AND_WHITESPACE, "Foobar\n"),
|
|
array(PHPParser_Parser::T_END_HEREDOC, 'NOWDOC'),
|
|
array(ord(';'), ';'),
|
|
)),
|
|
);
|
|
}
|
|
} |