| OLD | NEW |
| (Empty) |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "base/logging.h" | |
| 6 #include "mojom/lexer.h" | |
| 7 #include "testing/gtest/include/gtest/gtest.h" | |
| 8 | |
| 9 namespace mojo { | |
| 10 namespace mojom { | |
| 11 namespace { | |
| 12 | |
| 13 TEST(LexerTest, AllNonErrorTokens) { | |
| 14 const struct TestData { | |
| 15 const char* name; | |
| 16 const char* source; | |
| 17 mojom::TokenType expected_token; | |
| 18 } test_data[] = { | |
| 19 {"LPAREN", "(", mojom::TokenType::LPAREN}, | |
| 20 {"RPAREN", ")", mojom::TokenType::RPAREN}, | |
| 21 {"LBRACKET", "[", mojom::TokenType::LBRACKET}, | |
| 22 {"RBRACKET", "]", mojom::TokenType::RBRACKET}, | |
| 23 {"LBRACE", "{", mojom::TokenType::LBRACE}, | |
| 24 {"RBRACE", "}", mojom::TokenType::RBRACE}, | |
| 25 {"LANGLE", "<", mojom::TokenType::LANGLE}, | |
| 26 {"RANGLE", ">", mojom::TokenType::RANGLE}, | |
| 27 {"SEMI", ";", mojom::TokenType::SEMI}, | |
| 28 {"COMMA", ",", mojom::TokenType::COMMA}, | |
| 29 {"DOT", ".", mojom::TokenType::DOT}, | |
| 30 {"MINUS", "-", mojom::TokenType::MINUS}, | |
| 31 {"PLUS", "+", mojom::TokenType::PLUS}, | |
| 32 {"AMP", "&", mojom::TokenType::AMP}, | |
| 33 {"QSTN", "?", mojom::TokenType::QSTN}, | |
| 34 {"EQUALS", "=", mojom::TokenType::EQUALS}, | |
| 35 {"RESPONSE", "=>", mojom::TokenType::RESPONSE}, | |
| 36 {"IDENTIFIER", "something", mojom::TokenType::IDENTIFIER}, | |
| 37 {"IMPORT", "import", mojom::TokenType::IMPORT}, | |
| 38 {"MODULE", "module", mojom::TokenType::MODULE}, | |
| 39 {"STRUCT", "struct", mojom::TokenType::STRUCT}, | |
| 40 {"UNION", "union", mojom::TokenType::UNION}, | |
| 41 {"INTERFACE", "interface", mojom::TokenType::INTERFACE}, | |
| 42 {"ENUM", "enum", mojom::TokenType::ENUM}, | |
| 43 {"CONST", "const", mojom::TokenType::CONST}, | |
| 44 {"TRUE", "true", mojom::TokenType::TRUE}, | |
| 45 {"FALSE", "false", mojom::TokenType::FALSE}, | |
| 46 {"DEFAULT", "default", mojom::TokenType::DEFAULT}, | |
| 47 {"INT_CONST_DEC", "10", mojom::TokenType::INT_CONST_DEC}, | |
| 48 {"INT_CONST_DEC_0", "0", mojom::TokenType::INT_CONST_DEC}, | |
| 49 {"FLOAT_CONST", "10.5", mojom::TokenType::FLOAT_CONST}, | |
| 50 {"FLOAT_CONST_E", "10e5", mojom::TokenType::FLOAT_CONST}, | |
| 51 {"FLOAT_CONST_ZERO", "0.5", mojom::TokenType::FLOAT_CONST}, | |
| 52 {"FLOAT_CONST_E_ZERO", "0e5", mojom::TokenType::FLOAT_CONST}, | |
| 53 {"FLOAT_CONST_E_PLUS", "10e+5", mojom::TokenType::FLOAT_CONST}, | |
| 54 {"FLOAT_CONST_E_MINUS", "10e-5", mojom::TokenType::FLOAT_CONST}, | |
| 55 {"INT_CONST_HEX", "0x10A", mojom::TokenType::INT_CONST_HEX}, | |
| 56 {"ORDINAL", "@10", mojom::TokenType::ORDINAL}, | |
| 57 {"STRING_LITERAL", "\"hello world\"", mojom::TokenType::STRING_LITERAL}, | |
| 58 {"STRING_LITERAL_ESCAPE", | |
| 59 "\"hello \\\"world\\\"\"", | |
| 60 mojom::TokenType::STRING_LITERAL}, | |
| 61 {"STRING_LITERAL_HEX_ESCAPE", | |
| 62 "\"hello \\x23 world\"", | |
| 63 mojom::TokenType::STRING_LITERAL}, | |
| 64 }; | |
| 65 for (size_t i = 0; i < arraysize(test_data); i++) { | |
| 66 const char* test_name = test_data[i].name; | |
| 67 const char* source = test_data[i].source; | |
| 68 const mojom::TokenType expected_token = test_data[i].expected_token; | |
| 69 std::vector<mojom::Token> tokens = mojom::Tokenize(source); | |
| 70 DCHECK(tokens.size() >= 1) << "Failure to tokenize at all: " << test_name; | |
| 71 const mojom::Token token = tokens[0]; | |
| 72 EXPECT_EQ(expected_token, token.token_type) | |
| 73 << "Wrong token type: " << test_name; | |
| 74 EXPECT_EQ(source, token.token) << "Wrong token value: " << test_name; | |
| 75 } | |
| 76 } | |
| 77 | |
| 78 TEST(LexerTest, TokenPosition) { | |
| 79 std::string source(" \n ."); | |
| 80 std::vector<mojom::Token> tokens = mojom::Tokenize(source); | |
| 81 const mojom::Token token = tokens[0]; | |
| 82 EXPECT_EQ(mojom::TokenType::DOT, token.token_type); | |
| 83 EXPECT_EQ(".", token.token); | |
| 84 EXPECT_EQ(5U, token.char_pos); | |
| 85 EXPECT_EQ(1U, token.line_no); | |
| 86 EXPECT_EQ(2U, token.line_pos); | |
| 87 } | |
| 88 | |
| 89 TEST(LexerTest, ExhaustedTokens) { | |
| 90 std::string source(""); | |
| 91 std::vector<mojom::Token> tokens = mojom::Tokenize(source); | |
| 92 EXPECT_EQ(0U, tokens.size()); | |
| 93 } | |
| 94 | |
| 95 TEST(LexerTest, SkipSkippable) { | |
| 96 std::string source(" \t \r \n ."); | |
| 97 std::vector<mojom::Token> tokens = mojom::Tokenize(source); | |
| 98 const mojom::Token token = tokens[0]; | |
| 99 EXPECT_EQ(mojom::TokenType::DOT, token.token_type); | |
| 100 EXPECT_EQ(".", token.token); | |
| 101 } | |
| 102 | |
| 103 TEST(LexerTest, SkipToTheEnd) { | |
| 104 std::string source(" \t \r \n "); | |
| 105 std::vector<mojom::Token> tokens = mojom::Tokenize(source); | |
| 106 EXPECT_EQ(0U, tokens.size()); | |
| 107 } | |
| 108 | |
| 109 TEST(LexerTest, TokenizeMoreThanOne) { | |
| 110 std::string source("()"); | |
| 111 std::vector<mojom::Token> tokens = mojom::Tokenize(source); | |
| 112 | |
| 113 EXPECT_EQ(mojom::TokenType::LPAREN, tokens[0].token_type); | |
| 114 EXPECT_EQ(mojom::TokenType::RPAREN, tokens[1].token_type); | |
| 115 EXPECT_EQ(2U, tokens.size()); | |
| 116 } | |
| 117 | |
| 118 TEST(LexerTest, ERROR_ILLEGAL_CHAR) { | |
| 119 std::string source("#"); | |
| 120 std::vector<mojom::Token> tokens = mojom::Tokenize(source); | |
| 121 const mojom::Token token = tokens[0]; | |
| 122 EXPECT_EQ(mojom::TokenType::ERROR_ILLEGAL_CHAR, token.token_type); | |
| 123 EXPECT_EQ("#", token.token); | |
| 124 EXPECT_TRUE(token.error()); | |
| 125 } | |
| 126 | |
| 127 TEST(LexerTest, ERROR_UNTERMINATED_STRING_LITERAL_EOL) { | |
| 128 std::string source("\"Hello \n World\""); | |
| 129 std::vector<mojom::Token> tokens = mojom::Tokenize(source); | |
| 130 const mojom::Token token = tokens[0]; | |
| 131 EXPECT_EQ(mojom::TokenType::ERROR_UNTERMINATED_STRING_LITERAL, | |
| 132 token.token_type); | |
| 133 EXPECT_EQ("\"Hello ", token.token); | |
| 134 EXPECT_EQ(0U, token.char_pos); | |
| 135 EXPECT_TRUE(token.error()); | |
| 136 } | |
| 137 | |
| 138 TEST(LexerTest, ERROR_UNTERMINATED_STRING_LITERAL_EOF) { | |
| 139 std::string source("\"Hello "); | |
| 140 std::vector<mojom::Token> tokens = mojom::Tokenize(source); | |
| 141 const mojom::Token token = tokens[0]; | |
| 142 EXPECT_EQ(mojom::TokenType::ERROR_UNTERMINATED_STRING_LITERAL, | |
| 143 token.token_type); | |
| 144 EXPECT_EQ("\"Hello ", token.token); | |
| 145 EXPECT_EQ(0U, token.char_pos); | |
| 146 EXPECT_TRUE(token.error()); | |
| 147 } | |
| 148 | |
| 149 TEST(LexerTest, ERROR_UNTERMINATED_STRING_LITERAL_ESC_EOF) { | |
| 150 std::string source("\"Hello \\"); | |
| 151 std::vector<mojom::Token> tokens = mojom::Tokenize(source); | |
| 152 const mojom::Token token = tokens[0]; | |
| 153 EXPECT_EQ(mojom::TokenType::ERROR_UNTERMINATED_STRING_LITERAL, | |
| 154 token.token_type); | |
| 155 EXPECT_EQ("\"Hello \\", token.token); | |
| 156 EXPECT_EQ(0U, token.char_pos); | |
| 157 EXPECT_TRUE(token.error()); | |
| 158 } | |
| 159 | |
| 160 } // namespace | |
| 161 } // namespace mojom | |
| 162 } // namespace mojo | |
| OLD | NEW |