#![allow(unused_imports, dead_code)]
pub mod common;
pub use common::{TestContext, features::*, setup::*};
use pretty_assertions::assert_eq;
use sea_orm::TryInsertResult;
use sea_orm::entity::prelude::*;
use sea_orm::{Set, sea_query::OnConflict};
#[sea_orm_macros::test]
fn main() -> Result<(), DbErr> {
let ctx = TestContext::new("upsert_tests");
create_insert_default_table(&ctx.db)?;
create_insert_default(&ctx.db)?;
ctx.delete();
Ok(())
}
pub fn create_insert_default(db: &DatabaseConnection) -> Result<(), DbErr> {
use insert_default::*;
let res = Entity::insert_many::<ActiveModel, _>([]).exec(db);
assert_eq!(res?.last_insert_id, None);
let res =
Entity::insert_many([ActiveModel { id: Set(1) }, ActiveModel { id: Set(2) }]).exec(db);
assert_eq!(res?.last_insert_id, Some(2));
let on_conflict = OnConflict::column(Column::Id)
.do_nothing_on([Column::Id])
.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);
assert_eq!(res?.last_insert_id, Some(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);
assert_eq!(res?.last_insert_id, Some(4));
let res =
Entity::insert_many([ActiveModel { id: Set(3) }, ActiveModel { id: Set(4) }]).exec(db);
assert!(matches!(res, Err(DbErr::Query(_) | DbErr::Exec(_))));
let res = Entity::insert_many([ActiveModel { id: Set(3) }, ActiveModel { id: Set(4) }])
.on_conflict(on_conflict.clone())
.exec(db);
assert!(matches!(res, Err(DbErr::RecordNotInserted)));
let res = Entity::insert_many([ActiveModel { id: Set(3) }, ActiveModel { id: Set(4) }])
.on_conflict_do_nothing_on([Column::Id])
.exec(db);
assert!(matches!(res, Ok(TryInsertResult::Conflicted)));
Ok(())
}