sea-orm/tests/collection_tests.rs
Billy Chan e6b6629733 Revert SeaORM prelude
Add `stream_partial_model` to `Select<E>` and `SelectTwo<E,F>`

Minor refactoring

fmt

Add `into_partial_model` to `Cursor<S>`

refactoring

Add test cases

Fix test cases

More test cases

Move partial_model tests
2023-04-26 18:28:53 +08:00

179 lines
4.8 KiB
Rust

pub mod common;
pub use common::{features::*, setup::*, TestContext};
use pretty_assertions::assert_eq;
use sea_orm::{
entity::prelude::*, entity::*, DatabaseConnection, DerivePartialModel, FromQueryResult,
};
#[sea_orm_macros::test]
#[cfg(all(feature = "sqlx-postgres", feature = "postgres-array"))]
async fn main() -> Result<(), DbErr> {
let ctx = TestContext::new("collection_tests").await;
create_tables(&ctx.db).await?;
insert_collection(&ctx.db).await?;
update_collection(&ctx.db).await?;
select_collection(&ctx.db).await?;
ctx.delete().await;
Ok(())
}
pub async fn insert_collection(db: &DatabaseConnection) -> Result<(), DbErr> {
use collection::*;
let uuid = Uuid::new_v4();
assert_eq!(
Model {
id: 1,
name: "Collection 1".into(),
integers: vec![1, 2, 3],
integers_opt: Some(vec![1, 2, 3]),
teas: vec![Tea::BreakfastTea],
teas_opt: Some(vec![Tea::BreakfastTea]),
colors: vec![Color::Black],
colors_opt: Some(vec![Color::Black]),
uuid: vec![uuid],
uuid_hyphenated: vec![uuid.hyphenated()],
}
.into_active_model()
.insert(db)
.await?,
Model {
id: 1,
name: "Collection 1".into(),
integers: vec![1, 2, 3],
integers_opt: Some(vec![1, 2, 3]),
teas: vec![Tea::BreakfastTea],
teas_opt: Some(vec![Tea::BreakfastTea]),
colors: vec![Color::Black],
colors_opt: Some(vec![Color::Black]),
uuid: vec![uuid],
uuid_hyphenated: vec![uuid.hyphenated()],
}
);
assert_eq!(
Model {
id: 2,
name: "Collection 2".into(),
integers: vec![10, 9],
integers_opt: None,
teas: vec![Tea::BreakfastTea],
teas_opt: None,
colors: vec![Color::Black],
colors_opt: None,
uuid: vec![uuid],
uuid_hyphenated: vec![uuid.hyphenated()],
}
.into_active_model()
.insert(db)
.await?,
Model {
id: 2,
name: "Collection 2".into(),
integers: vec![10, 9],
integers_opt: None,
teas: vec![Tea::BreakfastTea],
teas_opt: None,
colors: vec![Color::Black],
colors_opt: None,
uuid: vec![uuid],
uuid_hyphenated: vec![uuid.hyphenated()],
}
);
assert_eq!(
Model {
id: 3,
name: "Collection 3".into(),
integers: vec![],
integers_opt: Some(vec![]),
teas: vec![],
teas_opt: Some(vec![]),
colors: vec![],
colors_opt: Some(vec![]),
uuid: vec![uuid],
uuid_hyphenated: vec![uuid.hyphenated()],
}
.into_active_model()
.insert(db)
.await?,
Model {
id: 3,
name: "Collection 3".into(),
integers: vec![],
integers_opt: Some(vec![]),
teas: vec![],
teas_opt: Some(vec![]),
colors: vec![],
colors_opt: Some(vec![]),
uuid: vec![uuid],
uuid_hyphenated: vec![uuid.hyphenated()],
}
);
Ok(())
}
pub async fn update_collection(db: &DatabaseConnection) -> Result<(), DbErr> {
use collection::*;
let uuid = Uuid::new_v4();
let model = Entity::find_by_id(1).one(db).await?.unwrap();
ActiveModel {
integers: Set(vec![4, 5, 6]),
integers_opt: Set(Some(vec![4, 5, 6])),
teas: Set(vec![Tea::EverydayTea]),
teas_opt: Set(Some(vec![Tea::EverydayTea])),
colors: Set(vec![Color::White]),
colors_opt: Set(Some(vec![Color::White])),
..model.into_active_model()
}
.update(db)
.await?;
ActiveModel {
id: Unchanged(3),
name: Set("Collection 3".into()),
integers: Set(vec![3, 1, 4]),
integers_opt: Set(None),
teas: Set(vec![Tea::EverydayTea]),
teas_opt: Set(None),
colors: Set(vec![Color::White]),
colors_opt: Set(None),
uuid: Set(vec![uuid]),
uuid_hyphenated: Set(vec![uuid.hyphenated()]),
}
.update(db)
.await?;
Ok(())
}
pub async fn select_collection(db: &DatabaseConnection) -> Result<(), DbErr> {
use collection::*;
#[derive(DerivePartialModel, FromQueryResult, Debug, PartialEq)]
#[sea_orm(entity = "Entity")]
struct PartialSelectResult {
name: String,
}
let result = Entity::find_by_id(1)
.into_partial_model::<PartialSelectResult>()
.one(db)
.await?;
assert_eq!(
result,
Some(PartialSelectResult {
name: "Collection 1".into(),
})
);
Ok(())
}