mirror of
https://github.com/danog/PHP-Parser.git
synced 2025-01-10 06:58:22 +01:00
9e43acee2c
Directly creating the node isn't necessary anymore, the token only needs to be parsed. This makes it consistent with the other scalar parsing methods and removes the need to pass $arguments around.
59 lines
1.9 KiB
PHP
59 lines
1.9 KiB
PHP
<?php
|
|
|
|
class PHPParser_Tests_Node_Scalar_StringTest extends PHPUnit_Framework_TestCase
|
|
{
|
|
/**
|
|
* @dataProvider provideTestParseEscapeSequences
|
|
*/
|
|
public function testParseEscapeSequences($expected, $string, $quote) {
|
|
$this->assertEquals(
|
|
$expected,
|
|
PHPParser_Node_Scalar_String::parseEscapeSequences($string, $quote)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideTestParse
|
|
*/
|
|
public function testCreate($expected, $string) {
|
|
$this->assertEquals(
|
|
$expected,
|
|
PHPParser_Node_Scalar_String::parse($string)
|
|
);
|
|
}
|
|
|
|
public function provideTestParseEscapeSequences() {
|
|
return array(
|
|
array('"', '\\"', '"'),
|
|
array('\\"', '\\"', '`'),
|
|
array('\\"\\`', '\\"\\`', null),
|
|
array("\\\$\n\r\t\f\v", '\\\\\$\n\r\t\f\v', null),
|
|
array("\x1B", '\e', null),
|
|
array(chr(255), '\xFF', null),
|
|
array(chr(255), '\377', null),
|
|
array(chr(0), '\400', null),
|
|
array("\0", '\0', null),
|
|
array('\xFF', '\\\\xFF', null),
|
|
);
|
|
}
|
|
|
|
public function provideTestParse() {
|
|
$tests = array(
|
|
array('A', '\'A\''),
|
|
array('A', 'b\'A\''),
|
|
array('A', '"A"'),
|
|
array('A', 'b"A"'),
|
|
array('\\', '\'\\\\\''),
|
|
array('\'', '\'\\\'\''),
|
|
);
|
|
|
|
foreach ($this->provideTestParseEscapeSequences() as $i => $test) {
|
|
// skip second and third tests, they aren't for double quotes
|
|
if ($i != 1 && $i != 2) {
|
|
$tests[] = array($test[0], '"' . $test[1] . '"');
|
|
}
|
|
}
|
|
|
|
return $tests;
|
|
}
|
|
} |