Merge pull request #249 from barakmich/fix_bolt
Fix bug where first Bolt iteration ignores deletion
This commit is contained in:
commit
3a7da9f2a0
2 changed files with 48 additions and 6 deletions
|
|
@ -465,3 +465,43 @@ func TestOptimize(t *testing.T) {
|
||||||
t.Errorf("Discordant tag results, new:%v old:%v", newResults, oldResults)
|
t.Errorf("Discordant tag results, new:%v old:%v", newResults, oldResults)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestDeletedFromIterator(t *testing.T) {
|
||||||
|
|
||||||
|
tmpFile, _ := ioutil.TempFile(os.TempDir(), "cayley_test")
|
||||||
|
t.Log(tmpFile.Name())
|
||||||
|
defer os.RemoveAll(tmpFile.Name())
|
||||||
|
err := createNewBolt(tmpFile.Name(), nil)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Failed to create working directory")
|
||||||
|
}
|
||||||
|
|
||||||
|
qs, err := newQuadStore(tmpFile.Name(), nil)
|
||||||
|
if qs == nil || err != nil {
|
||||||
|
t.Error("Failed to create leveldb QuadStore.")
|
||||||
|
}
|
||||||
|
defer qs.Close()
|
||||||
|
|
||||||
|
w, _ := writer.NewSingleReplication(qs, nil)
|
||||||
|
w.AddQuadSet(makeQuadSet())
|
||||||
|
|
||||||
|
expect := []quad.Quad{
|
||||||
|
{"E", "follows", "F", ""},
|
||||||
|
}
|
||||||
|
sort.Sort(ordered(expect))
|
||||||
|
|
||||||
|
// Subject iterator.
|
||||||
|
it := qs.QuadIterator(quad.Subject, qs.ValueOf("E"))
|
||||||
|
|
||||||
|
if got := iteratedQuads(qs, it); !reflect.DeepEqual(got, expect) {
|
||||||
|
t.Errorf("Failed to get expected results, got:%v expect:%v", got, expect)
|
||||||
|
}
|
||||||
|
it.Reset()
|
||||||
|
|
||||||
|
w.RemoveQuad(quad.Quad{"E", "follows", "F", ""})
|
||||||
|
expect = nil
|
||||||
|
|
||||||
|
if got := iteratedQuads(qs, it); !reflect.DeepEqual(got, expect) {
|
||||||
|
t.Errorf("Failed to get expected results, got:%v expect:%v", got, expect)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -135,13 +135,15 @@ func (it *Iterator) Next() bool {
|
||||||
b := tx.Bucket(it.bucket)
|
b := tx.Bucket(it.bucket)
|
||||||
cur := b.Cursor()
|
cur := b.Cursor()
|
||||||
if last == nil {
|
if last == nil {
|
||||||
k, _ := cur.Seek(it.checkID)
|
k, v := cur.Seek(it.checkID)
|
||||||
if bytes.HasPrefix(k, it.checkID) {
|
if bytes.HasPrefix(k, it.checkID) {
|
||||||
var out []byte
|
if it.isLiveValue(v) {
|
||||||
out = make([]byte, len(k))
|
var out []byte
|
||||||
copy(out, k)
|
out = make([]byte, len(k))
|
||||||
it.buffer = append(it.buffer, out)
|
copy(out, k)
|
||||||
i++
|
it.buffer = append(it.buffer, out)
|
||||||
|
i++
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
it.buffer = append(it.buffer, nil)
|
it.buffer = append(it.buffer, nil)
|
||||||
return errNotExist
|
return errNotExist
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue