aboutsummaryrefslogtreecommitdiff
path: root/sqlite3_test.go
diff options
context:
space:
mode:
authorEgon Elbre <egonelbre@gmail.com>2015-04-12 14:59:29 +0300
committerEgon Elbre <egonelbre@gmail.com>2015-04-12 15:02:50 +0300
commitac0129617fd4293e7c341a48bba2adfc85f5afe1 (patch)
tree177fc5461f6bd05dc6376d4b51b9086de388f5df /sqlite3_test.go
parentMerge pull request #188 from larsmans/optimize (diff)
downloadgolite-ac0129617fd4293e7c341a48bba2adfc85f5afe1.tar.gz
golite-ac0129617fd4293e7c341a48bba2adfc85f5afe1.tar.xz
Fix NULs in text.
NUL character is a valid symbols in UTF8. Fixes #195
Diffstat (limited to '')
-rw-r--r--sqlite3_test.go39
1 files changed, 39 insertions, 0 deletions
diff --git a/sqlite3_test.go b/sqlite3_test.go
index aa86011..44e00f1 100644
--- a/sqlite3_test.go
+++ b/sqlite3_test.go
@@ -945,3 +945,42 @@ func TestNumberNamedParams(t *testing.T) {
t.Error("Failed to db.QueryRow: not matched results")
}
}
+
+func TestStringContainingZero(t *testing.T) {
+ tempFilename := TempFilename()
+ db, err := sql.Open("sqlite3", tempFilename)
+ if err != nil {
+ t.Fatal("Failed to open database:", err)
+ }
+ defer os.Remove(tempFilename)
+ defer db.Close()
+
+ _, err = db.Exec(`
+ create table foo (id integer, name, extra text);
+ `)
+ if err != nil {
+ t.Error("Failed to call db.Query:", err)
+ }
+
+ const text = "foo\x00bar"
+
+ _, err = db.Exec(`insert into foo(id, name, extra) values($1, $2, $2)`, 1, text)
+ if err != nil {
+ t.Error("Failed to call db.Exec:", err)
+ }
+
+ row := db.QueryRow(`select id, extra from foo where id = $1 and extra = $2`, 1, text)
+ if row == nil {
+ t.Error("Failed to call db.QueryRow")
+ }
+
+ var id int
+ var extra string
+ err = row.Scan(&id, &extra)
+ if err != nil {
+ t.Error("Failed to db.Scan:", err)
+ }
+ if id != 1 || extra != text {
+ t.Error("Failed to db.QueryRow: not matched results")
+ }
+}