BlockSize: 80, Compression: opt.NoCompression, OpenFilesCacheCapacity: -1, Strict: opt.StrictAll, WriteBuffer: 1000, CompactionTableSize: 2000, } Describe("write test", func() { It("should do write correctly", func(done Done) { db := newTestingDB(o, nil, nil) t := testutil.DBTesting{ DB: db, Deleted: testutil.KeyValue_Generate(nil, 500, 1, 50, 5, 5).Clone(), } testutil.DoDBTesting(&t) db.TestClose() done <- true }, 20.0) }) Describe("read test", func() { testutil.AllKeyValueTesting(nil, nil, func(kv testutil.KeyValue) testutil.DB { // Building the DB. db := newTestingDB(o, nil, nil) kv.IterateShuffled(nil, func(i int, key, value []byte) { err := db.TestPut(key, value) Expect(err).NotTo(HaveOccurred()) }) return db
db := New(comparer.DefaultComparer, 0) t := testutil.DBTesting{ DB: db, Deleted: testutil.KeyValue_Generate(nil, 1000, 1, 30, 5, 5).Clone(), PostFn: func(t *testutil.DBTesting) { Expect(db.Len()).Should(Equal(t.Present.Len())) Expect(db.Size()).Should(Equal(t.Present.Size())) switch t.Act { case testutil.DBPut, testutil.DBOverwrite: Expect(db.Contains(t.ActKey)).Should(BeTrue()) default: Expect(db.Contains(t.ActKey)).Should(BeFalse()) } }, } testutil.DoDBTesting(&t) }) }) Describe("read test", func() { testutil.AllKeyValueTesting(nil, func(kv testutil.KeyValue) testutil.DB { // Building the DB. db := New(comparer.DefaultComparer, 0) kv.IterateShuffled(nil, func(i int, key, value []byte) { db.Put(key, value) }) if kv.Len() > 1 { It("Should find correct keys with findLT", func() { testutil.ShuffledIndex(nil, kv.Len()-1, 1, func(i int) { key_, key, _ := kv.IndexInexact(i + 1)