61 lines
1.5 KiB
Rust
61 lines
1.5 KiB
Rust
pub mod common;
|
|
|
|
pub use common::{features::*, setup::*, TestContext};
|
|
use pretty_assertions::assert_eq;
|
|
use sea_orm::entity::prelude::*;
|
|
use sea_orm::{sea_query::OnConflict, Set};
|
|
|
|
#[sea_orm_macros::test]
|
|
#[cfg(feature = "sqlx-postgres")]
|
|
async fn main() -> Result<(), DbErr> {
|
|
let ctx = TestContext::new("upsert_tests").await;
|
|
create_tables(&ctx.db).await?;
|
|
create_insert_default(&ctx.db).await?;
|
|
ctx.delete().await;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
pub async fn create_insert_default(db: &DatabaseConnection) -> Result<(), DbErr> {
|
|
use insert_default::*;
|
|
|
|
let on_conflict = OnConflict::column(Column::Id).do_nothing().to_owned();
|
|
|
|
let res = Entity::insert_many([
|
|
ActiveModel { id: Set(1) },
|
|
ActiveModel { id: Set(2) },
|
|
ActiveModel { id: Set(3) },
|
|
])
|
|
.on_conflict(on_conflict.clone())
|
|
.exec(db)
|
|
.await;
|
|
|
|
assert_eq!(res?.last_insert_id, 3);
|
|
|
|
let res = Entity::insert_many([
|
|
ActiveModel { id: Set(1) },
|
|
ActiveModel { id: Set(2) },
|
|
ActiveModel { id: Set(3) },
|
|
ActiveModel { id: Set(4) },
|
|
])
|
|
.on_conflict(on_conflict.clone())
|
|
.exec(db)
|
|
.await;
|
|
|
|
assert_eq!(res?.last_insert_id, 4);
|
|
|
|
let res = Entity::insert_many([
|
|
ActiveModel { id: Set(1) },
|
|
ActiveModel { id: Set(2) },
|
|
ActiveModel { id: Set(3) },
|
|
ActiveModel { id: Set(4) },
|
|
])
|
|
.on_conflict(on_conflict)
|
|
.exec(db)
|
|
.await;
|
|
|
|
assert_eq!(res.err(), Some(DbErr::RecordNotInserted));
|
|
|
|
Ok(())
|
|
}
|