morethantext-web/src/morethantext/mod.rs

136 lines
3.6 KiB
Rust
Raw Normal View History

2022-08-06 12:03:47 -04:00
pub mod error;
use async_std::sync::{Arc, RwLock};
2022-09-27 07:31:59 -04:00
use error::DBError;
2022-08-06 12:03:47 -04:00
use std::collections::HashMap;
2022-07-18 17:24:45 -04:00
#[derive(Clone)]
2022-08-06 12:03:47 -04:00
pub struct MoreThanText {
2022-09-27 07:31:59 -04:00
databases: Arc<RwLock<HashMap<String, Database>>>,
2022-08-06 12:03:47 -04:00
}
2022-07-18 17:24:45 -04:00
impl MoreThanText {
pub async fn new() -> Self {
2022-08-06 12:03:47 -04:00
Self {
2022-09-27 07:31:59 -04:00
databases: Arc::new(RwLock::new(HashMap::new())),
2022-08-06 12:03:47 -04:00
}
}
2022-09-27 07:31:59 -04:00
async fn create_database(&self, name: &str) -> Result<(), DBError> {
let mut databases = self.databases.write().await;
match databases.get(name) {
Some(_) => Err(DBError::new("duplicate database name")),
2022-08-06 12:03:47 -04:00
None => {
2022-09-27 07:31:59 -04:00
let db = Database::new().await;
databases.insert(name.to_string(), db);
Ok(())
2022-08-06 12:03:47 -04:00
}
}
}
2022-08-07 09:29:08 -04:00
2022-10-31 10:01:07 -04:00
async fn use_database(&self, name: &str) -> Result<Database, DBError> {
2022-09-27 07:31:59 -04:00
let databases = self.databases.read().await;
match databases.get(name) {
2022-10-31 10:01:07 -04:00
Some(db) => Ok(db.clone()),
2022-09-27 07:31:59 -04:00
None => Err(DBError::new("database name not found")),
2022-08-07 09:29:08 -04:00
}
}
}
2022-10-31 10:01:07 -04:00
#[derive(Clone)]
2022-09-27 07:31:59 -04:00
struct Database;
2022-08-05 16:47:01 -04:00
2022-09-27 07:31:59 -04:00
impl Database {
async fn new() -> Self {
2022-08-05 16:47:01 -04:00
Self {}
}
2022-10-23 16:55:29 -04:00
2022-10-31 10:01:07 -04:00
async fn add_table(&self, _name: &str) {}
2022-08-05 16:47:01 -04:00
}
#[cfg(test)]
2022-09-27 07:31:59 -04:00
mod engine_functions {
use super::*;
#[async_std::test]
2022-09-27 07:31:59 -04:00
async fn create_database() {
let mtt = MoreThanText::new().await;
mtt.create_database("smith").await.unwrap();
}
2022-08-06 12:03:47 -04:00
#[async_std::test]
2022-09-27 07:31:59 -04:00
async fn database_names_must_be_unique() -> Result<(), DBError> {
let mtt = MoreThanText::new().await;
let msg = "duplicate database name";
mtt.create_database("john").await.unwrap();
match mtt.create_database("john").await {
Ok(_) => Err(DBError::new("Duplicate names should cause error")),
2022-08-06 12:03:47 -04:00
Err(err) => {
if err.to_string() == msg {
Ok(())
} else {
2022-09-27 07:31:59 -04:00
Err(DBError::new(format!(
"incorrect err message: got: '{}' want: '{}'",
2022-08-06 12:03:47 -04:00
err.to_string(),
msg
2022-09-27 07:31:59 -04:00
)))
2022-08-06 12:03:47 -04:00
}
}
}
}
2022-08-07 09:29:08 -04:00
#[async_std::test]
2022-09-27 07:31:59 -04:00
async fn use_database() -> Result<(), DBError> {
let mtt = MoreThanText::new().await;
let dbname = "Johnson";
mtt.create_database(dbname).await.unwrap();
mtt.use_database(dbname).await.unwrap();
Ok(())
2022-08-07 09:29:08 -04:00
}
#[async_std::test]
2022-09-27 07:31:59 -04:00
async fn use_missing_database() -> Result<(), DBError> {
let error = "database name not found";
let mtt = MoreThanText::new().await;
match mtt.use_database("ssmith").await {
Ok(_) => Err(DBError::new("Should raise database missing error")),
Err(err) => {
if err.to_string() == error {
Ok(())
} else {
Err(DBError::new(format!(
"Incorrect error message: Got '{}' Want '{}'",
err.to_string(),
error
)))
}
}
}
2022-08-07 09:29:08 -04:00
}
2022-10-31 10:01:07 -04:00
#[async_std::test]
async fn create_get_table() {
let db = "thedatabase";
let mtt = MoreThanText::new().await;
mtt.create_database(db).await.unwrap();
let dbase = mtt.use_database(db).await.unwrap();
dbase.add_table("melvin").await;
}
}
2022-08-05 16:47:01 -04:00
#[cfg(test)]
2022-09-27 07:31:59 -04:00
mod database_functions {
2022-08-05 16:47:01 -04:00
use super::*;
#[async_std::test]
2022-09-27 07:31:59 -04:00
async fn new_database() {
Database::new().await;
}
#[async_std::test]
2022-10-31 10:01:07 -04:00
async fn new_table() {
2022-10-23 16:55:29 -04:00
let db = Database::new().await;
2022-10-31 10:01:07 -04:00
db.add_table("fred").await;
2022-08-05 16:47:01 -04:00
}
}