mirror of
https://github.com/meilisearch/meilisearch.git
synced 2025-10-24 04:26:27 +00:00
Remove soft-deleted related methods from Index
This commit is contained in:
@@ -324,7 +324,6 @@ impl ErrorCode for milli::Error {
|
|||||||
UserError::SerdeJson(_)
|
UserError::SerdeJson(_)
|
||||||
| UserError::InvalidLmdbOpenOptions
|
| UserError::InvalidLmdbOpenOptions
|
||||||
| UserError::DocumentLimitReached
|
| UserError::DocumentLimitReached
|
||||||
| UserError::AccessingSoftDeletedDocument { .. }
|
|
||||||
| UserError::UnknownInternalDocumentId { .. } => Code::Internal,
|
| UserError::UnknownInternalDocumentId { .. } => Code::Internal,
|
||||||
UserError::InvalidStoreFile => Code::InvalidStoreFile,
|
UserError::InvalidStoreFile => Code::InvalidStoreFile,
|
||||||
UserError::NoSpaceLeftOnDevice => Code::NoSpaceLeftOnDevice,
|
UserError::NoSpaceLeftOnDevice => Code::NoSpaceLeftOnDevice,
|
||||||
|
@@ -89,8 +89,6 @@ pub enum FieldIdMapMissingEntry {
|
|||||||
|
|
||||||
#[derive(Error, Debug)]
|
#[derive(Error, Debug)]
|
||||||
pub enum UserError {
|
pub enum UserError {
|
||||||
#[error("A soft deleted internal document id have been used: `{document_id}`.")]
|
|
||||||
AccessingSoftDeletedDocument { document_id: DocumentId },
|
|
||||||
#[error("A document cannot contain more than 65,535 fields.")]
|
#[error("A document cannot contain more than 65,535 fields.")]
|
||||||
AttributeLimitReached,
|
AttributeLimitReached,
|
||||||
#[error(transparent)]
|
#[error(transparent)]
|
||||||
|
@@ -40,7 +40,6 @@ pub mod main_key {
|
|||||||
pub const DISPLAYED_FIELDS_KEY: &str = "displayed-fields";
|
pub const DISPLAYED_FIELDS_KEY: &str = "displayed-fields";
|
||||||
pub const DISTINCT_FIELD_KEY: &str = "distinct-field-key";
|
pub const DISTINCT_FIELD_KEY: &str = "distinct-field-key";
|
||||||
pub const DOCUMENTS_IDS_KEY: &str = "documents-ids";
|
pub const DOCUMENTS_IDS_KEY: &str = "documents-ids";
|
||||||
pub const SOFT_DELETED_DOCUMENTS_IDS_KEY: &str = "soft-deleted-documents-ids";
|
|
||||||
pub const HIDDEN_FACETED_FIELDS_KEY: &str = "hidden-faceted-fields";
|
pub const HIDDEN_FACETED_FIELDS_KEY: &str = "hidden-faceted-fields";
|
||||||
pub const FILTERABLE_FIELDS_KEY: &str = "filterable-fields";
|
pub const FILTERABLE_FIELDS_KEY: &str = "filterable-fields";
|
||||||
pub const SORTABLE_FIELDS_KEY: &str = "sortable-fields";
|
pub const SORTABLE_FIELDS_KEY: &str = "sortable-fields";
|
||||||
@@ -367,29 +366,6 @@ impl Index {
|
|||||||
Ok(count.unwrap_or_default())
|
Ok(count.unwrap_or_default())
|
||||||
}
|
}
|
||||||
|
|
||||||
/* deleted documents ids */
|
|
||||||
|
|
||||||
/// Writes the soft deleted documents ids.
|
|
||||||
pub(crate) fn put_soft_deleted_documents_ids(
|
|
||||||
&self,
|
|
||||||
wtxn: &mut RwTxn,
|
|
||||||
docids: &RoaringBitmap,
|
|
||||||
) -> heed::Result<()> {
|
|
||||||
self.main.put::<_, Str, RoaringBitmapCodec>(
|
|
||||||
wtxn,
|
|
||||||
main_key::SOFT_DELETED_DOCUMENTS_IDS_KEY,
|
|
||||||
docids,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns the soft deleted documents ids.
|
|
||||||
pub(crate) fn soft_deleted_documents_ids(&self, rtxn: &RoTxn) -> heed::Result<RoaringBitmap> {
|
|
||||||
Ok(self
|
|
||||||
.main
|
|
||||||
.get::<_, Str, RoaringBitmapCodec>(rtxn, main_key::SOFT_DELETED_DOCUMENTS_IDS_KEY)?
|
|
||||||
.unwrap_or_default())
|
|
||||||
}
|
|
||||||
|
|
||||||
/* primary key */
|
/* primary key */
|
||||||
|
|
||||||
/// Writes the documents primary key, this is the field name that is used to store the id.
|
/// Writes the documents primary key, this is the field name that is used to store the id.
|
||||||
@@ -1187,12 +1163,7 @@ impl Index {
|
|||||||
rtxn: &'t RoTxn,
|
rtxn: &'t RoTxn,
|
||||||
ids: impl IntoIterator<Item = DocumentId> + 'a,
|
ids: impl IntoIterator<Item = DocumentId> + 'a,
|
||||||
) -> Result<impl Iterator<Item = Result<(DocumentId, obkv::KvReaderU16<'t>)>> + 'a> {
|
) -> Result<impl Iterator<Item = Result<(DocumentId, obkv::KvReaderU16<'t>)>> + 'a> {
|
||||||
let soft_deleted_documents = self.soft_deleted_documents_ids(rtxn)?;
|
|
||||||
|
|
||||||
Ok(ids.into_iter().map(move |id| {
|
Ok(ids.into_iter().map(move |id| {
|
||||||
if soft_deleted_documents.contains(id) {
|
|
||||||
return Err(UserError::AccessingSoftDeletedDocument { document_id: id })?;
|
|
||||||
}
|
|
||||||
let kv = self
|
let kv = self
|
||||||
.documents
|
.documents
|
||||||
.get(rtxn, &BEU32::new(id))?
|
.get(rtxn, &BEU32::new(id))?
|
||||||
@@ -1418,14 +1389,10 @@ impl Index {
|
|||||||
rtxn: &RoTxn,
|
rtxn: &RoTxn,
|
||||||
key: &(Script, Language),
|
key: &(Script, Language),
|
||||||
) -> heed::Result<Option<RoaringBitmap>> {
|
) -> heed::Result<Option<RoaringBitmap>> {
|
||||||
let soft_deleted_documents = self.soft_deleted_documents_ids(rtxn)?;
|
Ok(self.script_language_docids.get(rtxn, key)?)
|
||||||
let doc_ids = self.script_language_docids.get(rtxn, key)?;
|
|
||||||
Ok(doc_ids.map(|ids| ids - soft_deleted_documents))
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn script_language(&self, rtxn: &RoTxn) -> heed::Result<HashMap<Script, Vec<Language>>> {
|
pub fn script_language(&self, rtxn: &RoTxn) -> heed::Result<HashMap<Script, Vec<Language>>> {
|
||||||
let soft_deleted_documents = self.soft_deleted_documents_ids(rtxn)?;
|
|
||||||
|
|
||||||
let mut script_language: HashMap<Script, Vec<Language>> = HashMap::new();
|
let mut script_language: HashMap<Script, Vec<Language>> = HashMap::new();
|
||||||
let mut script_language_doc_count: Vec<(Script, Language, u64)> = Vec::new();
|
let mut script_language_doc_count: Vec<(Script, Language, u64)> = Vec::new();
|
||||||
let mut total = 0;
|
let mut total = 0;
|
||||||
@@ -1433,7 +1400,7 @@ impl Index {
|
|||||||
let ((script, language), docids) = sl?;
|
let ((script, language), docids) = sl?;
|
||||||
|
|
||||||
// keep only Languages that contains at least 1 document.
|
// keep only Languages that contains at least 1 document.
|
||||||
let remaining_documents_count = (docids - &soft_deleted_documents).len();
|
let remaining_documents_count = docids.len();
|
||||||
total += remaining_documents_count;
|
total += remaining_documents_count;
|
||||||
if remaining_documents_count > 0 {
|
if remaining_documents_count > 0 {
|
||||||
script_language_doc_count.push((script, language, remaining_documents_count));
|
script_language_doc_count.push((script, language, remaining_documents_count));
|
||||||
@@ -1918,7 +1885,6 @@ pub(crate) mod tests {
|
|||||||
2 2
|
2 2
|
||||||
3 3
|
3 3
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 1, @"[]");
|
|
||||||
db_snap!(index, facet_id_f64_docids, 1, @r###"
|
db_snap!(index, facet_id_f64_docids, 1, @r###"
|
||||||
1 0 0 1 [0, ]
|
1 0 0 1 [0, ]
|
||||||
1 0 1 1 [1, ]
|
1 0 1 1 [1, ]
|
||||||
@@ -1943,7 +1909,6 @@ pub(crate) mod tests {
|
|||||||
2 6
|
2 6
|
||||||
3 3
|
3 3
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 2, @"[0, 1, 2, ]");
|
|
||||||
db_snap!(index, facet_id_f64_docids, 2, @r###"
|
db_snap!(index, facet_id_f64_docids, 2, @r###"
|
||||||
1 0 0 1 [0, ]
|
1 0 0 1 [0, ]
|
||||||
1 0 1 1 [1, 4, ]
|
1 0 1 1 [1, 4, ]
|
||||||
@@ -1965,7 +1930,6 @@ pub(crate) mod tests {
|
|||||||
2 6
|
2 6
|
||||||
3 3
|
3 3
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 3, @"[0, 1, 2, 3, ]");
|
|
||||||
db_snap!(index, facet_id_f64_docids, 3, @r###"
|
db_snap!(index, facet_id_f64_docids, 3, @r###"
|
||||||
1 0 0 1 [0, ]
|
1 0 0 1 [0, ]
|
||||||
1 0 1 1 [1, 4, ]
|
1 0 1 1 [1, 4, ]
|
||||||
@@ -1989,7 +1953,6 @@ pub(crate) mod tests {
|
|||||||
2 6
|
2 6
|
||||||
3 7
|
3 7
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 3, @"[]");
|
|
||||||
db_snap!(index, facet_id_f64_docids, 3, @r###"
|
db_snap!(index, facet_id_f64_docids, 3, @r###"
|
||||||
0 0 0 1 [4, ]
|
0 0 0 1 [4, ]
|
||||||
0 0 1 1 [5, ]
|
0 0 1 1 [5, ]
|
||||||
@@ -2052,7 +2015,6 @@ pub(crate) mod tests {
|
|||||||
2 2
|
2 2
|
||||||
3 3
|
3 3
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 1, @"[]");
|
|
||||||
db_snap!(index, facet_id_f64_docids, 1, @r###"
|
db_snap!(index, facet_id_f64_docids, 1, @r###"
|
||||||
1 0 0 1 [0, ]
|
1 0 0 1 [0, ]
|
||||||
1 0 1 1 [1, ]
|
1 0 1 1 [1, ]
|
||||||
@@ -2085,7 +2047,6 @@ pub(crate) mod tests {
|
|||||||
2 6
|
2 6
|
||||||
3 3
|
3 3
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 1, @"[0, 1, 2, ]");
|
|
||||||
db_snap!(index, facet_id_f64_docids, 1, @r###"
|
db_snap!(index, facet_id_f64_docids, 1, @r###"
|
||||||
1 0 0 1 [0, 4, ]
|
1 0 0 1 [0, 4, ]
|
||||||
1 0 1 1 [1, 5, ]
|
1 0 1 1 [1, 5, ]
|
||||||
@@ -2153,7 +2114,6 @@ pub(crate) mod tests {
|
|||||||
2 9
|
2 9
|
||||||
3 3
|
3 3
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 1, @"[0, 1, 2, 4, 5, 6, ]");
|
|
||||||
db_snap!(index, facet_id_f64_docids, 1, @r###"
|
db_snap!(index, facet_id_f64_docids, 1, @r###"
|
||||||
1 0 0 1 [0, 4, 7, ]
|
1 0 0 1 [0, 4, 7, ]
|
||||||
1 0 1 1 [1, 5, 8, ]
|
1 0 1 1 [1, 5, 8, ]
|
||||||
@@ -2221,7 +2181,7 @@ pub(crate) mod tests {
|
|||||||
2 12
|
2 12
|
||||||
3 3
|
3 3
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 1, @"[]");
|
|
||||||
db_snap!(index, facet_id_f64_docids, 1, @r###"
|
db_snap!(index, facet_id_f64_docids, 1, @r###"
|
||||||
1 0 0 1 [10, ]
|
1 0 0 1 [10, ]
|
||||||
1 0 3 1 [3, 11, ]
|
1 0 3 1 [3, 11, ]
|
||||||
@@ -2291,7 +2251,6 @@ pub(crate) mod tests {
|
|||||||
34 1
|
34 1
|
||||||
38 0
|
38 0
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 1, @"[]");
|
|
||||||
|
|
||||||
index.delete_document("34");
|
index.delete_document("34");
|
||||||
|
|
||||||
@@ -2302,7 +2261,6 @@ pub(crate) mod tests {
|
|||||||
34 1
|
34 1
|
||||||
38 0
|
38 0
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 2, @"[1, ]");
|
|
||||||
|
|
||||||
index
|
index
|
||||||
.update_settings(|s| {
|
.update_settings(|s| {
|
||||||
@@ -2318,7 +2276,6 @@ pub(crate) mod tests {
|
|||||||
hard:
|
hard:
|
||||||
38 0
|
38 0
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 3, @"[]");
|
|
||||||
|
|
||||||
// So that this document addition works correctly now.
|
// So that this document addition works correctly now.
|
||||||
// It would be wrongly interpreted as a replacement before
|
// It would be wrongly interpreted as a replacement before
|
||||||
@@ -2331,7 +2288,6 @@ pub(crate) mod tests {
|
|||||||
34 1
|
34 1
|
||||||
38 0
|
38 0
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 4, @"[]");
|
|
||||||
|
|
||||||
// We do the test again, but deleting the document with id 0 instead of id 1 now
|
// We do the test again, but deleting the document with id 0 instead of id 1 now
|
||||||
index.delete_document("38");
|
index.delete_document("38");
|
||||||
@@ -2343,7 +2299,6 @@ pub(crate) mod tests {
|
|||||||
34 1
|
34 1
|
||||||
38 0
|
38 0
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 5, @"[0, ]");
|
|
||||||
|
|
||||||
index
|
index
|
||||||
.update_settings(|s| {
|
.update_settings(|s| {
|
||||||
@@ -2357,7 +2312,6 @@ pub(crate) mod tests {
|
|||||||
hard:
|
hard:
|
||||||
34 1
|
34 1
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 6, @"[]");
|
|
||||||
|
|
||||||
// And adding lots of documents afterwards instead of just one.
|
// And adding lots of documents afterwards instead of just one.
|
||||||
// These extra subtests don't add much, but it's better than nothing.
|
// These extra subtests don't add much, but it's better than nothing.
|
||||||
@@ -2374,7 +2328,6 @@ pub(crate) mod tests {
|
|||||||
41 3
|
41 3
|
||||||
42 5
|
42 5
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 7, @"[]");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
@@ -2403,7 +2356,6 @@ pub(crate) mod tests {
|
|||||||
30 0
|
30 0
|
||||||
34 1
|
34 1
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 1, @"[]");
|
|
||||||
|
|
||||||
index.delete_document("34");
|
index.delete_document("34");
|
||||||
|
|
||||||
@@ -2414,7 +2366,6 @@ pub(crate) mod tests {
|
|||||||
30 0
|
30 0
|
||||||
34 1
|
34 1
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 2, @"[1, ]");
|
|
||||||
|
|
||||||
index
|
index
|
||||||
.update_settings(|s| {
|
.update_settings(|s| {
|
||||||
@@ -2430,7 +2381,6 @@ pub(crate) mod tests {
|
|||||||
hard:
|
hard:
|
||||||
30 0
|
30 0
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 3, @"[]");
|
|
||||||
|
|
||||||
// So that when we add a new document
|
// So that when we add a new document
|
||||||
index.add_documents(documents!({ "primary_key": 35, "b": 2 })).unwrap();
|
index.add_documents(documents!({ "primary_key": 35, "b": 2 })).unwrap();
|
||||||
@@ -2444,7 +2394,6 @@ pub(crate) mod tests {
|
|||||||
30 0
|
30 0
|
||||||
35 1
|
35 1
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 4, @"[]");
|
|
||||||
|
|
||||||
// And when we add 34 again, we don't replace document 35
|
// And when we add 34 again, we don't replace document 35
|
||||||
index.add_documents(documents!({ "primary_key": 34, "a": 1 })).unwrap();
|
index.add_documents(documents!({ "primary_key": 34, "a": 1 })).unwrap();
|
||||||
@@ -2458,7 +2407,6 @@ pub(crate) mod tests {
|
|||||||
34 2
|
34 2
|
||||||
35 1
|
35 1
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 5, @"[]");
|
|
||||||
|
|
||||||
let rtxn = index.read_txn().unwrap();
|
let rtxn = index.read_txn().unwrap();
|
||||||
let (_docid, obkv) = index.documents(&rtxn, [0]).unwrap()[0];
|
let (_docid, obkv) = index.documents(&rtxn, [0]).unwrap()[0];
|
||||||
@@ -2499,7 +2447,6 @@ pub(crate) mod tests {
|
|||||||
38 4
|
38 4
|
||||||
39 5
|
39 5
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 6, @"[]");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
@@ -2530,7 +2477,6 @@ pub(crate) mod tests {
|
|||||||
4 1
|
4 1
|
||||||
5 2
|
5 2
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 1, @"[]");
|
|
||||||
|
|
||||||
index.delete_document("3");
|
index.delete_document("3");
|
||||||
|
|
||||||
@@ -2542,7 +2488,6 @@ pub(crate) mod tests {
|
|||||||
4 1
|
4 1
|
||||||
5 2
|
5 2
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 2, @"[0, ]");
|
|
||||||
|
|
||||||
index.add_documents(documents!([{ "primary_key": "4", "a": 2 }])).unwrap();
|
index.add_documents(documents!([{ "primary_key": "4", "a": 2 }])).unwrap();
|
||||||
|
|
||||||
@@ -2553,7 +2498,6 @@ pub(crate) mod tests {
|
|||||||
4 3
|
4 3
|
||||||
5 2
|
5 2
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 2, @"[]");
|
|
||||||
|
|
||||||
index
|
index
|
||||||
.add_documents(documents!([
|
.add_documents(documents!([
|
||||||
@@ -2569,7 +2513,6 @@ pub(crate) mod tests {
|
|||||||
4 3
|
4 3
|
||||||
5 2
|
5 2
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, 2, @"[]");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
@@ -2598,7 +2541,6 @@ pub(crate) mod tests {
|
|||||||
11 0
|
11 0
|
||||||
4 1
|
4 1
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, @"[]");
|
|
||||||
|
|
||||||
index
|
index
|
||||||
.add_documents(documents!([
|
.add_documents(documents!([
|
||||||
@@ -2615,7 +2557,6 @@ pub(crate) mod tests {
|
|||||||
11 0
|
11 0
|
||||||
4 2
|
4 2
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, @"[1, ]");
|
|
||||||
|
|
||||||
let mut wtxn = index.write_txn().unwrap();
|
let mut wtxn = index.write_txn().unwrap();
|
||||||
let mut delete = DeleteDocuments::new(&mut wtxn, &index).unwrap();
|
let mut delete = DeleteDocuments::new(&mut wtxn, &index).unwrap();
|
||||||
@@ -2630,7 +2571,6 @@ pub(crate) mod tests {
|
|||||||
11 0
|
11 0
|
||||||
4 2
|
4 2
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, @"[]");
|
|
||||||
|
|
||||||
index
|
index
|
||||||
.add_documents(documents!([
|
.add_documents(documents!([
|
||||||
@@ -2647,7 +2587,6 @@ pub(crate) mod tests {
|
|||||||
11 0
|
11 0
|
||||||
4 1
|
4 1
|
||||||
"###);
|
"###);
|
||||||
db_snap!(index, soft_deleted_documents_ids, @"[2, 3, ]");
|
|
||||||
|
|
||||||
let rtxn = index.read_txn().unwrap();
|
let rtxn = index.read_txn().unwrap();
|
||||||
let search = Search::new(&rtxn, &index);
|
let search = Search::new(&rtxn, &index);
|
||||||
|
@@ -223,12 +223,9 @@ impl<'a> Filter<'a> {
|
|||||||
impl<'a> Filter<'a> {
|
impl<'a> Filter<'a> {
|
||||||
pub fn evaluate(&self, rtxn: &heed::RoTxn, index: &Index) -> Result<RoaringBitmap> {
|
pub fn evaluate(&self, rtxn: &heed::RoTxn, index: &Index) -> Result<RoaringBitmap> {
|
||||||
// to avoid doing this for each recursive call we're going to do it ONCE ahead of time
|
// to avoid doing this for each recursive call we're going to do it ONCE ahead of time
|
||||||
let soft_deleted_documents = index.soft_deleted_documents_ids(rtxn)?;
|
|
||||||
let filterable_fields = index.filterable_fields(rtxn)?;
|
let filterable_fields = index.filterable_fields(rtxn)?;
|
||||||
|
|
||||||
// and finally we delete all the soft_deleted_documents, again, only once at the very end
|
|
||||||
self.inner_evaluate(rtxn, index, &filterable_fields)
|
self.inner_evaluate(rtxn, index, &filterable_fields)
|
||||||
.map(|result| result - soft_deleted_documents)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn evaluate_operator(
|
fn evaluate_operator(
|
||||||
|
@@ -98,7 +98,6 @@ Create a snapshot test of the given database.
|
|||||||
- `facet_id_string_docids`
|
- `facet_id_string_docids`
|
||||||
- `documents_ids`
|
- `documents_ids`
|
||||||
- `stop_words`
|
- `stop_words`
|
||||||
- `soft_deleted_documents_ids`
|
|
||||||
- `field_distribution`
|
- `field_distribution`
|
||||||
- `fields_ids_map`
|
- `fields_ids_map`
|
||||||
- `geo_faceted_documents_ids`
|
- `geo_faceted_documents_ids`
|
||||||
@@ -308,12 +307,6 @@ pub fn snap_stop_words(index: &Index) -> String {
|
|||||||
let snap = format!("{stop_words:?}");
|
let snap = format!("{stop_words:?}");
|
||||||
snap
|
snap
|
||||||
}
|
}
|
||||||
pub fn snap_soft_deleted_documents_ids(index: &Index) -> String {
|
|
||||||
let rtxn = index.read_txn().unwrap();
|
|
||||||
let soft_deleted_documents_ids = index.soft_deleted_documents_ids(&rtxn).unwrap();
|
|
||||||
|
|
||||||
display_bitmap(&soft_deleted_documents_ids)
|
|
||||||
}
|
|
||||||
pub fn snap_field_distributions(index: &Index) -> String {
|
pub fn snap_field_distributions(index: &Index) -> String {
|
||||||
let rtxn = index.read_txn().unwrap();
|
let rtxn = index.read_txn().unwrap();
|
||||||
let mut snap = String::new();
|
let mut snap = String::new();
|
||||||
@@ -484,9 +477,6 @@ macro_rules! full_snap_of_db {
|
|||||||
($index:ident, stop_words) => {{
|
($index:ident, stop_words) => {{
|
||||||
$crate::snapshot_tests::snap_stop_words(&$index)
|
$crate::snapshot_tests::snap_stop_words(&$index)
|
||||||
}};
|
}};
|
||||||
($index:ident, soft_deleted_documents_ids) => {{
|
|
||||||
$crate::snapshot_tests::snap_soft_deleted_documents_ids(&$index)
|
|
||||||
}};
|
|
||||||
($index:ident, field_distribution) => {{
|
($index:ident, field_distribution) => {{
|
||||||
$crate::snapshot_tests::snap_field_distributions(&$index)
|
$crate::snapshot_tests::snap_field_distributions(&$index)
|
||||||
}};
|
}};
|
||||||
|
@@ -8,16 +8,11 @@ pub struct AvailableDocumentsIds {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl AvailableDocumentsIds {
|
impl AvailableDocumentsIds {
|
||||||
pub fn from_documents_ids(
|
pub fn from_documents_ids(docids: &RoaringBitmap) -> AvailableDocumentsIds {
|
||||||
docids: &RoaringBitmap,
|
match docids.max() {
|
||||||
soft_deleted_docids: &RoaringBitmap,
|
|
||||||
) -> AvailableDocumentsIds {
|
|
||||||
let used_docids = docids | soft_deleted_docids;
|
|
||||||
|
|
||||||
match used_docids.max() {
|
|
||||||
Some(last_id) => {
|
Some(last_id) => {
|
||||||
let mut available = RoaringBitmap::from_iter(0..last_id);
|
let mut available = RoaringBitmap::from_iter(0..last_id);
|
||||||
available -= used_docids;
|
available -= docids;
|
||||||
|
|
||||||
let iter = match last_id.checked_add(1) {
|
let iter = match last_id.checked_add(1) {
|
||||||
Some(id) => id..=u32::max_value(),
|
Some(id) => id..=u32::max_value(),
|
||||||
@@ -50,7 +45,7 @@ mod tests {
|
|||||||
#[test]
|
#[test]
|
||||||
fn empty() {
|
fn empty() {
|
||||||
let base = RoaringBitmap::new();
|
let base = RoaringBitmap::new();
|
||||||
let left = AvailableDocumentsIds::from_documents_ids(&base, &RoaringBitmap::new());
|
let left = AvailableDocumentsIds::from_documents_ids(&base);
|
||||||
let right = 0..=u32::max_value();
|
let right = 0..=u32::max_value();
|
||||||
left.zip(right).take(500).for_each(|(l, r)| assert_eq!(l, r));
|
left.zip(right).take(500).for_each(|(l, r)| assert_eq!(l, r));
|
||||||
}
|
}
|
||||||
@@ -63,28 +58,8 @@ mod tests {
|
|||||||
base.insert(100);
|
base.insert(100);
|
||||||
base.insert(405);
|
base.insert(405);
|
||||||
|
|
||||||
let left = AvailableDocumentsIds::from_documents_ids(&base, &RoaringBitmap::new());
|
let left = AvailableDocumentsIds::from_documents_ids(&base);
|
||||||
let right = (0..=u32::max_value()).filter(|&n| n != 0 && n != 10 && n != 100 && n != 405);
|
let right = (0..=u32::max_value()).filter(|&n| n != 0 && n != 10 && n != 100 && n != 405);
|
||||||
left.zip(right).take(500).for_each(|(l, r)| assert_eq!(l, r));
|
left.zip(right).take(500).for_each(|(l, r)| assert_eq!(l, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn soft_deleted() {
|
|
||||||
let mut base = RoaringBitmap::new();
|
|
||||||
base.insert(0);
|
|
||||||
base.insert(10);
|
|
||||||
base.insert(100);
|
|
||||||
base.insert(405);
|
|
||||||
|
|
||||||
let mut soft_deleted = RoaringBitmap::new();
|
|
||||||
soft_deleted.insert(1);
|
|
||||||
soft_deleted.insert(11);
|
|
||||||
soft_deleted.insert(101);
|
|
||||||
soft_deleted.insert(406);
|
|
||||||
|
|
||||||
let left = AvailableDocumentsIds::from_documents_ids(&base, &soft_deleted);
|
|
||||||
let right =
|
|
||||||
(0..=u32::max_value()).filter(|&n| ![0, 1, 10, 11, 100, 101, 405, 406].contains(&n));
|
|
||||||
left.zip(right).take(500).for_each(|(l, r)| assert_eq!(l, r));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@@ -56,7 +56,6 @@ impl<'t, 'u, 'i> ClearDocuments<'t, 'u, 'i> {
|
|||||||
self.index.put_words_prefixes_fst(self.wtxn, &fst::Set::default())?;
|
self.index.put_words_prefixes_fst(self.wtxn, &fst::Set::default())?;
|
||||||
self.index.put_external_documents_ids(self.wtxn, &ExternalDocumentsIds::default())?;
|
self.index.put_external_documents_ids(self.wtxn, &ExternalDocumentsIds::default())?;
|
||||||
self.index.put_documents_ids(self.wtxn, &empty_roaring)?;
|
self.index.put_documents_ids(self.wtxn, &empty_roaring)?;
|
||||||
self.index.put_soft_deleted_documents_ids(self.wtxn, &empty_roaring)?;
|
|
||||||
self.index.put_field_distribution(self.wtxn, &FieldDistribution::default())?;
|
self.index.put_field_distribution(self.wtxn, &FieldDistribution::default())?;
|
||||||
self.index.delete_geo_rtree(self.wtxn)?;
|
self.index.delete_geo_rtree(self.wtxn)?;
|
||||||
self.index.delete_geo_faceted_documents_ids(self.wtxn)?;
|
self.index.delete_geo_faceted_documents_ids(self.wtxn)?;
|
||||||
|
@@ -594,7 +594,6 @@ mod tests {
|
|||||||
index.add_documents(documents).unwrap();
|
index.add_documents(documents).unwrap();
|
||||||
|
|
||||||
db_snap!(index, facet_id_f64_docids, "initial", @"777e0e221d778764b472c512617eeb3b");
|
db_snap!(index, facet_id_f64_docids, "initial", @"777e0e221d778764b472c512617eeb3b");
|
||||||
db_snap!(index, soft_deleted_documents_ids, "initial", @"[]");
|
|
||||||
|
|
||||||
let mut documents = vec![];
|
let mut documents = vec![];
|
||||||
for i in 0..999 {
|
for i in 0..999 {
|
||||||
@@ -616,7 +615,6 @@ mod tests {
|
|||||||
index.add_documents(documents).unwrap();
|
index.add_documents(documents).unwrap();
|
||||||
|
|
||||||
db_snap!(index, facet_id_f64_docids, "replaced_1_soft", @"abba175d7bed727d0efadaef85a4388f");
|
db_snap!(index, facet_id_f64_docids, "replaced_1_soft", @"abba175d7bed727d0efadaef85a4388f");
|
||||||
db_snap!(index, soft_deleted_documents_ids, "replaced_1_soft", @"6c975deb900f286d2f6456d2d5c3a123");
|
|
||||||
|
|
||||||
// Then replace the last document while disabling soft_deletion
|
// Then replace the last document while disabling soft_deletion
|
||||||
let mut documents = vec![];
|
let mut documents = vec![];
|
||||||
@@ -639,7 +637,6 @@ mod tests {
|
|||||||
index.add_documents(documents).unwrap();
|
index.add_documents(documents).unwrap();
|
||||||
|
|
||||||
db_snap!(index, facet_id_f64_docids, "replaced_2_hard", @"029e27a46d09c574ae949aa4289b45e6");
|
db_snap!(index, facet_id_f64_docids, "replaced_2_hard", @"029e27a46d09c574ae949aa4289b45e6");
|
||||||
db_snap!(index, soft_deleted_documents_ids, "replaced_2_hard", @"[]");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -999,7 +999,6 @@ mod tests {
|
|||||||
assert_eq!(count, 6);
|
assert_eq!(count, 6);
|
||||||
|
|
||||||
db_snap!(index, word_docids, "updated");
|
db_snap!(index, word_docids, "updated");
|
||||||
db_snap!(index, soft_deleted_documents_ids, "updated", @"[0, 1, 4, ]");
|
|
||||||
|
|
||||||
drop(rtxn);
|
drop(rtxn);
|
||||||
}
|
}
|
||||||
@@ -2649,8 +2648,6 @@ mod tests {
|
|||||||
0 1
|
0 1
|
||||||
"###);
|
"###);
|
||||||
|
|
||||||
db_snap!(index, soft_deleted_documents_ids, @"[]");
|
|
||||||
|
|
||||||
// BATCH 3
|
// BATCH 3
|
||||||
|
|
||||||
println!("--- ENTERING BATCH 3");
|
println!("--- ENTERING BATCH 3");
|
||||||
|
@@ -132,17 +132,13 @@ impl<'a, 'i> Transform<'a, 'i> {
|
|||||||
indexer_settings.max_memory.map(|mem| mem / 2),
|
indexer_settings.max_memory.map(|mem| mem / 2),
|
||||||
);
|
);
|
||||||
let documents_ids = index.documents_ids(wtxn)?;
|
let documents_ids = index.documents_ids(wtxn)?;
|
||||||
let soft_deleted_documents_ids = index.soft_deleted_documents_ids(wtxn)?;
|
|
||||||
|
|
||||||
Ok(Transform {
|
Ok(Transform {
|
||||||
index,
|
index,
|
||||||
fields_ids_map: index.fields_ids_map(wtxn)?,
|
fields_ids_map: index.fields_ids_map(wtxn)?,
|
||||||
indexer_settings,
|
indexer_settings,
|
||||||
autogenerate_docids,
|
autogenerate_docids,
|
||||||
available_documents_ids: AvailableDocumentsIds::from_documents_ids(
|
available_documents_ids: AvailableDocumentsIds::from_documents_ids(&documents_ids),
|
||||||
&documents_ids,
|
|
||||||
&soft_deleted_documents_ids,
|
|
||||||
),
|
|
||||||
original_sorter,
|
original_sorter,
|
||||||
flattened_sorter,
|
flattened_sorter,
|
||||||
index_documents_method,
|
index_documents_method,
|
||||||
|
@@ -508,7 +508,6 @@ mod tests {
|
|||||||
db_snap!(index, word_docids, "replaced");
|
db_snap!(index, word_docids, "replaced");
|
||||||
db_snap!(index, word_prefix_pair_proximity_docids, "replaced");
|
db_snap!(index, word_prefix_pair_proximity_docids, "replaced");
|
||||||
db_snap!(index, prefix_word_pair_proximity_docids, "replaced");
|
db_snap!(index, prefix_word_pair_proximity_docids, "replaced");
|
||||||
db_snap!(index, soft_deleted_documents_ids, "replaced", @"[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, ]");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
@@ -568,6 +567,5 @@ mod tests {
|
|||||||
db_snap!(index, word_docids, "replaced");
|
db_snap!(index, word_docids, "replaced");
|
||||||
db_snap!(index, word_prefix_pair_proximity_docids, "replaced");
|
db_snap!(index, word_prefix_pair_proximity_docids, "replaced");
|
||||||
db_snap!(index, prefix_word_pair_proximity_docids, "replaced");
|
db_snap!(index, prefix_word_pair_proximity_docids, "replaced");
|
||||||
db_snap!(index, soft_deleted_documents_ids, "replaced", @"[]");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user