aboutsummaryrefslogtreecommitdiffstats
path: root/SQLiteStudio3/Tests/LexerTest/tst_lexertest.cpp
diff options
context:
space:
mode:
authorLibravatarUnit 193 <unit193@ubuntu.com>2018-07-27 23:54:15 -0400
committerLibravatarUnit 193 <unit193@ubuntu.com>2018-07-27 23:54:15 -0400
commit6d3d39356473078c6b47e03b8a7616e4b34de928 (patch)
treefe5be2e6a08e4cfc73207746aba4c9fccfecfa10 /SQLiteStudio3/Tests/LexerTest/tst_lexertest.cpp
parentf98e49169a40876bcf1df832de6e908d1b350193 (diff)
parentfeda8a7db8d1d7c5439aa8f8feef7cc0dd2b59a0 (diff)
Update upstream source from tag 'upstream/3.2.1+dfsg1'
Update to upstream version '3.2.1+dfsg1' with Debian dir 5ea0333565de4dc898c062cc0ff4ba1153e2c1e4
Diffstat (limited to 'SQLiteStudio3/Tests/LexerTest/tst_lexertest.cpp')
-rw-r--r--SQLiteStudio3/Tests/LexerTest/tst_lexertest.cpp66
1 files changed, 66 insertions, 0 deletions
diff --git a/SQLiteStudio3/Tests/LexerTest/tst_lexertest.cpp b/SQLiteStudio3/Tests/LexerTest/tst_lexertest.cpp
new file mode 100644
index 0000000..deac898
--- /dev/null
+++ b/SQLiteStudio3/Tests/LexerTest/tst_lexertest.cpp
@@ -0,0 +1,66 @@
+#include "parser/lexer.h"
+#include <QString>
+#include <QtTest>
+
+class LexerTest : public QObject
+{
+ Q_OBJECT
+
+ public:
+ LexerTest();
+
+ private Q_SLOTS:
+ void testStringCase1();
+ void testFloat();
+ void testHex1();
+ void testHex2();
+};
+
+LexerTest::LexerTest()
+{
+}
+
+void LexerTest::testStringCase1()
+{
+ QString sql = "INSERT INTO tab VALUES (1, 2, :val); /* test";
+
+ Lexer lex(Dialect::Sqlite3);
+ TokenList tokens = lex.tokenize(sql);
+ QVERIFY(tokens.size() == 20);
+}
+
+void LexerTest::testFloat()
+{
+ QString sql = "SELECT .2";
+
+ Lexer lex(Dialect::Sqlite3);
+ TokenList tokens = lex.tokenize(sql);
+ QVERIFY(tokens.size() == 3);
+ QVERIFY(tokens[2]->type == Token::FLOAT);
+}
+
+void LexerTest::testHex1()
+{
+ QString sql = "SELECT 0x";
+
+ Lexer lex(Dialect::Sqlite3);
+ TokenList tokens = lex.tokenize(sql);
+ QVERIFY(tokens.size() == 3);
+ QVERIFY(tokens[2]->type == Token::INVALID);
+}
+
+void LexerTest::testHex2()
+{
+ QString sql = "SELECT 0x5zzz";
+
+ Lexer lex(Dialect::Sqlite3);
+ TokenList tokens = lex.tokenize(sql);
+ QVERIFY(tokens.size() == 4);
+ QVERIFY(tokens[2]->type == Token::INTEGER);
+ QVERIFY(tokens[3]->type == Token::OTHER);
+ QVERIFY(tokens[3]->value == "zzz");
+}
+
+QTEST_APPLESS_MAIN(LexerTest)
+
+#include "tst_lexertest.moc"