use anyhow::{Error, Ok, Result}; use rstest::rstest; use std::{env, io::BufRead}; use surrealdb::{engine::local::Db, Surreal}; use wikidata_to_surrealdb::utils::*; async fn inti_db() -> Result, Error> { env::set_var("WIKIDATA_LANG", "en"); env::set_var("OVERWRITE_DB", "true"); let db = create_db_mem().await?; Ok(db) } fn init_reader(file_format: &str, file_name: &str) -> Box { File_Format::new(file_format) .reader(&format!("./tests/data/{}.{}", file_name, file_format)) .unwrap() } async fn entity_query(db: &Surreal) -> Result, Error> { let x: Option = db .query(r#" return ( select claims.claims[where id = Property:1113][0].value.ClaimValueData.Quantity.amount as number_of_episodes from Entity where label = "Black Clover, season 1" )[0].number_of_episodes; "#) .await .unwrap() .take(0) .unwrap(); Ok(x) } #[tokio::test] async fn entity() { let db = inti_db().await.unwrap(); let reader = init_reader("json", "Entity"); for line in reader.lines() { create_db_entity(&db, &line.unwrap()).await.unwrap(); } assert_eq!(51.0, entity_query(&db).await.unwrap().unwrap()) } #[rstest] #[case(CreateVersion::Single)] #[case(CreateVersion::Bulk)] #[tokio::test] async fn entity_threaded(#[case] version: CreateVersion) -> Result<(), Error> { let db = inti_db().await?; let reader = init_reader("json", "Entity"); create_db_entities_threaded(Some(db.clone()), reader, None, 1_000, 100, version).await?; assert_eq!(51.0, entity_query(&db).await?.unwrap()); Ok(()) } #[tokio::test] async fn entity_threaded_filter() -> Result<(), Error> { env::set_var("FILTER_PATH", "./tests/data/test_filter.surql"); let db = inti_db().await?; let reader = init_reader("json", "bench"); create_db_entities_threaded( Some(db.clone()), reader, None, 1_000, 100, CreateVersion::BulkFilter, ) .await?; let count: Option = db .query("return count(select * from Entity);") .await .unwrap() .take(0) .unwrap(); assert_eq!(3.0, count.unwrap()); Ok(()) } async fn property_query(db: &Surreal) -> Result, Error> { let x: Option = db .query("return count(select * from Property);") .await .unwrap() .take(0) .unwrap(); Ok(x) } #[tokio::test] async fn property() { let db = inti_db().await.unwrap(); let reader = init_reader("json", "Property"); for line in reader.lines() { create_db_entity(&db, &line.unwrap()).await.unwrap(); } assert_eq!(2.0, property_query(&db).await.unwrap().unwrap()) } #[rstest] #[case(CreateVersion::Single)] #[case(CreateVersion::Bulk)] #[tokio::test] async fn property_threaded(#[case] version: CreateVersion) -> Result<(), Error> { let db = inti_db().await?; let reader = init_reader("json", "Property"); create_db_entities_threaded(Some(db.clone()), reader, None, 1_000, 100, version).await?; assert_eq!(2.0, property_query(&db).await?.unwrap()); Ok(()) }