906: Facet distribution correct case r=LegendreM a=MarinPostma

~

Co-authored-by: mpostma <postma.marin@protonmail.com>
Co-authored-by: marin <postma.marin@protonmail.com>
This commit is contained in:
bors[bot] 2020-08-12 09:04:36 +00:00 committed by GitHub
commit 1903302a74
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 146 additions and 99 deletions

View File

@ -39,7 +39,7 @@ pub fn bucket_sort<'c, FI>(
query: &str, query: &str,
range: Range<usize>, range: Range<usize>,
facets_docids: Option<SetBuf<DocumentId>>, facets_docids: Option<SetBuf<DocumentId>>,
facet_count_docids: Option<HashMap<String, HashMap<String, Cow<Set<DocumentId>>>>>, facet_count_docids: Option<HashMap<String, HashMap<String, (&str, Cow<Set<DocumentId>>)>>>,
filter: Option<FI>, filter: Option<FI>,
criteria: Criteria<'c>, criteria: Criteria<'c>,
searchable_attrs: Option<ReorderedAttrs>, searchable_attrs: Option<ReorderedAttrs>,
@ -199,7 +199,7 @@ pub fn bucket_sort_with_distinct<'c, FI, FD>(
query: &str, query: &str,
range: Range<usize>, range: Range<usize>,
facets_docids: Option<SetBuf<DocumentId>>, facets_docids: Option<SetBuf<DocumentId>>,
facet_count_docids: Option<HashMap<String, HashMap<String, Cow<Set<DocumentId>>>>>, facet_count_docids: Option<HashMap<String, HashMap<String, (&str, Cow<Set<DocumentId>>)>>>,
filter: Option<FI>, filter: Option<FI>,
distinct: FD, distinct: FD,
distinct_size: usize, distinct_size: usize,
@ -637,17 +637,17 @@ pub fn placeholder_document_sort(
/// For each entry in facet_docids, calculates the number of documents in the intersection with candidate_docids. /// For each entry in facet_docids, calculates the number of documents in the intersection with candidate_docids.
pub fn facet_count( pub fn facet_count(
facet_docids: HashMap<String, HashMap<String, Cow<Set<DocumentId>>>>, facet_docids: HashMap<String, HashMap<String, (&str, Cow<Set<DocumentId>>)>>,
candidate_docids: &Set<DocumentId>, candidate_docids: &Set<DocumentId>,
) -> HashMap<String, HashMap<String, usize>> { ) -> HashMap<String, HashMap<String, usize>> {
let mut facets_counts = HashMap::with_capacity(facet_docids.len()); let mut facets_counts = HashMap::with_capacity(facet_docids.len());
for (key, doc_map) in facet_docids { for (key, doc_map) in facet_docids {
let mut count_map = HashMap::with_capacity(doc_map.len()); let mut count_map = HashMap::with_capacity(doc_map.len());
for (value, docids) in doc_map { for (_, (value, docids)) in doc_map {
let mut counter = Counter::new(); let mut counter = Counter::new();
let op = OpBuilder::new(docids.as_ref(), candidate_docids).intersection(); let op = OpBuilder::new(docids.as_ref(), candidate_docids).intersection();
SetOperation::<DocumentId>::extend_collection(op, &mut counter); SetOperation::<DocumentId>::extend_collection(op, &mut counter);
count_map.insert(value, counter.0); count_map.insert(value.to_string(), counter.0);
} }
facets_counts.insert(key, count_map); facets_counts.insert(key, count_map);
} }

View File

@ -164,7 +164,7 @@ impl<'a> heed::BytesDecode<'a> for FacetKey {
} }
pub fn add_to_facet_map( pub fn add_to_facet_map(
facet_map: &mut HashMap<FacetKey, Vec<DocumentId>>, facet_map: &mut HashMap<FacetKey, (String, Vec<DocumentId>)>,
field_id: FieldId, field_id: FieldId,
value: Value, value: Value,
document_id: DocumentId, document_id: DocumentId,
@ -175,8 +175,8 @@ pub fn add_to_facet_map(
Value::Null => return Ok(()), Value::Null => return Ok(()),
value => return Err(FacetError::InvalidDocumentAttribute(value.to_string())), value => return Err(FacetError::InvalidDocumentAttribute(value.to_string())),
}; };
let key = FacetKey::new(field_id, value); let key = FacetKey::new(field_id, value.clone());
facet_map.entry(key).or_insert_with(Vec::new).push(document_id); facet_map.entry(key).or_insert_with(|| (value, Vec::new())).1.push(document_id);
Ok(()) Ok(())
} }
@ -185,8 +185,10 @@ pub fn facet_map_from_docids(
index: &crate::Index, index: &crate::Index,
document_ids: &[DocumentId], document_ids: &[DocumentId],
attributes_for_facetting: &[FieldId], attributes_for_facetting: &[FieldId],
) -> MResult<HashMap<FacetKey, Vec<DocumentId>>> { ) -> MResult<HashMap<FacetKey, (String, Vec<DocumentId>)>> {
let mut facet_map = HashMap::new(); // A hashmap that ascociate a facet key to a pair containing the original facet attribute
// string with it's case preserved, and a list of document ids for that facet attribute.
let mut facet_map: HashMap<FacetKey, (String, Vec<DocumentId>)> = HashMap::new();
for document_id in document_ids { for document_id in document_ids {
for result in index for result in index
.documents_fields .documents_fields
@ -212,7 +214,7 @@ pub fn facet_map_from_docs(
schema: &Schema, schema: &Schema,
documents: &HashMap<DocumentId, IndexMap<String, Value>>, documents: &HashMap<DocumentId, IndexMap<String, Value>>,
attributes_for_facetting: &[FieldId], attributes_for_facetting: &[FieldId],
) -> MResult<HashMap<FacetKey, Vec<DocumentId>>> { ) -> MResult<HashMap<FacetKey, (String, Vec<DocumentId>)>> {
let mut facet_map = HashMap::new(); let mut facet_map = HashMap::new();
let attributes_for_facetting = attributes_for_facetting let attributes_for_facetting = attributes_for_facetting
.iter() .iter()

View File

@ -97,16 +97,14 @@ impl<'c, 'f, 'd, 'i> QueryBuilder<'c, 'f, 'd, 'i> {
.unwrap_or_default(); .unwrap_or_default();
ors.push(docids); ors.push(docids);
} }
let sets: Vec<_> = ors.iter().map(Cow::deref).collect(); let sets: Vec<_> = ors.iter().map(|(_, i)| i).map(Cow::deref).collect();
let or_result = sdset::multi::OpBuilder::from_vec(sets) let or_result = sdset::multi::OpBuilder::from_vec(sets).union().into_set_buf();
.union()
.into_set_buf();
ands.push(Cow::Owned(or_result)); ands.push(Cow::Owned(or_result));
ors.clear(); ors.clear();
} }
Either::Right(key) => { Either::Right(key) => {
match self.index.facets.facet_document_ids(reader, &key)? { match self.index.facets.facet_document_ids(reader, &key)? {
Some(docids) => ands.push(docids), Some((_name, docids)) => ands.push(docids),
// no candidates for search, early return. // no candidates for search, early return.
None => return Ok(Some(SetBuf::default())), None => return Ok(Some(SetBuf::default())),
} }
@ -206,7 +204,7 @@ impl<'c, 'f, 'd, 'i> QueryBuilder<'c, 'f, 'd, 'i> {
} }
} }
fn facet_count_docids<'a>(&self, reader: &'a MainReader) -> MResult<Option<HashMap<String, HashMap<String, Cow<'a, Set<DocumentId>>>>>> { fn facet_count_docids<'a>(&self, reader: &'a MainReader) -> MResult<Option<HashMap<String, HashMap<String, (&'a str, Cow<'a, Set<DocumentId>>)>>>> {
match self.facets { match self.facets {
Some(ref field_ids) => { Some(ref field_ids) => {
let mut facet_count_map = HashMap::new(); let mut facet_count_map = HashMap::new();

View File

@ -1,12 +1,14 @@
use std::borrow::Cow; use std::borrow::Cow;
use std::collections::HashMap; use std::collections::HashMap;
use std::mem;
use heed::{RwTxn, RoTxn, Result as ZResult, RoRange}; use heed::{RwTxn, RoTxn, RoRange, types::Str, BytesEncode, BytesDecode};
use sdset::{SetBuf, Set, SetOperation}; use sdset::{SetBuf, Set, SetOperation};
use meilisearch_types::DocumentId; use meilisearch_types::DocumentId;
use meilisearch_schema::FieldId; use meilisearch_schema::FieldId;
use crate::MResult;
use crate::database::MainT; use crate::database::MainT;
use crate::facets::FacetKey; use crate::facets::FacetKey;
use super::cow_set::CowSet; use super::cow_set::CowSet;
@ -14,45 +16,82 @@ use super::cow_set::CowSet;
/// contains facet info /// contains facet info
#[derive(Clone, Copy)] #[derive(Clone, Copy)]
pub struct Facets { pub struct Facets {
pub(crate) facets: heed::Database<FacetKey, CowSet<DocumentId>>, pub(crate) facets: heed::Database<FacetKey, FacetData>,
}
pub struct FacetData;
impl<'a> BytesEncode<'a> for FacetData {
type EItem = (&'a str, &'a Set<DocumentId>);
fn bytes_encode(item: &'a Self::EItem) -> Option<Cow<'a, [u8]>> {
// get size of the first item
let first_size = item.0.as_bytes().len();
let size = mem::size_of::<u64>()
+ first_size
+ item.1.len() * mem::size_of::<DocumentId>();
let mut buffer = Vec::with_capacity(size);
// encode the length of the first item
buffer.extend_from_slice(&first_size.to_be_bytes());
buffer.extend_from_slice(Str::bytes_encode(&item.0)?.as_ref());
let second_slice = CowSet::bytes_encode(&item.1)?;
buffer.extend_from_slice(second_slice.as_ref());
Some(Cow::Owned(buffer))
}
}
impl<'a> BytesDecode<'a> for FacetData {
type DItem = (&'a str, Cow<'a, Set<DocumentId>>);
fn bytes_decode(bytes: &'a [u8]) -> Option<Self::DItem> {
const LEN: usize = mem::size_of::<u64>();
let mut size_buf = [0; LEN];
size_buf.copy_from_slice(bytes.get(0..LEN)?);
// decode size of the first item from the bytes
let first_size = usize::from_be_bytes(size_buf);
// decode first and second items
let first_item = Str::bytes_decode(bytes.get(LEN..(LEN + first_size))?)?;
let second_item = CowSet::bytes_decode(bytes.get((LEN + first_size)..)?)?;
Some((first_item, second_item))
}
} }
impl Facets { impl Facets {
// we use sdset::SetBuf to ensure the docids are sorted. // we use sdset::SetBuf to ensure the docids are sorted.
pub fn put_facet_document_ids(&self, writer: &mut RwTxn<MainT>, facet_key: FacetKey, doc_ids: &Set<DocumentId>) -> ZResult<()> { pub fn put_facet_document_ids(&self, writer: &mut RwTxn<MainT>, facet_key: FacetKey, doc_ids: &Set<DocumentId>, facet_value: &str) -> MResult<()> {
self.facets.put(writer, &facet_key, doc_ids) Ok(self.facets.put(writer, &facet_key, &(facet_value, doc_ids))?)
} }
pub fn field_document_ids<'txn>(&self, reader: &'txn RoTxn<MainT>, field_id: FieldId) -> ZResult<RoRange<'txn, FacetKey, CowSet<DocumentId>>> { pub fn field_document_ids<'txn>(&self, reader: &'txn RoTxn<MainT>, field_id: FieldId) -> MResult<RoRange<'txn, FacetKey, FacetData>> {
self.facets.prefix_iter(reader, &FacetKey::new(field_id, String::new())) Ok(self.facets.prefix_iter(reader, &FacetKey::new(field_id, String::new()))?)
} }
pub fn facet_document_ids<'txn>(&self, reader: &'txn RoTxn<MainT>, facet_key: &FacetKey) -> ZResult<Option<Cow<'txn, Set<DocumentId>>>> { pub fn facet_document_ids<'txn>(&self, reader: &'txn RoTxn<MainT>, facet_key: &FacetKey) -> MResult<Option<(&'txn str,Cow<'txn, Set<DocumentId>>)>> {
self.facets.get(reader, &facet_key) Ok(self.facets.get(reader, &facet_key)?)
} }
/// updates the facets store, revmoving the documents from the facets provided in the /// updates the facets store, revmoving the documents from the facets provided in the
/// `facet_map` argument /// `facet_map` argument
pub fn remove(&self, writer: &mut RwTxn<MainT>, facet_map: HashMap<FacetKey, Vec<DocumentId>>) -> ZResult<()> { pub fn remove(&self, writer: &mut RwTxn<MainT>, facet_map: HashMap<FacetKey, (String, Vec<DocumentId>)>) -> MResult<()> {
for (key, document_ids) in facet_map { for (key, (name, document_ids)) in facet_map {
if let Some(old) = self.facets.get(writer, &key)? { if let Some((_, old)) = self.facets.get(writer, &key)? {
let to_remove = SetBuf::from_dirty(document_ids); let to_remove = SetBuf::from_dirty(document_ids);
let new = sdset::duo::OpBuilder::new(old.as_ref(), to_remove.as_set()).difference().into_set_buf(); let new = sdset::duo::OpBuilder::new(old.as_ref(), to_remove.as_set()).difference().into_set_buf();
self.facets.put(writer, &key, new.as_set())?; self.facets.put(writer, &key, &(&name, new.as_set()))?;
} }
} }
Ok(()) Ok(())
} }
pub fn add(&self, writer: &mut RwTxn<MainT>, facet_map: HashMap<FacetKey, Vec<DocumentId>>) -> ZResult<()> { pub fn add(&self, writer: &mut RwTxn<MainT>, facet_map: HashMap<FacetKey, (String, Vec<DocumentId>)>) -> MResult<()> {
for (key, document_ids) in facet_map { for (key, (facet_name, document_ids)) in facet_map {
let set = SetBuf::from_dirty(document_ids); let set = SetBuf::from_dirty(document_ids);
self.put_facet_document_ids(writer, key, set.as_set())?; self.put_facet_document_ids(writer, key, set.as_set(), &facet_name)?;
} }
Ok(()) Ok(())
} }
pub fn clear(self, writer: &mut heed::RwTxn<MainT>) -> ZResult<()> { pub fn clear(self, writer: &mut heed::RwTxn<MainT>) -> MResult<()> {
self.facets.clear(writer) Ok(self.facets.clear(writer)?)
} }
} }

View File

@ -5,7 +5,7 @@
"balance": "$2,668.55", "balance": "$2,668.55",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 36, "age": 36,
"color": "green", "color": "Green",
"name": "Lucas Hess", "name": "Lucas Hess",
"gender": "male", "gender": "male",
"email": "lucashess@chorizon.com", "email": "lucashess@chorizon.com",
@ -26,7 +26,7 @@
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -90,7 +90,7 @@
"balance": "$2,575.78", "balance": "$2,575.78",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 39, "age": 39,
"color": "green", "color": "Green",
"name": "Mariana Pacheco", "name": "Mariana Pacheco",
"gender": "female", "gender": "female",
"email": "marianapacheco@chorizon.com", "email": "marianapacheco@chorizon.com",
@ -110,7 +110,7 @@
"balance": "$3,793.09", "balance": "$3,793.09",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 20, "age": 20,
"color": "green", "color": "Green",
"name": "Warren Watson", "name": "Warren Watson",
"gender": "male", "gender": "male",
"email": "warrenwatson@chorizon.com", "email": "warrenwatson@chorizon.com",
@ -155,7 +155,7 @@
"balance": "$1,349.50", "balance": "$1,349.50",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 28, "age": 28,
"color": "green", "color": "Green",
"name": "Chrystal Boyd", "name": "Chrystal Boyd",
"gender": "female", "gender": "female",
"email": "chrystalboyd@chorizon.com", "email": "chrystalboyd@chorizon.com",
@ -235,7 +235,7 @@
"balance": "$1,351.43", "balance": "$1,351.43",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 28, "age": 28,
"color": "green", "color": "Green",
"name": "Evans Wagner", "name": "Evans Wagner",
"gender": "male", "gender": "male",
"email": "evanswagner@chorizon.com", "email": "evanswagner@chorizon.com",
@ -431,7 +431,7 @@
"balance": "$1,986.48", "balance": "$1,986.48",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 38, "age": 38,
"color": "green", "color": "Green",
"name": "Florence Long", "name": "Florence Long",
"gender": "female", "gender": "female",
"email": "florencelong@chorizon.com", "email": "florencelong@chorizon.com",
@ -530,7 +530,7 @@
"balance": "$3,973.43", "balance": "$3,973.43",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 29, "age": 29,
"color": "green", "color": "Green",
"name": "Sykes Conley", "name": "Sykes Conley",
"gender": "male", "gender": "male",
"email": "sykesconley@chorizon.com", "email": "sykesconley@chorizon.com",
@ -813,7 +813,7 @@
"balance": "$1,992.38", "balance": "$1,992.38",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 40, "age": 40,
"color": "green", "color": "Green",
"name": "Christina Short", "name": "Christina Short",
"gender": "female", "gender": "female",
"email": "christinashort@chorizon.com", "email": "christinashort@chorizon.com",
@ -944,7 +944,7 @@
"balance": "$2,893.45", "balance": "$2,893.45",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 22, "age": 22,
"color": "green", "color": "Green",
"name": "Joni Spears", "name": "Joni Spears",
"gender": "female", "gender": "female",
"email": "jonispears@chorizon.com", "email": "jonispears@chorizon.com",
@ -988,7 +988,7 @@
"balance": "$1,348.04", "balance": "$1,348.04",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 34, "age": 34,
"color": "green", "color": "Green",
"name": "Lawson Curtis", "name": "Lawson Curtis",
"gender": "male", "gender": "male",
"email": "lawsoncurtis@chorizon.com", "email": "lawsoncurtis@chorizon.com",
@ -1006,7 +1006,7 @@
"balance": "$1,132.41", "balance": "$1,132.41",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 38, "age": 38,
"color": "green", "color": "Green",
"name": "Goff May", "name": "Goff May",
"gender": "male", "gender": "male",
"email": "goffmay@chorizon.com", "email": "goffmay@chorizon.com",
@ -1026,7 +1026,7 @@
"balance": "$1,201.87", "balance": "$1,201.87",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 38, "age": 38,
"color": "green", "color": "Green",
"name": "Goodman Becker", "name": "Goodman Becker",
"gender": "male", "gender": "male",
"email": "goodmanbecker@chorizon.com", "email": "goodmanbecker@chorizon.com",
@ -1069,7 +1069,7 @@
"balance": "$1,947.08", "balance": "$1,947.08",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 21, "age": 21,
"color": "green", "color": "Green",
"name": "Guerra Mcintyre", "name": "Guerra Mcintyre",
"gender": "male", "gender": "male",
"email": "guerramcintyre@chorizon.com", "email": "guerramcintyre@chorizon.com",
@ -1153,7 +1153,7 @@
"balance": "$2,113.29", "balance": "$2,113.29",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 28, "age": 28,
"color": "green", "color": "Green",
"name": "Richards Walls", "name": "Richards Walls",
"gender": "male", "gender": "male",
"email": "richardswalls@chorizon.com", "email": "richardswalls@chorizon.com",
@ -1211,7 +1211,7 @@
"balance": "$1,844.56", "balance": "$1,844.56",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 20, "age": 20,
"color": "green", "color": "Green",
"name": "Kaitlin Conner", "name": "Kaitlin Conner",
"gender": "female", "gender": "female",
"email": "kaitlinconner@chorizon.com", "email": "kaitlinconner@chorizon.com",
@ -1229,7 +1229,7 @@
"balance": "$2,876.10", "balance": "$2,876.10",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 38, "age": 38,
"color": "green", "color": "Green",
"name": "Mamie Fischer", "name": "Mamie Fischer",
"gender": "female", "gender": "female",
"email": "mamiefischer@chorizon.com", "email": "mamiefischer@chorizon.com",
@ -1252,7 +1252,7 @@
"balance": "$1,921.58", "balance": "$1,921.58",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 31, "age": 31,
"color": "green", "color": "Green",
"name": "Harper Carson", "name": "Harper Carson",
"gender": "male", "gender": "male",
"email": "harpercarson@chorizon.com", "email": "harpercarson@chorizon.com",
@ -1291,7 +1291,7 @@
"balance": "$2,813.41", "balance": "$2,813.41",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 37, "age": 37,
"color": "green", "color": "Green",
"name": "Charles Castillo", "name": "Charles Castillo",
"gender": "male", "gender": "male",
"email": "charlescastillo@chorizon.com", "email": "charlescastillo@chorizon.com",
@ -1433,7 +1433,7 @@
"balance": "$1,539.98", "balance": "$1,539.98",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 24, "age": 24,
"color": "green", "color": "Green",
"name": "Angelina Dyer", "name": "Angelina Dyer",
"gender": "female", "gender": "female",
"email": "angelinadyer@chorizon.com", "email": "angelinadyer@chorizon.com",
@ -1493,7 +1493,7 @@
"balance": "$3,381.63", "balance": "$3,381.63",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 38, "age": 38,
"color": "green", "color": "Green",
"name": "Candace Sawyer", "name": "Candace Sawyer",
"gender": "female", "gender": "female",
"email": "candacesawyer@chorizon.com", "email": "candacesawyer@chorizon.com",
@ -1514,7 +1514,7 @@
"balance": "$1,640.98", "balance": "$1,640.98",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Hendricks Martinez", "name": "Hendricks Martinez",
"gender": "male", "gender": "male",
"email": "hendricksmartinez@chorizon.com", "email": "hendricksmartinez@chorizon.com",
@ -1557,7 +1557,7 @@
"balance": "$1,180.90", "balance": "$1,180.90",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 36, "age": 36,
"color": "green", "color": "Green",
"name": "Stark Wong", "name": "Stark Wong",
"gender": "male", "gender": "male",
"email": "starkwong@chorizon.com", "email": "starkwong@chorizon.com",
@ -1577,7 +1577,7 @@
"balance": "$1,913.42", "balance": "$1,913.42",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 24, "age": 24,
"color": "green", "color": "Green",
"name": "Emma Jacobs", "name": "Emma Jacobs",
"gender": "female", "gender": "female",
"email": "emmajacobs@chorizon.com", "email": "emmajacobs@chorizon.com",
@ -1595,7 +1595,7 @@
"balance": "$1,274.29", "balance": "$1,274.29",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 25, "age": 25,
"color": "green", "color": "Green",
"name": "Clarice Gardner", "name": "Clarice Gardner",
"gender": "female", "gender": "female",
"email": "claricegardner@chorizon.com", "email": "claricegardner@chorizon.com",

View File

@ -156,7 +156,7 @@ async fn placeholder_search_with_filter() {
test_post_get_search!(server, query, |response, _status_code| { test_post_get_search!(server, query, |response, _status_code| {
let hits = response["hits"].as_array().unwrap(); let hits = response["hits"].as_array().unwrap();
assert!(hits.iter().all(|v| v["color"].as_str().unwrap() == "green")); assert!(hits.iter().all(|v| v["color"].as_str().unwrap() == "Green"));
}); });
let query = json!({ let query = json!({
@ -177,7 +177,7 @@ async fn placeholder_search_with_filter() {
let bug = Value::String(String::from("bug")); let bug = Value::String(String::from("bug"));
let wontfix = Value::String(String::from("wontfix")); let wontfix = Value::String(String::from("wontfix"));
assert!(hits.iter().all(|v| assert!(hits.iter().all(|v|
v["color"].as_str().unwrap() == "green" && v["color"].as_str().unwrap() == "Green" &&
v["tags"].as_array().unwrap().contains(&bug) || v["tags"].as_array().unwrap().contains(&bug) ||
v["tags"].as_array().unwrap().contains(&wontfix))); v["tags"].as_array().unwrap().contains(&wontfix)));
}); });
@ -206,7 +206,7 @@ async fn placeholder_test_faceted_search_valid() {
.as_array() .as_array()
.unwrap() .unwrap()
.iter() .iter()
.all(|value| value.get("color").unwrap() == "green")); .all(|value| value.get("color").unwrap() == "Green"));
}); });
let query = json!({ let query = json!({
@ -296,7 +296,7 @@ async fn placeholder_test_faceted_search_valid() {
.unwrap() == "blue" .unwrap() == "blue"
|| value || value
.get("color") .get("color")
.unwrap() == "green")); .unwrap() == "Green"));
}); });
// test and-or: ["tags:bug", ["color:blue", "color:green"]] // test and-or: ["tags:bug", ["color:blue", "color:green"]]
let query = json!({ let query = json!({
@ -322,7 +322,7 @@ async fn placeholder_test_faceted_search_valid() {
.unwrap() == "blue" .unwrap() == "blue"
|| value || value
.get("color") .get("color")
.unwrap() == "green"))); .unwrap() == "Green")));
}); });
} }

