use serde::Deserialize;
use super::{Outcome, TestFile};
use crate::{
bson::{Bson, Document},
options::{Collation, DistinctOptions},
test::{run_spec_test, util::TestClient, LOCK},
};
#[derive(Debug, Deserialize)]
#[serde(rename_all = "camelCase")]
struct Arguments {
pub filter: Option<Document>,
pub field_name: String,
pub collation: Option<Collation>,
}
#[function_name::named]
async fn run_distinct_test(test_file: TestFile) {
let client = TestClient::new().await;
let data = test_file.data;
for mut test_case in test_file.tests {
if test_case.operation.name != "distinct" {
continue;
}
let _guard = LOCK.run_concurrently().await;
test_case.description = test_case.description.replace('$', "%");
let coll = client
.init_db_and_coll(function_name!(), &test_case.description)
.await;
coll.insert_many(data.clone(), None)
.await
.expect(&test_case.description);
let arguments: Arguments = bson::from_bson(Bson::Document(test_case.operation.arguments))
.expect(&test_case.description);
let outcome: Outcome<Vec<Bson>> =
bson::from_bson(Bson::Document(test_case.outcome)).expect(&test_case.description);
if let Some(ref c) = outcome.collection {
if let Some(ref name) = c.name {
client.drop_collection(function_name!(), name).await;
}
}
let opts = DistinctOptions {
collation: arguments.collation,
..Default::default()
};
let result = coll
.distinct(&arguments.field_name, arguments.filter, opts)
.await
.expect(&test_case.description);
assert_eq!(result, outcome.result, "{}", test_case.description);
}
}
#[cfg_attr(feature = "tokio-runtime", tokio::test)]
#[cfg_attr(feature = "async-std-runtime", async_std::test)]
async fn run() {
run_spec_test(&["crud", "v1", "read"], run_distinct_test).await;
}