mirror of https://github.com/etcd-io/bbolt.git
Fix Cursor.Last() on empty buckets.
@tv42 reported that creating a cursor on an empty bucket and then calling Cursor.Last() causes an index out of range error and panics. This commit adds a check for the page's item count being greater than zero. Fixes #63.pull/34/head
parent
b9b69d867a
commit
4132080333
|
@ -235,7 +235,7 @@ func (c *Cursor) nsearch(key []byte) {
|
||||||
// keyValue returns the key and value of the current leaf element.
|
// keyValue returns the key and value of the current leaf element.
|
||||||
func (c *Cursor) keyValue() ([]byte, []byte) {
|
func (c *Cursor) keyValue() ([]byte, []byte) {
|
||||||
ref := &c.stack[len(c.stack)-1]
|
ref := &c.stack[len(c.stack)-1]
|
||||||
if ref.index >= ref.count() {
|
if ref.count() == 0 || ref.index >= ref.count() {
|
||||||
return nil, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
27
tx_test.go
27
tx_test.go
|
@ -190,12 +190,27 @@ func TestTxDeleteBucketNotFound(t *testing.T) {
|
||||||
func TestTxCursorEmptyBucket(t *testing.T) {
|
func TestTxCursorEmptyBucket(t *testing.T) {
|
||||||
withOpenDB(func(db *DB, path string) {
|
withOpenDB(func(db *DB, path string) {
|
||||||
db.CreateBucket("widgets")
|
db.CreateBucket("widgets")
|
||||||
tx, _ := db.Tx()
|
db.With(func(tx *Tx) error {
|
||||||
c := tx.Bucket("widgets").Cursor()
|
c := tx.Bucket("widgets").Cursor()
|
||||||
k, v := c.First()
|
k, v := c.First()
|
||||||
assert.Nil(t, k)
|
assert.Nil(t, k)
|
||||||
assert.Nil(t, v)
|
assert.Nil(t, v)
|
||||||
tx.Commit()
|
return nil
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// Ensure that a Tx cursor can reverse iterate over an empty bucket without error.
|
||||||
|
func TestCursorEmptyBucketReverse(t *testing.T) {
|
||||||
|
withOpenDB(func(db *DB, path string) {
|
||||||
|
db.CreateBucket("widgets")
|
||||||
|
db.With(func(tx *Tx) error {
|
||||||
|
c := tx.Bucket("widgets").Cursor()
|
||||||
|
k, v := c.Last()
|
||||||
|
assert.Nil(t, k)
|
||||||
|
assert.Nil(t, v)
|
||||||
|
return nil
|
||||||
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue