Chromium Code Reviews| Index: pkg/front_end/test/scanner_test.dart |
| diff --git a/pkg/front_end/test/scanner_test.dart b/pkg/front_end/test/scanner_test.dart |
| index ca8d75e126ca7ac18a1001683c117d87518b9167..aef85848285efdc704a3a151e9d5eeb47c907cb8 100644 |
| --- a/pkg/front_end/test/scanner_test.dart |
| +++ b/pkg/front_end/test/scanner_test.dart |
| @@ -439,6 +439,7 @@ abstract class ScannerTestBase { |
| // fasta inserts synthetic closers |
| expectedTokens.addAll([ |
| new SyntheticToken(TokenType.CLOSE_CURLY_BRACKET, 10), |
| + new SyntheticStringToken(TokenType.STRING, "\"", 10, 0), |
| ]); |
| } else { |
| expectedTokens.addAll([ |
| @@ -992,28 +993,58 @@ abstract class ScannerTestBase { |
| } |
| void test_string_multi_unterminated() { |
| - _assertErrorAndTokens(ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 8, |
| - "'''string", [new StringToken(TokenType.STRING, "'''string", 0)]); |
| + List<Token> expectedTokens = []; |
| + if (usingFasta) { |
| + // fasta inserts synthetic closers |
|
ahe
2017/06/02 12:26:43
fasta -> Fasta
Add period at end of sentence.
Her
|
| + expectedTokens.addAll([ |
| + new SyntheticStringToken(TokenType.STRING, "'''string'''", 0, 9), |
| + ]); |
| + } else { |
| + expectedTokens.addAll([ |
| + new StringToken(TokenType.STRING, "'''string", 0), |
| + ]); |
| + } |
| } |
| void test_string_multi_unterminated_interpolation_block() { |
| - _assertErrorAndTokens( |
| - ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 8, "'''\${name", [ |
| + List<Token> expectedTokens = [ |
| new StringToken(TokenType.STRING, "'''", 0), |
| new StringToken(TokenType.STRING_INTERPOLATION_EXPRESSION, "\${", 3), |
| new StringToken(TokenType.IDENTIFIER, "name", 5), |
| - new StringToken(TokenType.STRING, "", 9) |
| - ]); |
| + ]; |
| + if (usingFasta) { |
| + // fasta inserts synthetic closers |
| + expectedTokens.addAll([ |
| + new SyntheticToken(TokenType.CLOSE_CURLY_BRACKET, 9), |
| + new SyntheticStringToken(TokenType.STRING, "'''", 9, 0), |
| + ]); |
| + } else { |
| + expectedTokens.addAll([ |
| + new StringToken(TokenType.STRING, "", 9), |
| + ]); |
| + } |
| + _assertErrorAndTokens(ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 8, |
| + "'''\${name", expectedTokens); |
| } |
| void test_string_multi_unterminated_interpolation_identifier() { |
| - _assertErrorAndTokens( |
| - ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 7, "'''\$name", [ |
| + List<Token> expectedTokens = [ |
| new StringToken(TokenType.STRING, "'''", 0), |
| new StringToken(TokenType.STRING_INTERPOLATION_IDENTIFIER, "\$", 3), |
| new StringToken(TokenType.IDENTIFIER, "name", 4), |
| - new StringToken(TokenType.STRING, "", 8) |
| - ]); |
| + ]; |
| + if (usingFasta) { |
| + // fasta inserts synthetic closers |
| + expectedTokens.addAll([ |
| + new SyntheticStringToken(TokenType.STRING, "'''", 8, 0), |
| + ]); |
| + } else { |
| + expectedTokens.addAll([ |
| + new StringToken(TokenType.STRING, "", 8), |
| + ]); |
| + } |
| + _assertErrorAndTokens(ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 7, |
| + "'''\$name", expectedTokens); |
| } |
| void test_string_raw_multi_double() { |
| @@ -1026,8 +1057,19 @@ abstract class ScannerTestBase { |
| void test_string_raw_multi_unterminated() { |
| String source = "r'''string"; |
| + List<Token> expectedTokens = []; |
| + if (usingFasta) { |
| + // fasta inserts synthetic closers |
| + expectedTokens.addAll([ |
| + new SyntheticStringToken(TokenType.STRING, "r'''string'''", 0, 10), |
| + ]); |
| + } else { |
| + expectedTokens.addAll([ |
| + new StringToken(TokenType.STRING, "r'''string", 0), |
| + ]); |
| + } |
| _assertErrorAndTokens(ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 9, |
| - source, [new StringToken(TokenType.STRING, source, 0)]); |
| + source, expectedTokens); |
| } |
| void test_string_raw_simple_double() { |
| @@ -1040,14 +1082,36 @@ abstract class ScannerTestBase { |
| void test_string_raw_simple_unterminated_eof() { |
| String source = "r'string"; |
| + List<Token> expectedTokens = []; |
| + if (usingFasta) { |
| + // fasta inserts synthetic closers |
| + expectedTokens.addAll([ |
| + new SyntheticStringToken(TokenType.STRING, "r'string'", 0, 8), |
| + ]); |
| + } else { |
| + expectedTokens.addAll([ |
| + new StringToken(TokenType.STRING, "r'string", 0), |
| + ]); |
| + } |
| _assertErrorAndTokens(ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 7, |
| - source, [new StringToken(TokenType.STRING, source, 0)]); |
| + source, expectedTokens); |
| } |
| void test_string_raw_simple_unterminated_eol() { |
| - String source = "r'string"; |
| - _assertErrorAndTokens(ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 8, |
| - "$source\n", [new StringToken(TokenType.STRING, source, 0)]); |
| + String source = "r'string\n"; |
| + List<Token> expectedTokens = []; |
| + if (usingFasta) { |
| + // fasta inserts synthetic closers |
| + expectedTokens.addAll([ |
| + new SyntheticStringToken(TokenType.STRING, "r'string'", 0, 8), |
| + ]); |
| + } else { |
| + expectedTokens.addAll([ |
| + new StringToken(TokenType.STRING, "r'string", 0), |
| + ]); |
| + } |
| + _assertErrorAndTokens(ScannerErrorCode.UNTERMINATED_STRING_LITERAL, |
| + usingFasta ? 7 : 8, source, expectedTokens); |
| } |
| void test_string_simple_double() { |
| @@ -1143,34 +1207,77 @@ abstract class ScannerTestBase { |
| void test_string_simple_unterminated_eof() { |
| String source = "'string"; |
| + List<Token> expectedTokens = []; |
| + if (usingFasta) { |
| + // fasta inserts synthetic closers |
| + expectedTokens.addAll([ |
| + new SyntheticStringToken(TokenType.STRING, "'string'", 0, 7), |
| + ]); |
| + } else { |
| + expectedTokens.addAll([ |
| + new StringToken(TokenType.STRING, "'string", 0), |
| + ]); |
| + } |
| _assertErrorAndTokens(ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 6, |
| - source, [new StringToken(TokenType.STRING, source, 0)]); |
| + source, expectedTokens); |
| } |
| void test_string_simple_unterminated_eol() { |
| - String source = "'string"; |
| - _assertErrorAndTokens(ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 7, |
| - "$source\r", [new StringToken(TokenType.STRING, source, 0)]); |
| + String source = "'string\r"; |
| + List<Token> expectedTokens = []; |
| + if (usingFasta) { |
| + // fasta inserts synthetic closers |
| + expectedTokens.addAll([ |
| + new SyntheticStringToken(TokenType.STRING, "'string'", 0, 7), |
| + ]); |
| + } else { |
| + expectedTokens.addAll([ |
| + new StringToken(TokenType.STRING, "'string", 0), |
| + ]); |
| + } |
| + _assertErrorAndTokens(ScannerErrorCode.UNTERMINATED_STRING_LITERAL, |
| + usingFasta ? 6 : 7, source, expectedTokens); |
| } |
| void test_string_simple_unterminated_interpolation_block() { |
| - _assertErrorAndTokens( |
| - ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 6, "'\${name", [ |
| + List<Token> expectedTokens = [ |
| new StringToken(TokenType.STRING, "'", 0), |
| new StringToken(TokenType.STRING_INTERPOLATION_EXPRESSION, "\${", 1), |
| new StringToken(TokenType.IDENTIFIER, "name", 3), |
| - new StringToken(TokenType.STRING, "", 7) |
| - ]); |
| + ]; |
| + if (usingFasta) { |
| + // fasta inserts synthetic closers |
| + expectedTokens.addAll([ |
| + new SyntheticToken(TokenType.CLOSE_CURLY_BRACKET, 7), |
| + new SyntheticStringToken(TokenType.STRING, "'", 7, 0), |
| + ]); |
| + } else { |
| + expectedTokens.addAll([ |
| + new StringToken(TokenType.STRING, "", 7), |
| + ]); |
| + } |
| + _assertErrorAndTokens(ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 6, |
| + "'\${name", expectedTokens); |
| } |
| void test_string_simple_unterminated_interpolation_identifier() { |
| - _assertErrorAndTokens( |
| - ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 5, "'\$name", [ |
| + List<Token> expectedTokens = [ |
| new StringToken(TokenType.STRING, "'", 0), |
| new StringToken(TokenType.STRING_INTERPOLATION_IDENTIFIER, "\$", 1), |
| new StringToken(TokenType.IDENTIFIER, "name", 2), |
| - new StringToken(TokenType.STRING, "", 6) |
| - ]); |
| + ]; |
| + if (usingFasta) { |
| + // fasta inserts synthetic closers |
| + expectedTokens.addAll([ |
| + new SyntheticStringToken(TokenType.STRING, "'", 6, 0), |
| + ]); |
| + } else { |
| + expectedTokens.addAll([ |
| + new StringToken(TokenType.STRING, "", 6), |
| + ]); |
| + } |
| + _assertErrorAndTokens(ScannerErrorCode.UNTERMINATED_STRING_LITERAL, 5, |
| + "'\$name", expectedTokens); |
| } |
| void test_sync_star() { |