From 961984c9255ce9c14eb2aaffb3cad3f97eda83a5 Mon Sep 17 00:00:00 2001 From: "Matthew \"strager\" Glazar" Date: Sat, 20 Jan 2024 20:32:36 -0500 Subject: [PATCH] feat(test): ensure '>=>' is token-split correctly Splitting '>=>' into '>' and '=>' is a bit tricky, so ensure we test this case directly. --- test/test-lex.cpp | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/test/test-lex.cpp b/test/test-lex.cpp index 46f056c41a..dc979a8d6b 100644 --- a/test/test-lex.cpp +++ b/test/test-lex.cpp @@ -1421,6 +1421,21 @@ TEST_F(Test_Lex, split_greater_from_bigger_token) { l.skip(); EXPECT_EQ(l.peek().type, Token_Type::semicolon); } + + { + Padded_String input(u8">=>;"_sv); + Lexer l(&input, &Null_Diag_Reporter::instance); + EXPECT_EQ(l.peek().type, Token_Type::greater_equal); + + l.skip_as_greater(); + EXPECT_EQ(l.peek().type, Token_Type::equal_greater); + EXPECT_EQ(l.peek().begin, &input[1]); + EXPECT_EQ(l.peek().end, &input[3]); + EXPECT_EQ(l.end_of_previous_token(), &input[1]); + l.skip(); + + EXPECT_EQ(l.peek().type, Token_Type::semicolon); + } } TEST_F(Test_Lex, split_greater_from_bigger_token_has_no_leading_newline) {