2021-06-03 20:44:53 +08:00
|
|
|
use big_s::S;
|
2021-06-15 19:45:20 +08:00
|
|
|
use milli::update::Settings;
|
2021-06-17 00:33:33 +08:00
|
|
|
use milli::{Criterion, Search, SearchResult};
|
|
|
|
use Criterion::*;
|
2021-06-03 20:44:53 +08:00
|
|
|
|
|
|
|
use crate::search::{self, EXTERNAL_DOCUMENTS_IDS};
|
2021-06-08 18:33:02 +08:00
|
|
|
|
|
|
|
const ALLOW_TYPOS: bool = true;
|
|
|
|
const DISALLOW_TYPOS: bool = false;
|
|
|
|
const ALLOW_OPTIONAL_WORDS: bool = true;
|
|
|
|
const DISALLOW_OPTIONAL_WORDS: bool = false;
|
|
|
|
|
|
|
|
macro_rules! test_criterion {
|
2021-06-17 20:24:59 +08:00
|
|
|
($func:ident, $optional_word:ident, $authorize_typos:ident, $criteria:expr) => {
|
2021-06-08 18:33:02 +08:00
|
|
|
#[test]
|
|
|
|
fn $func() {
|
2021-06-17 20:24:59 +08:00
|
|
|
let criteria = $criteria;
|
2021-06-08 18:33:02 +08:00
|
|
|
let index = search::setup_search_index_with_criteria(&criteria);
|
2021-06-17 21:19:03 +08:00
|
|
|
let rtxn = index.read_txn().unwrap();
|
2021-06-08 18:33:02 +08:00
|
|
|
|
2021-06-17 21:19:03 +08:00
|
|
|
let mut search = Search::new(&rtxn, &index);
|
2021-06-08 18:33:02 +08:00
|
|
|
search.query(search::TEST_QUERY);
|
|
|
|
search.limit(EXTERNAL_DOCUMENTS_IDS.len());
|
|
|
|
search.authorize_typos($authorize_typos);
|
|
|
|
search.optional_words($optional_word);
|
|
|
|
|
2021-06-08 20:11:00 +08:00
|
|
|
let SearchResult { documents_ids, .. } = search.execute().unwrap();
|
2021-06-08 18:33:02 +08:00
|
|
|
|
2021-06-17 19:56:09 +08:00
|
|
|
let expected_external_ids: Vec<_> =
|
|
|
|
search::expected_order(&criteria, $authorize_typos, $optional_word)
|
|
|
|
.into_iter()
|
|
|
|
.map(|d| d.id)
|
|
|
|
.collect();
|
2021-06-08 18:33:02 +08:00
|
|
|
let documents_ids = search::internal_to_external_ids(&index, &documents_ids);
|
|
|
|
assert_eq!(documents_ids, expected_external_ids);
|
|
|
|
}
|
2021-06-17 19:56:09 +08:00
|
|
|
};
|
2021-06-08 18:33:02 +08:00
|
|
|
}
|
|
|
|
|
2021-06-17 21:19:03 +08:00
|
|
|
test_criterion!(none_allow_typo, ALLOW_OPTIONAL_WORDS, ALLOW_TYPOS, vec![]);
|
|
|
|
test_criterion!(none_disallow_typo, DISALLOW_OPTIONAL_WORDS, DISALLOW_TYPOS, vec![]);
|
|
|
|
test_criterion!(words_allow_typo, ALLOW_OPTIONAL_WORDS, ALLOW_TYPOS, vec![Words]);
|
|
|
|
test_criterion!(attribute_allow_typo, DISALLOW_OPTIONAL_WORDS, ALLOW_TYPOS, vec![Attribute]);
|
|
|
|
test_criterion!(attribute_disallow_typo, DISALLOW_OPTIONAL_WORDS, DISALLOW_TYPOS, vec![Attribute]);
|
|
|
|
test_criterion!(exactness_allow_typo, DISALLOW_OPTIONAL_WORDS, ALLOW_TYPOS, vec![Exactness]);
|
|
|
|
test_criterion!(exactness_disallow_typo, DISALLOW_OPTIONAL_WORDS, DISALLOW_TYPOS, vec![Exactness]);
|
|
|
|
test_criterion!(proximity_allow_typo, DISALLOW_OPTIONAL_WORDS, ALLOW_TYPOS, vec![Proximity]);
|
|
|
|
test_criterion!(proximity_disallow_typo, DISALLOW_OPTIONAL_WORDS, DISALLOW_TYPOS, vec![Proximity]);
|
|
|
|
test_criterion!(
|
|
|
|
asc_allow_typo,
|
|
|
|
DISALLOW_OPTIONAL_WORDS,
|
|
|
|
ALLOW_TYPOS,
|
|
|
|
vec![Asc(S("asc_desc_rank"))]
|
|
|
|
);
|
|
|
|
test_criterion!(
|
|
|
|
asc_disallow_typo,
|
|
|
|
DISALLOW_OPTIONAL_WORDS,
|
|
|
|
DISALLOW_TYPOS,
|
|
|
|
vec![Asc(S("asc_desc_rank"))]
|
|
|
|
);
|
|
|
|
test_criterion!(
|
|
|
|
desc_allow_typo,
|
|
|
|
DISALLOW_OPTIONAL_WORDS,
|
|
|
|
ALLOW_TYPOS,
|
|
|
|
vec![Desc(S("asc_desc_rank"))]
|
|
|
|
);
|
|
|
|
test_criterion!(
|
|
|
|
desc_disallow_typo,
|
|
|
|
DISALLOW_OPTIONAL_WORDS,
|
|
|
|
DISALLOW_TYPOS,
|
|
|
|
vec![Desc(S("asc_desc_rank"))]
|
|
|
|
);
|
|
|
|
test_criterion!(
|
|
|
|
asc_unexisting_field_allow_typo,
|
|
|
|
DISALLOW_OPTIONAL_WORDS,
|
|
|
|
ALLOW_TYPOS,
|
|
|
|
vec![Asc(S("unexisting_field"))]
|
|
|
|
);
|
|
|
|
test_criterion!(
|
|
|
|
asc_unexisting_field_disallow_typo,
|
|
|
|
DISALLOW_OPTIONAL_WORDS,
|
|
|
|
DISALLOW_TYPOS,
|
|
|
|
vec![Asc(S("unexisting_field"))]
|
|
|
|
);
|
|
|
|
test_criterion!(
|
|
|
|
desc_unexisting_field_allow_typo,
|
|
|
|
DISALLOW_OPTIONAL_WORDS,
|
|
|
|
ALLOW_TYPOS,
|
|
|
|
vec![Desc(S("unexisting_field"))]
|
|
|
|
);
|
|
|
|
test_criterion!(
|
|
|
|
desc_unexisting_field_disallow_typo,
|
|
|
|
DISALLOW_OPTIONAL_WORDS,
|
|
|
|
DISALLOW_TYPOS,
|
|
|
|
vec![Desc(S("unexisting_field"))]
|
|
|
|
);
|
|
|
|
test_criterion!(
|
|
|
|
default_criteria_order,
|
|
|
|
ALLOW_OPTIONAL_WORDS,
|
|
|
|
ALLOW_TYPOS,
|
|
|
|
vec![Words, Typo, Proximity, Attribute, Exactness]
|
|
|
|
);
|
2021-06-03 20:44:53 +08:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn criteria_mixup() {
|
|
|
|
use Criterion::*;
|
2021-06-17 00:33:33 +08:00
|
|
|
let index = search::setup_search_index_with_criteria(&vec![
|
|
|
|
Words,
|
|
|
|
Attribute,
|
|
|
|
Desc(S("asc_desc_rank")),
|
|
|
|
Exactness,
|
|
|
|
Proximity,
|
|
|
|
Typo,
|
|
|
|
]);
|
2021-06-03 20:44:53 +08:00
|
|
|
|
2021-06-17 00:33:33 +08:00
|
|
|
#[rustfmt::skip]
|
2021-06-03 20:44:53 +08:00
|
|
|
let criteria_mix = {
|
2021-06-08 20:11:00 +08:00
|
|
|
// Criterion doesn't implement Copy, we create a new Criterion using a closure
|
2021-06-03 20:44:53 +08:00
|
|
|
let desc = || Desc(S("asc_desc_rank"));
|
|
|
|
// all possible criteria order
|
|
|
|
vec![
|
|
|
|
vec![Words, Attribute, desc(), Exactness, Proximity, Typo],
|
|
|
|
vec![Words, Attribute, desc(), Exactness, Typo, Proximity],
|
|
|
|
vec![Words, Attribute, desc(), Proximity, Exactness, Typo],
|
|
|
|
vec![Words, Attribute, desc(), Proximity, Typo, Exactness],
|
|
|
|
vec![Words, Attribute, desc(), Typo, Exactness, Proximity],
|
|
|
|
vec![Words, Attribute, desc(), Typo, Proximity, Exactness],
|
|
|
|
vec![Words, Attribute, Exactness, desc(), Proximity, Typo],
|
|
|
|
vec![Words, Attribute, Exactness, desc(), Typo, Proximity],
|
|
|
|
vec![Words, Attribute, Exactness, Proximity, desc(), Typo],
|
|
|
|
vec![Words, Attribute, Exactness, Proximity, Typo, desc()],
|
|
|
|
vec![Words, Attribute, Exactness, Typo, desc(), Proximity],
|
|
|
|
vec![Words, Attribute, Exactness, Typo, Proximity, desc()],
|
|
|
|
vec![Words, Attribute, Proximity, desc(), Exactness, Typo],
|
|
|
|
vec![Words, Attribute, Proximity, desc(), Typo, Exactness],
|
|
|
|
vec![Words, Attribute, Proximity, Exactness, desc(), Typo],
|
|
|
|
vec![Words, Attribute, Proximity, Exactness, Typo, desc()],
|
|
|
|
vec![Words, Attribute, Proximity, Typo, desc(), Exactness],
|
|
|
|
vec![Words, Attribute, Proximity, Typo, Exactness, desc()],
|
|
|
|
vec![Words, Attribute, Typo, desc(), Exactness, Proximity],
|
|
|
|
vec![Words, Attribute, Typo, desc(), Proximity, Exactness],
|
|
|
|
vec![Words, Attribute, Typo, Exactness, desc(), Proximity],
|
|
|
|
vec![Words, Attribute, Typo, Exactness, Proximity, desc()],
|
|
|
|
vec![Words, Attribute, Typo, Proximity, desc(), Exactness],
|
|
|
|
vec![Words, Attribute, Typo, Proximity, Exactness, desc()],
|
|
|
|
vec![Words, desc(), Attribute, Exactness, Proximity, Typo],
|
|
|
|
vec![Words, desc(), Attribute, Exactness, Typo, Proximity],
|
|
|
|
vec![Words, desc(), Attribute, Proximity, Exactness, Typo],
|
|
|
|
vec![Words, desc(), Attribute, Proximity, Typo, Exactness],
|
|
|
|
vec![Words, desc(), Attribute, Typo, Exactness, Proximity],
|
|
|
|
vec![Words, desc(), Attribute, Typo, Proximity, Exactness],
|
|
|
|
vec![Words, desc(), Exactness, Attribute, Proximity, Typo],
|
|
|
|
vec![Words, desc(), Exactness, Attribute, Typo, Proximity],
|
|
|
|
vec![Words, desc(), Exactness, Proximity, Attribute, Typo],
|
|
|
|
vec![Words, desc(), Exactness, Proximity, Typo, Attribute],
|
|
|
|
vec![Words, desc(), Exactness, Typo, Attribute, Proximity],
|
|
|
|
vec![Words, desc(), Exactness, Typo, Proximity, Attribute],
|
|
|
|
vec![Words, desc(), Proximity, Attribute, Exactness, Typo],
|
|
|
|
vec![Words, desc(), Proximity, Attribute, Typo, Exactness],
|
|
|
|
vec![Words, desc(), Proximity, Exactness, Attribute, Typo],
|
|
|
|
vec![Words, desc(), Proximity, Exactness, Typo, Attribute],
|
|
|
|
vec![Words, desc(), Proximity, Typo, Attribute, Exactness],
|
|
|
|
vec![Words, desc(), Proximity, Typo, Exactness, Attribute],
|
|
|
|
vec![Words, desc(), Typo, Attribute, Exactness, Proximity],
|
|
|
|
vec![Words, desc(), Typo, Attribute, Proximity, Exactness],
|
|
|
|
vec![Words, desc(), Typo, Exactness, Attribute, Proximity],
|
|
|
|
vec![Words, desc(), Typo, Exactness, Proximity, Attribute],
|
|
|
|
vec![Words, desc(), Typo, Proximity, Attribute, Exactness],
|
|
|
|
vec![Words, desc(), Typo, Proximity, Exactness, Attribute],
|
|
|
|
vec![Words, Exactness, Attribute, desc(), Proximity, Typo],
|
|
|
|
vec![Words, Exactness, Attribute, desc(), Typo, Proximity],
|
|
|
|
vec![Words, Exactness, Attribute, Proximity, desc(), Typo],
|
|
|
|
vec![Words, Exactness, Attribute, Proximity, Typo, desc()],
|
|
|
|
vec![Words, Exactness, Attribute, Typo, desc(), Proximity],
|
|
|
|
vec![Words, Exactness, Attribute, Typo, Proximity, desc()],
|
|
|
|
vec![Words, Exactness, desc(), Attribute, Proximity, Typo],
|
|
|
|
vec![Words, Exactness, desc(), Attribute, Typo, Proximity],
|
|
|
|
vec![Words, Exactness, desc(), Proximity, Attribute, Typo],
|
|
|
|
vec![Words, Exactness, desc(), Proximity, Typo, Attribute],
|
|
|
|
vec![Words, Exactness, desc(), Typo, Attribute, Proximity],
|
|
|
|
vec![Words, Exactness, desc(), Typo, Proximity, Attribute],
|
|
|
|
vec![Words, Exactness, Proximity, Attribute, desc(), Typo],
|
|
|
|
vec![Words, Exactness, Proximity, Attribute, Typo, desc()],
|
|
|
|
vec![Words, Exactness, Proximity, desc(), Attribute, Typo],
|
|
|
|
vec![Words, Exactness, Proximity, desc(), Typo, Attribute],
|
|
|
|
vec![Words, Exactness, Proximity, Typo, Attribute, desc()],
|
|
|
|
vec![Words, Exactness, Proximity, Typo, desc(), Attribute],
|
|
|
|
vec![Words, Exactness, Typo, Attribute, desc(), Proximity],
|
|
|
|
vec![Words, Exactness, Typo, Attribute, Proximity, desc()],
|
|
|
|
vec![Words, Exactness, Typo, desc(), Attribute, Proximity],
|
|
|
|
vec![Words, Exactness, Typo, desc(), Proximity, Attribute],
|
|
|
|
vec![Words, Exactness, Typo, Proximity, Attribute, desc()],
|
|
|
|
vec![Words, Exactness, Typo, Proximity, desc(), Attribute],
|
|
|
|
vec![Words, Proximity, Attribute, desc(), Exactness, Typo],
|
|
|
|
vec![Words, Proximity, Attribute, desc(), Typo, Exactness],
|
|
|
|
vec![Words, Proximity, Attribute, Exactness, desc(), Typo],
|
|
|
|
vec![Words, Proximity, Attribute, Exactness, Typo, desc()],
|
|
|
|
vec![Words, Proximity, Attribute, Typo, desc(), Exactness],
|
|
|
|
vec![Words, Proximity, Attribute, Typo, Exactness, desc()],
|
|
|
|
vec![Words, Proximity, desc(), Attribute, Exactness, Typo],
|
|
|
|
vec![Words, Proximity, desc(), Attribute, Typo, Exactness],
|
|
|
|
vec![Words, Proximity, desc(), Exactness, Attribute, Typo],
|
|
|
|
vec![Words, Proximity, desc(), Exactness, Typo, Attribute],
|
|
|
|
vec![Words, Proximity, desc(), Typo, Attribute, Exactness],
|
|
|
|
vec![Words, Proximity, desc(), Typo, Exactness, Attribute],
|
|
|
|
vec![Words, Proximity, Exactness, Attribute, desc(), Typo],
|
|
|
|
vec![Words, Proximity, Exactness, Attribute, Typo, desc()],
|
|
|
|
vec![Words, Proximity, Exactness, desc(), Attribute, Typo],
|
|
|
|
vec![Words, Proximity, Exactness, desc(), Typo, Attribute],
|
|
|
|
vec![Words, Proximity, Exactness, Typo, Attribute, desc()],
|
|
|
|
vec![Words, Proximity, Exactness, Typo, desc(), Attribute],
|
|
|
|
vec![Words, Proximity, Typo, Attribute, desc(), Exactness],
|
|
|
|
vec![Words, Proximity, Typo, Attribute, Exactness, desc()],
|
|
|
|
vec![Words, Proximity, Typo, desc(), Attribute, Exactness],
|
|
|
|
vec![Words, Proximity, Typo, desc(), Exactness, Attribute],
|
|
|
|
vec![Words, Proximity, Typo, Exactness, Attribute, desc()],
|
|
|
|
vec![Words, Proximity, Typo, Exactness, desc(), Attribute],
|
|
|
|
vec![Words, Typo, Attribute, desc(), Exactness, Proximity],
|
|
|
|
vec![Words, Typo, Attribute, desc(), Proximity, Exactness],
|
|
|
|
vec![Words, Typo, Attribute, Exactness, desc(), Proximity],
|
|
|
|
vec![Words, Typo, Attribute, Exactness, Proximity, desc()],
|
|
|
|
vec![Words, Typo, Attribute, Proximity, desc(), Exactness],
|
|
|
|
vec![Words, Typo, Attribute, Proximity, Exactness, desc()],
|
|
|
|
vec![Words, Typo, desc(), Attribute, Proximity, Exactness],
|
|
|
|
vec![Words, Typo, desc(), Exactness, Attribute, Proximity],
|
|
|
|
vec![Words, Typo, desc(), Exactness, Attribute, Proximity],
|
|
|
|
vec![Words, Typo, desc(), Exactness, Proximity, Attribute],
|
|
|
|
vec![Words, Typo, desc(), Proximity, Attribute, Exactness],
|
|
|
|
vec![Words, Typo, desc(), Proximity, Exactness, Attribute],
|
|
|
|
vec![Words, Typo, Exactness, Attribute, desc(), Proximity],
|
|
|
|
vec![Words, Typo, Exactness, Attribute, Proximity, desc()],
|
|
|
|
vec![Words, Typo, Exactness, desc(), Attribute, Proximity],
|
|
|
|
vec![Words, Typo, Exactness, desc(), Proximity, Attribute],
|
|
|
|
vec![Words, Typo, Exactness, Proximity, Attribute, desc()],
|
|
|
|
vec![Words, Typo, Exactness, Proximity, desc(), Attribute],
|
|
|
|
vec![Words, Typo, Proximity, Attribute, desc(), Exactness],
|
|
|
|
vec![Words, Typo, Proximity, Attribute, Exactness, desc()],
|
|
|
|
vec![Words, Typo, Proximity, desc(), Attribute, Exactness],
|
|
|
|
vec![Words, Typo, Proximity, desc(), Exactness, Attribute],
|
|
|
|
vec![Words, Typo, Proximity, Exactness, Attribute, desc()],
|
|
|
|
vec![Words, Typo, Proximity, Exactness, desc(), Attribute],
|
|
|
|
]
|
|
|
|
};
|
|
|
|
|
|
|
|
for criteria in criteria_mix {
|
|
|
|
eprintln!("Testing with criteria order: {:?}", &criteria);
|
|
|
|
//update criteria
|
|
|
|
let mut wtxn = index.write_txn().unwrap();
|
2021-06-15 19:45:20 +08:00
|
|
|
let mut builder = Settings::new(&mut wtxn, &index, 0);
|
|
|
|
builder.set_criteria(criteria.iter().map(ToString::to_string).collect());
|
|
|
|
builder.execute(|_, _| ()).unwrap();
|
2021-06-03 20:44:53 +08:00
|
|
|
wtxn.commit().unwrap();
|
|
|
|
|
|
|
|
let mut rtxn = index.read_txn().unwrap();
|
|
|
|
|
|
|
|
let mut search = Search::new(&mut rtxn, &index);
|
|
|
|
search.query(search::TEST_QUERY);
|
|
|
|
search.limit(EXTERNAL_DOCUMENTS_IDS.len());
|
2021-06-08 20:11:00 +08:00
|
|
|
search.optional_words(ALLOW_OPTIONAL_WORDS);
|
|
|
|
search.authorize_typos(ALLOW_TYPOS);
|
2021-06-03 20:44:53 +08:00
|
|
|
|
2021-06-08 20:11:00 +08:00
|
|
|
let SearchResult { documents_ids, .. } = search.execute().unwrap();
|
2021-06-03 20:44:53 +08:00
|
|
|
|
2021-06-17 00:33:33 +08:00
|
|
|
let expected_external_ids: Vec<_> =
|
|
|
|
search::expected_order(&criteria, ALLOW_OPTIONAL_WORDS, ALLOW_TYPOS)
|
|
|
|
.into_iter()
|
|
|
|
.map(|d| d.id)
|
|
|
|
.collect();
|
2021-06-03 20:44:53 +08:00
|
|
|
let documents_ids = search::internal_to_external_ids(&index, &documents_ids);
|
|
|
|
|
|
|
|
assert_eq!(documents_ids, expected_external_ids);
|
|
|
|
}
|
|
|
|
}
|