support writebatch count

master
siddontang 9 years ago committed by Karl Hobley
parent 12259e0c1b
commit ee7483204c
  1. 9
      src/rocksdb.rs

@ -759,6 +759,12 @@ impl Writable for DB {
} }
} }
impl WriteBatch {
pub fn count(&self) -> usize {
unsafe { rocksdb_ffi::rocksdb_writebatch_count(self.inner) as usize }
}
}
impl Default for WriteBatch { impl Default for WriteBatch {
fn default() -> WriteBatch { fn default() -> WriteBatch {
WriteBatch { WriteBatch {
@ -972,7 +978,9 @@ fn writebatch_works() {
// test put // test put
let batch = WriteBatch::default(); let batch = WriteBatch::default();
assert!(db.get(b"k1").unwrap().is_none()); assert!(db.get(b"k1").unwrap().is_none());
assert_eq!(batch.count(), 0);
let _ = batch.put(b"k1", b"v1111"); let _ = batch.put(b"k1", b"v1111");
assert_eq!(batch.count(), 1);
assert!(db.get(b"k1").unwrap().is_none()); assert!(db.get(b"k1").unwrap().is_none());
let p = db.write(batch); let p = db.write(batch);
assert!(p.is_ok()); assert!(p.is_ok());
@ -983,6 +991,7 @@ fn writebatch_works() {
// test delete // test delete
let batch = WriteBatch::default(); let batch = WriteBatch::default();
let _ = batch.delete(b"k1"); let _ = batch.delete(b"k1");
assert_eq!(batch.count(), 1);
let p = db.write(batch); let p = db.write(batch);
assert!(p.is_ok()); assert!(p.is_ok());
assert!(db.get(b"k1").unwrap().is_none()); assert!(db.get(b"k1").unwrap().is_none());

Loading…
Cancel
Save