aboutsummaryrefslogtreecommitdiff
path: root/all_test.go
diff options
context:
space:
mode:
authorJan Mercl <0xjnml@gmail.com>2017-06-13 15:18:34 +0200
committerJan Mercl <0xjnml@gmail.com>2017-06-13 15:18:34 +0200
commit11216f730451a292847505d464294ed7cf2c05c4 (patch)
tree6a4a698a908984439a496b5df452f0e36b4a82e5 /all_test.go
parentec1aabd88adb1660d33f8ca47a56633773de98f6 (diff)
Do not use fixed heap on Linux. Updates #12.
modified: all_test.go modified: generator.go modified: internal/bin/bin_linux_386.go modified: internal/bin/bin_linux_amd64.go modified: main.c modified: sqlite.go modified: sqlite_go18.go
Diffstat (limited to 'all_test.go')
-rw-r--r--all_test.go36
1 files changed, 36 insertions, 0 deletions
diff --git a/all_test.go b/all_test.go
index ae09653..0697a0a 100644
--- a/all_test.go
+++ b/all_test.go
@@ -312,3 +312,39 @@ func TestIssue11(t *testing.T) {
t.Fatal(err)
}
}
+
+// https://github.com/cznic/sqlite/issues/12
+func TestMemDB(t *testing.T) {
+ // Verify we can create out-of-the heap memory DB instance.
+ db, err := sql.Open(driverName, "file::memory:")
+ if err != nil {
+ t.Fatal(err)
+ }
+
+ defer func() {
+ db.Close()
+ }()
+
+ v := strings.Repeat("a", 1024)
+ if _, err := db.Exec(`
+ create table t(s string);
+ begin;
+ `); err != nil {
+ t.Fatal(err)
+ }
+
+ s, err := db.Prepare("insert into t values(?)")
+ if err != nil {
+ t.Fatal(err)
+ }
+
+ // Heap used to be fixed at 32MB.
+ for i := 0; i < (64<<20)/len(v); i++ {
+ if _, err := s.Exec(v); err != nil {
+ t.Fatalf("%v * %v= %v: %v", i, len(v), i*len(v), err)
+ }
+ }
+ if _, err := db.Exec(`commit;`); err != nil {
+ t.Fatal(err)
+ }
+}