Add a test to check that we can index more that 256 fields

This commit is contained in:
Kerollmops 2021-07-06 11:40:45 +02:00
parent 838ed1cd32
commit a9553af635
No known key found for this signature in database
GPG Key ID: 92ADA4E935E71FA4

View File

@ -842,10 +842,12 @@ impl<'t, 'u, 'i, 'a> IndexDocuments<'t, 'u, 'i, 'a> {
mod tests { mod tests {
use std::io::Cursor; use std::io::Cursor;
use big_s::S;
use heed::EnvOpenOptions; use heed::EnvOpenOptions;
use super::*; use super::*;
use crate::update::DeleteDocuments; use crate::update::DeleteDocuments;
use crate::HashMap;
#[test] #[test]
fn simple_document_replacement() { fn simple_document_replacement() {
@ -1352,4 +1354,30 @@ mod tests {
wtxn.commit().unwrap(); wtxn.commit().unwrap();
} }
#[test]
fn index_more_than_256_fields() {
let path = tempfile::tempdir().unwrap();
let mut options = EnvOpenOptions::new();
options.map_size(10 * 1024 * 1024); // 10 MB
let index = Index::new(options, &path).unwrap();
let mut wtxn = index.write_txn().unwrap();
let mut big_object = HashMap::new();
big_object.insert(S("id"), "wow");
for i in 0..1000 {
let key = i.to_string();
big_object.insert(key, "I am a text!");
}
let content = vec![big_object];
let content = serde_json::to_string(&content).unwrap();
let mut builder = IndexDocuments::new(&mut wtxn, &index, 0);
builder.update_format(UpdateFormat::Json);
builder.execute(Cursor::new(content), |_, _| ()).unwrap();
wtxn.commit().unwrap();
}
} }