View File

@ -21,7 +21,7 @@ async fn search_with_limit() {
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -42,7 +42,7 @@ async fn search_with_limit() {
"balance": "$1,921.58", "balance": "$1,921.58",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 31, "age": 31,
"color": "green", "color": "Green",
"name": "Harper Carson", "name": "Harper Carson",
"gender": "male", "gender": "male",
"email": "harpercarson@chorizon.com", "email": "harpercarson@chorizon.com",
@ -101,7 +101,7 @@ async fn search_with_offset() {
"balance": "$1,921.58", "balance": "$1,921.58",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 31, "age": 31,
"color": "green", "color": "Green",
"name": "Harper Carson", "name": "Harper Carson",
"gender": "male", "gender": "male",
"email": "harpercarson@chorizon.com", "email": "harpercarson@chorizon.com",
@ -142,7 +142,7 @@ async fn search_with_offset() {
"balance": "$2,668.55", "balance": "$2,668.55",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 36, "age": 36,
"color": "green", "color": "Green",
"name": "Lucas Hess", "name": "Lucas Hess",
"gender": "male", "gender": "male",
"email": "lucashess@chorizon.com", "email": "lucashess@chorizon.com",
@ -181,7 +181,7 @@ async fn search_with_attribute_to_highlight_wildcard() {
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -201,7 +201,7 @@ async fn search_with_attribute_to_highlight_wildcard() {
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "<em>Cherry</em> Orr", "name": "<em>Cherry</em> Orr",
"gender": "female", "gender": "female",
"email": "<em>cherry</em>orr@chorizon.com", "email": "<em>cherry</em>orr@chorizon.com",
@ -241,7 +241,7 @@ async fn search_with_attribute_to_highlight_1() {
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -261,7 +261,7 @@ async fn search_with_attribute_to_highlight_1() {
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "<em>Cherry</em> Orr", "name": "<em>Cherry</em> Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -301,7 +301,7 @@ async fn search_with_matches() {
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -355,7 +355,7 @@ async fn search_with_crop() {
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -375,7 +375,7 @@ async fn search_with_crop() {
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -413,7 +413,7 @@ async fn search_with_attributes_to_retrieve() {
{ {
"name": "Cherry Orr", "name": "Cherry Orr",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"gender": "female" "gender": "female"
} }
]); ]);
@ -440,7 +440,7 @@ async fn search_with_attributes_to_retrieve_wildcard() {
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -478,7 +478,7 @@ async fn search_with_filter() {
"balance": "$1,921.58", "balance": "$1,921.58",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 31, "age": 31,
"color": "green", "color": "Green",
"name": "Harper Carson", "name": "Harper Carson",
"gender": "male", "gender": "male",
"email": "harpercarson@chorizon.com", "email": "harpercarson@chorizon.com",
@ -499,7 +499,7 @@ async fn search_with_filter() {
"balance": "$2,668.55", "balance": "$2,668.55",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 36, "age": 36,
"color": "green", "color": "Green",
"name": "Lucas Hess", "name": "Lucas Hess",
"gender": "male", "gender": "male",
"email": "lucashess@chorizon.com", "email": "lucashess@chorizon.com",
@ -547,7 +547,7 @@ async fn search_with_filter() {
"balance": "$2,668.55", "balance": "$2,668.55",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 36, "age": 36,
"color": "green", "color": "Green",
"name": "Lucas Hess", "name": "Lucas Hess",
"gender": "male", "gender": "male",
"email": "lucashess@chorizon.com", "email": "lucashess@chorizon.com",
@ -601,7 +601,7 @@ async fn search_with_filter() {
"balance": "$1,913.42", "balance": "$1,913.42",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 24, "age": 24,
"color": "green", "color": "Green",
"name": "Emma Jacobs", "name": "Emma Jacobs",
"gender": "female", "gender": "female",
"email": "emmajacobs@chorizon.com", "email": "emmajacobs@chorizon.com",
@ -705,7 +705,7 @@ async fn search_with_filter() {
"balance": "$1,921.58", "balance": "$1,921.58",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 31, "age": 31,
"color": "green", "color": "Green",
"name": "Harper Carson", "name": "Harper Carson",
"gender": "male", "gender": "male",
"email": "harpercarson@chorizon.com", "email": "harpercarson@chorizon.com",
@ -726,7 +726,7 @@ async fn search_with_filter() {
"balance": "$2,668.55", "balance": "$2,668.55",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 36, "age": 36,
"color": "green", "color": "Green",
"name": "Lucas Hess", "name": "Lucas Hess",
"gender": "male", "gender": "male",
"email": "lucashess@chorizon.com", "email": "lucashess@chorizon.com",
@ -779,7 +779,7 @@ async fn search_with_filter() {
"balance": "$1,351.43", "balance": "$1,351.43",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 28, "age": 28,
"color": "green", "color": "Green",
"name": "Evans Wagner", "name": "Evans Wagner",
"gender": "male", "gender": "male",
"email": "evanswagner@chorizon.com", "email": "evanswagner@chorizon.com",
@ -823,7 +823,7 @@ async fn search_with_attributes_to_highlight_and_matches() {
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -843,7 +843,7 @@ async fn search_with_attributes_to_highlight_and_matches() {
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "<em>Cherry</em> Orr", "name": "<em>Cherry</em> Orr",
"gender": "female", "gender": "female",
"email": "<em>cherry</em>orr@chorizon.com", "email": "<em>cherry</em>orr@chorizon.com",
@ -900,7 +900,7 @@ async fn search_with_attributes_to_highlight_and_matches_and_crop() {
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -920,7 +920,7 @@ async fn search_with_attributes_to_highlight_and_matches_and_crop() {
"balance": "$1,706.13", "balance": "$1,706.13",
"picture": "http://placehold.it/32x32", "picture": "http://placehold.it/32x32",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -1223,7 +1223,7 @@ async fn test_faceted_search_valid() {
.as_array() .as_array()
.unwrap() .unwrap()
.iter() .iter()
.all(|value| value.get("color").unwrap() == "green")); .all(|value| value.get("color").unwrap() == "Green"));
}); });
let query = json!({ let query = json!({
@ -1318,7 +1318,7 @@ async fn test_faceted_search_valid() {
.unwrap() == "blue" .unwrap() == "blue"
|| value || value
.get("color") .get("color")
.unwrap() == "green")); .unwrap() == "Green"));
}); });
// test and-or: ["tags:bug", ["color:blue", "color:green"]] // test and-or: ["tags:bug", ["color:blue", "color:green"]]
let query = json!({ let query = json!({
@ -1345,7 +1345,7 @@ async fn test_faceted_search_valid() {
.unwrap() == "blue" .unwrap() == "blue"
|| value || value
.get("color") .get("color")
.unwrap() == "green"))); .unwrap() == "Green")));
}); });
} }
@ -1469,6 +1469,14 @@ async fn test_facet_count() {
println!("{}", response); println!("{}", response);
assert!(response.get("exhaustiveFacetsCount").is_some()); assert!(response.get("exhaustiveFacetsCount").is_some());
assert_eq!(response.get("facetsDistribution").unwrap().as_object().unwrap().values().count(), 1); assert_eq!(response.get("facetsDistribution").unwrap().as_object().unwrap().values().count(), 1);
// assert that case is preserved
assert!(response["facetsDistribution"]
.as_object()
.unwrap()["color"]
.as_object()
.unwrap()
.get("Green")
.is_some());
}); });
// searching on color and tags // searching on color and tags
let query = json!({ let query = json!({

View File

@ -130,7 +130,7 @@ async fn search_with_settings_stop_words() {
{ {
"balance": "$1,921.58", "balance": "$1,921.58",
"age": 31, "age": 31,
"color": "green", "color": "Green",
"name": "Harper Carson", "name": "Harper Carson",
"gender": "male", "gender": "male",
"email": "harpercarson@chorizon.com", "email": "harpercarson@chorizon.com",
@ -140,7 +140,7 @@ async fn search_with_settings_stop_words() {
{ {
"balance": "$1,706.13", "balance": "$1,706.13",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -213,7 +213,7 @@ async fn search_with_settings_synonyms() {
{ {
"balance": "$1,921.58", "balance": "$1,921.58",
"age": 31, "age": 31,
"color": "green", "color": "Green",
"name": "Harper Carson", "name": "Harper Carson",
"gender": "male", "gender": "male",
"email": "harpercarson@chorizon.com", "email": "harpercarson@chorizon.com",
@ -223,7 +223,7 @@ async fn search_with_settings_synonyms() {
{ {
"balance": "$1,706.13", "balance": "$1,706.13",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -292,7 +292,7 @@ async fn search_with_settings_ranking_rules() {
{ {
"balance": "$1,921.58", "balance": "$1,921.58",
"age": 31, "age": 31,
"color": "green", "color": "Green",
"name": "Harper Carson", "name": "Harper Carson",
"gender": "male", "gender": "male",
"email": "harpercarson@chorizon.com", "email": "harpercarson@chorizon.com",
@ -302,7 +302,7 @@ async fn search_with_settings_ranking_rules() {
{ {
"balance": "$1,706.13", "balance": "$1,706.13",
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",
@ -438,7 +438,7 @@ async fn search_with_settings_displayed_attributes() {
let expect = json!([ let expect = json!([
{ {
"age": 31, "age": 31,
"color": "green", "color": "Green",
"name": "Harper Carson", "name": "Harper Carson",
"gender": "male", "gender": "male",
"email": "harpercarson@chorizon.com", "email": "harpercarson@chorizon.com",
@ -446,7 +446,7 @@ async fn search_with_settings_displayed_attributes() {
}, },
{ {
"age": 27, "age": 27,
"color": "green", "color": "Green",
"name": "Cherry Orr", "name": "Cherry Orr",
"gender": "female", "gender": "female",
"email": "cherryorr@chorizon.com", "email": "cherryorr@chorizon.com",