aboutsummaryrefslogtreecommitdiff
path: root/weed/util/sqlutil/splitter_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'weed/util/sqlutil/splitter_test.go')
-rw-r--r--weed/util/sqlutil/splitter_test.go147
1 files changed, 147 insertions, 0 deletions
diff --git a/weed/util/sqlutil/splitter_test.go b/weed/util/sqlutil/splitter_test.go
new file mode 100644
index 000000000..91fac6196
--- /dev/null
+++ b/weed/util/sqlutil/splitter_test.go
@@ -0,0 +1,147 @@
+package sqlutil
+
+import (
+ "reflect"
+ "testing"
+)
+
+func TestSplitStatements(t *testing.T) {
+ tests := []struct {
+ name string
+ input string
+ expected []string
+ }{
+ {
+ name: "Simple single statement",
+ input: "SELECT * FROM users",
+ expected: []string{"SELECT * FROM users"},
+ },
+ {
+ name: "Multiple statements",
+ input: "SELECT * FROM users; SELECT * FROM orders;",
+ expected: []string{"SELECT * FROM users", "SELECT * FROM orders"},
+ },
+ {
+ name: "Semicolon in single quotes",
+ input: "SELECT 'hello;world' FROM users; SELECT * FROM orders;",
+ expected: []string{"SELECT 'hello;world' FROM users", "SELECT * FROM orders"},
+ },
+ {
+ name: "Semicolon in double quotes",
+ input: `SELECT "column;name" FROM users; SELECT * FROM orders;`,
+ expected: []string{`SELECT "column;name" FROM users`, "SELECT * FROM orders"},
+ },
+ {
+ name: "Escaped quotes in strings",
+ input: `SELECT 'don''t split; here' FROM users; SELECT * FROM orders;`,
+ expected: []string{`SELECT 'don''t split; here' FROM users`, "SELECT * FROM orders"},
+ },
+ {
+ name: "Escaped quotes in identifiers",
+ input: `SELECT "column""name" FROM users; SELECT * FROM orders;`,
+ expected: []string{`SELECT "column""name" FROM users`, "SELECT * FROM orders"},
+ },
+ {
+ name: "Single line comment",
+ input: "SELECT * FROM users; -- This is a comment\nSELECT * FROM orders;",
+ expected: []string{"SELECT * FROM users", "SELECT * FROM orders"},
+ },
+ {
+ name: "Single line comment with semicolon",
+ input: "SELECT * FROM users; -- Comment with; semicolon\nSELECT * FROM orders;",
+ expected: []string{"SELECT * FROM users", "SELECT * FROM orders"},
+ },
+ {
+ name: "Multi-line comment",
+ input: "SELECT * FROM users; /* Multi-line\ncomment */ SELECT * FROM orders;",
+ expected: []string{"SELECT * FROM users", "SELECT * FROM orders"},
+ },
+ {
+ name: "Multi-line comment with semicolon",
+ input: "SELECT * FROM users; /* Comment with; semicolon */ SELECT * FROM orders;",
+ expected: []string{"SELECT * FROM users", "SELECT * FROM orders"},
+ },
+ {
+ name: "Complex mixed case",
+ input: `SELECT 'test;string', "quoted;id" FROM users; -- Comment; here
+ /* Another; comment */
+ INSERT INTO users VALUES ('name''s value', "id""field");`,
+ expected: []string{
+ `SELECT 'test;string', "quoted;id" FROM users`,
+ `INSERT INTO users VALUES ('name''s value', "id""field")`,
+ },
+ },
+ {
+ name: "Empty statements filtered",
+ input: "SELECT * FROM users;;; SELECT * FROM orders;",
+ expected: []string{"SELECT * FROM users", "SELECT * FROM orders"},
+ },
+ {
+ name: "Whitespace handling",
+ input: " SELECT * FROM users ; SELECT * FROM orders ; ",
+ expected: []string{"SELECT * FROM users", "SELECT * FROM orders"},
+ },
+ {
+ name: "Single statement without semicolon",
+ input: "SELECT * FROM users",
+ expected: []string{"SELECT * FROM users"},
+ },
+ {
+ name: "Empty query",
+ input: "",
+ expected: []string{},
+ },
+ {
+ name: "Only whitespace",
+ input: " \n\t ",
+ expected: []string{},
+ },
+ }
+
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ result := SplitStatements(tt.input)
+ if !reflect.DeepEqual(result, tt.expected) {
+ t.Errorf("SplitStatements() = %v, expected %v", result, tt.expected)
+ }
+ })
+ }
+}
+
+func TestSplitStatements_EdgeCases(t *testing.T) {
+ tests := []struct {
+ name string
+ input string
+ expected []string
+ }{
+ {
+ name: "Nested comments are not supported but handled gracefully",
+ input: "SELECT * FROM users; /* Outer /* inner */ comment */ SELECT * FROM orders;",
+ expected: []string{"SELECT * FROM users", "comment */ SELECT * FROM orders"},
+ },
+ {
+ name: "Unterminated string (malformed SQL)",
+ input: "SELECT 'unterminated string; SELECT * FROM orders;",
+ expected: []string{"SELECT 'unterminated string; SELECT * FROM orders;"},
+ },
+ {
+ name: "Unterminated comment (malformed SQL)",
+ input: "SELECT * FROM users; /* unterminated comment",
+ expected: []string{"SELECT * FROM users"},
+ },
+ {
+ name: "Multiple semicolons in quotes",
+ input: "SELECT ';;;' FROM users; SELECT ';;;' FROM orders;",
+ expected: []string{"SELECT ';;;' FROM users", "SELECT ';;;' FROM orders"},
+ },
+ }
+
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ result := SplitStatements(tt.input)
+ if !reflect.DeepEqual(result, tt.expected) {
+ t.Errorf("SplitStatements() = %v, expected %v", result, tt.expected)
+ }
+ })
+ }
+}