package db import ( "fmt" "testing" "github.com/stretchr/testify/assert" ) func TestDBIteratorSingleKey(t *testing.T) { for backend := range backends { t.Run(fmt.Sprintf("Backend %s", backend), func(t *testing.T) { db := newTempDB(t, backend) db.SetSync(bz("1"), bz("value_1")) itr := db.Iterator(nil, nil) checkValid(t, itr, true) checkNext(t, itr, false) checkValid(t, itr, false) checkNextPanics(t, itr) // Once invalid... checkInvalid(t, itr) }) } } func TestDBIteratorTwoKeys(t *testing.T) { for backend := range backends { t.Run(fmt.Sprintf("Backend %s", backend), func(t *testing.T) { db := newTempDB(t, backend) db.SetSync(bz("1"), bz("value_1")) db.SetSync(bz("2"), bz("value_1")) { // Fail by calling Next too much itr := db.Iterator(nil, nil) checkValid(t, itr, true) checkNext(t, itr, true) checkValid(t, itr, true) checkNext(t, itr, false) checkValid(t, itr, false) checkNextPanics(t, itr) // Once invalid... checkInvalid(t, itr) } }) } } func TestDBIteratorMany(t *testing.T) { for backend := range backends { t.Run(fmt.Sprintf("Backend %s", backend), func(t *testing.T) { db := newTempDB(t, backend) keys := make([][]byte, 100) for i := 0; i < 100; i++ { keys[i] = []byte{byte(i)} } value := []byte{5} for _, k := range keys { db.Set(k, value) } itr := db.Iterator(nil, nil) defer itr.Close() for ; itr.Valid(); itr.Next() { assert.Equal(t, db.Get(itr.Key()), itr.Value()) } }) } } func TestDBIteratorEmpty(t *testing.T) { for backend := range backends { t.Run(fmt.Sprintf("Backend %s", backend), func(t *testing.T) { db := newTempDB(t, backend) itr := db.Iterator(nil, nil) checkInvalid(t, itr) }) } } func TestDBIteratorEmptyBeginAfter(t *testing.T) { for backend := range backends { t.Run(fmt.Sprintf("Backend %s", backend), func(t *testing.T) { db := newTempDB(t, backend) itr := db.Iterator(bz("1"), nil) checkInvalid(t, itr) }) } } func TestDBIteratorNonemptyBeginAfter(t *testing.T) { for backend := range backends { t.Run(fmt.Sprintf("Backend %s", backend), func(t *testing.T) { db := newTempDB(t, backend) db.SetSync(bz("1"), bz("value_1")) itr := db.Iterator(bz("2"), nil) checkInvalid(t, itr) }) } } func TestDBBatchWrite1(t *testing.T) { mdb := newMockDB() ddb := NewDebugDB(t.Name(), mdb) batch := ddb.NewBatch() batch.Set(bz("1"), bz("1")) batch.Set(bz("2"), bz("2")) batch.Delete(bz("3")) batch.Set(bz("4"), bz("4")) batch.Write() assert.Equal(t, 0, mdb.calls["Set"]) assert.Equal(t, 0, mdb.calls["SetSync"]) assert.Equal(t, 3, mdb.calls["SetNoLock"]) assert.Equal(t, 0, mdb.calls["SetNoLockSync"]) assert.Equal(t, 0, mdb.calls["Delete"]) assert.Equal(t, 0, mdb.calls["DeleteSync"]) assert.Equal(t, 1, mdb.calls["DeleteNoLock"]) assert.Equal(t, 0, mdb.calls["DeleteNoLockSync"]) } func TestDBBatchWrite2(t *testing.T) { mdb := newMockDB() ddb := NewDebugDB(t.Name(), mdb) batch := ddb.NewBatch() batch.Set(bz("1"), bz("1")) batch.Set(bz("2"), bz("2")) batch.Set(bz("4"), bz("4")) batch.Delete(bz("3")) batch.Write() assert.Equal(t, 0, mdb.calls["Set"]) assert.Equal(t, 0, mdb.calls["SetSync"]) assert.Equal(t, 3, mdb.calls["SetNoLock"]) assert.Equal(t, 0, mdb.calls["SetNoLockSync"]) assert.Equal(t, 0, mdb.calls["Delete"]) assert.Equal(t, 0, mdb.calls["DeleteSync"]) assert.Equal(t, 1, mdb.calls["DeleteNoLock"]) assert.Equal(t, 0, mdb.calls["DeleteNoLockSync"]) } func TestDBBatchWriteSync1(t *testing.T) { mdb := newMockDB() ddb := NewDebugDB(t.Name(), mdb) batch := ddb.NewBatch() batch.Set(bz("1"), bz("1")) batch.Set(bz("2"), bz("2")) batch.Delete(bz("3")) batch.Set(bz("4"), bz("4")) batch.WriteSync() assert.Equal(t, 0, mdb.calls["Set"]) assert.Equal(t, 0, mdb.calls["SetSync"]) assert.Equal(t, 2, mdb.calls["SetNoLock"]) assert.Equal(t, 1, mdb.calls["SetNoLockSync"]) assert.Equal(t, 0, mdb.calls["Delete"]) assert.Equal(t, 0, mdb.calls["DeleteSync"]) assert.Equal(t, 1, mdb.calls["DeleteNoLock"]) assert.Equal(t, 0, mdb.calls["DeleteNoLockSync"]) } func TestDBBatchWriteSync2(t *testing.T) { mdb := newMockDB() ddb := NewDebugDB(t.Name(), mdb) batch := ddb.NewBatch() batch.Set(bz("1"), bz("1")) batch.Set(bz("2"), bz("2")) batch.Set(bz("4"), bz("4")) batch.Delete(bz("3")) batch.WriteSync() assert.Equal(t, 0, mdb.calls["Set"]) assert.Equal(t, 0, mdb.calls["SetSync"]) assert.Equal(t, 3, mdb.calls["SetNoLock"]) assert.Equal(t, 0, mdb.calls["SetNoLockSync"]) assert.Equal(t, 0, mdb.calls["Delete"]) assert.Equal(t, 0, mdb.calls["DeleteSync"]) assert.Equal(t, 0, mdb.calls["DeleteNoLock"]) assert.Equal(t, 1, mdb.calls["DeleteNoLockSync"]) }