diff options
author | Jan Mercl <0xjnml@gmail.com> | 2017-06-13 15:18:34 +0200 |
---|---|---|
committer | Jan Mercl <0xjnml@gmail.com> | 2017-06-13 15:18:34 +0200 |
commit | 11216f730451a292847505d464294ed7cf2c05c4 (patch) | |
tree | 6a4a698a908984439a496b5df452f0e36b4a82e5 /all_test.go | |
parent | ec1aabd88adb1660d33f8ca47a56633773de98f6 (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.go | 36 |
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) + } +} |