Bug fix: Remove min/1000 in tx:delp (#3167)

This commit is contained in:
Emmanuel Keller 2023-12-15 21:53:04 +00:00 committed by GitHub
parent e5fb44fabd
commit c9f037f7a6
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 59 additions and 8 deletions

View file

@ -1,8 +1,8 @@
use crate::err::Error; use crate::err::Error;
use crate::idx::trees::bkeys::TrieKeys; use crate::idx::trees::bkeys::TrieKeys;
use crate::idx::trees::btree::{BStatistics, BTree, BTreeStore}; use crate::idx::trees::btree::{BState, BStatistics, BTree, BTreeStore};
use crate::idx::trees::store::{IndexStores, TreeNodeProvider}; use crate::idx::trees::store::{IndexStores, TreeNodeProvider};
use crate::idx::{trees, IndexKeyBase, VersionedSerdeState}; use crate::idx::{IndexKeyBase, VersionedSerdeState};
use crate::kvs::{Key, Transaction, TransactionType}; use crate::kvs::{Key, Transaction, TransactionType};
use revision::revisioned; use revision::revisioned;
use roaring::RoaringTreemap; use roaring::RoaringTreemap;
@ -154,7 +154,7 @@ impl DocIds {
#[derive(Serialize, Deserialize)] #[derive(Serialize, Deserialize)]
#[revisioned(revision = 1)] #[revisioned(revision = 1)]
struct State { struct State {
btree: trees::btree::BState, btree: BState,
available_ids: Option<RoaringTreemap>, available_ids: Option<RoaringTreemap>,
next_doc_id: DocId, next_doc_id: DocId,
} }
@ -164,7 +164,7 @@ impl VersionedSerdeState for State {}
impl State { impl State {
fn new(default_btree_order: u32) -> Self { fn new(default_btree_order: u32) -> Self {
Self { Self {
btree: trees::btree::BState::new(default_btree_order), btree: BState::new(default_btree_order),
available_ids: None, available_ids: None,
next_doc_id: 0, next_doc_id: 0,
} }

View file

@ -155,14 +155,23 @@ impl State {
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use crate::idx::ft::postings::TermFrequency; use crate::idx::ft::postings::TermFrequency;
use crate::idx::ft::terms::Terms; use crate::idx::ft::terms::{State, Terms};
use crate::idx::IndexKeyBase; use crate::idx::{IndexKeyBase, VersionedSerdeState};
use crate::kvs::TransactionType::{Read, Write}; use crate::kvs::TransactionType::{Read, Write};
use crate::kvs::{Datastore, LockType::*, Transaction, TransactionType}; use crate::kvs::{Datastore, LockType::*, Transaction, TransactionType};
use rand::{thread_rng, Rng}; use rand::{thread_rng, Rng};
use std::collections::HashSet; use std::collections::HashSet;
use test_log::test; use test_log::test;
#[test]
fn test_state_serde() {
let s = State::new(3);
let val = s.try_to_val().unwrap();
let s = State::try_from_val(val).unwrap();
assert_eq!(s.btree.generation(), 0);
assert_eq!(s.next_term_id, 0);
}
fn random_term(key_length: usize) -> String { fn random_term(key_length: usize) -> String {
thread_rng() thread_rng()
.sample_iter(&rand::distributions::Alphanumeric) .sample_iter(&rand::distributions::Alphanumeric)

View file

@ -964,8 +964,7 @@ impl Transaction {
let end: Key = beg.clone().add(0xff); let end: Key = beg.clone().add(0xff);
let min = beg.clone(); let min = beg.clone();
let max = end.clone(); let max = end.clone();
let num = std::cmp::min(1000, limit); self.delr(min..max, limit).await?;
self.delr(min..max, num).await?;
Ok(()) Ok(())
} }
@ -2886,6 +2885,8 @@ impl Transaction {
#[cfg(test)] #[cfg(test)]
#[cfg(feature = "kv-mem")] #[cfg(feature = "kv-mem")]
mod tests { mod tests {
use crate::key::database::all::All;
use crate::key::database::tb::Tb;
use crate::{ use crate::{
kvs::{Datastore, LockType::*, TransactionType::*}, kvs::{Datastore, LockType::*, TransactionType::*},
sql::{statements::DefineUserStatement, Base}, sql::{statements::DefineUserStatement, Base},
@ -3095,4 +3096,45 @@ mod tests {
txn.complete_changes(false).await.unwrap(); txn.complete_changes(false).await.unwrap();
txn.commit().await.unwrap(); txn.commit().await.unwrap();
} }
#[tokio::test]
async fn test_delp() {
let ds = Datastore::new("memory").await.unwrap();
// Create entries
{
let mut txn = ds.transaction(Write, Optimistic).await.unwrap();
for i in 0..2500 {
let t = format!("{i}");
let tb = Tb::new("test", "test", &t);
txn.set(tb, vec![]).await.unwrap();
}
txn.commit().await.unwrap();
}
let beg = crate::key::database::tb::prefix("test", "test");
let end = crate::key::database::tb::suffix("test", "test");
let rng = beg..end;
// Check we have the table keys
{
let mut txn = ds.transaction(Read, Optimistic).await.unwrap();
let res = txn.getr(rng.clone(), u32::MAX).await.unwrap();
assert_eq!(res.len(), 2500);
}
// Delete using the prefix
{
let mut txn = ds.transaction(Write, Optimistic).await.unwrap();
let all = All::new("test", "test");
txn.delp(all, u32::MAX).await.unwrap();
txn.commit().await.unwrap();
}
// Check we don't have any table key anymore
{
let mut txn = ds.transaction(Read, Optimistic).await.unwrap();
let res = txn.getr(rng, u32::MAX).await.unwrap();
assert_eq!(res.len(), 0);
}
}
} }