Test update cake
This commit is contained in:
parent
883bd1605d
commit
7ebfddae91
@ -31,4 +31,6 @@ async fn create_entities(db: &DbConn) {
|
||||
crud::create_cake::test_create_cake(db).await;
|
||||
crud::create_lineitem::test_create_lineitem(db).await;
|
||||
crud::create_order::test_create_order(db).await;
|
||||
|
||||
crud::updates::test_update_cake(db).await;
|
||||
}
|
||||
|
@ -5,6 +5,7 @@ pub use super::bakery_chain::*;
|
||||
pub mod create_cake;
|
||||
pub mod create_lineitem;
|
||||
pub mod create_order;
|
||||
pub mod updates;
|
||||
|
||||
pub async fn test_create_bakery(db: &DbConn) {
|
||||
let seaside_bakery = bakery::ActiveModel {
|
||||
|
55
tests/crud/updates.rs
Normal file
55
tests/crud/updates.rs
Normal file
@ -0,0 +1,55 @@
|
||||
pub use super::*;
|
||||
use rust_decimal_macros::dec;
|
||||
|
||||
pub async fn test_update_cake(db: &DbConn) {
|
||||
let seaside_bakery = bakery::ActiveModel {
|
||||
name: Set("SeaSide Bakery".to_owned()),
|
||||
profit_margin: Set(10.4),
|
||||
..Default::default()
|
||||
};
|
||||
let bakery_insert_res: InsertResult = Bakery::insert(seaside_bakery)
|
||||
.exec(db)
|
||||
.await
|
||||
.expect("could not insert bakery");
|
||||
|
||||
let mud_cake = cake::ActiveModel {
|
||||
name: Set("Mud Cake".to_owned()),
|
||||
price: Set(dec!(10.25)),
|
||||
gluten_free: Set(false),
|
||||
bakery_id: Set(Some(bakery_insert_res.last_insert_id as i32)),
|
||||
..Default::default()
|
||||
};
|
||||
|
||||
let cake_insert_res: InsertResult = Cake::insert(mud_cake)
|
||||
.exec(db)
|
||||
.await
|
||||
.expect("could not insert cake");
|
||||
|
||||
let cake: Option<cake::Model> = Cake::find_by_id(cake_insert_res.last_insert_id)
|
||||
.one(db)
|
||||
.await
|
||||
.expect("could not find cake");
|
||||
|
||||
assert!(cake.is_some());
|
||||
let cake_model = cake.unwrap();
|
||||
assert_eq!(cake_model.name, "Mud Cake");
|
||||
assert_eq!(cake_model.price, dec!(10.25));
|
||||
assert_eq!(cake_model.gluten_free, false);
|
||||
|
||||
let mut cake_am: cake::ActiveModel = cake_model.into();
|
||||
cake_am.name = Set("Extra chocolate mud cake".to_owned());
|
||||
cake_am.price = Set(dec!(20.00));
|
||||
|
||||
let _cake_update_res: cake::ActiveModel = Cake::update(cake_am)
|
||||
.exec(db)
|
||||
.await
|
||||
.expect("could not update cake");
|
||||
|
||||
let cake: Option<cake::Model> = Cake::find_by_id(cake_insert_res.last_insert_id)
|
||||
.one(db)
|
||||
.await
|
||||
.expect("could not find cake");
|
||||
let cake_model = cake.unwrap();
|
||||
assert_eq!(cake_model.name, "Extra chocolate mud cake");
|
||||
assert_eq!(cake_model.price, dec!(20.00));
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user