sea-orm-sync 2.0.0-rc.40

🐚 The sync version of SeaORM
Documentation
pub use super::*;
use sea_orm::error::*;
#[cfg(any(
    feature = "sqlx-mysql",
    feature = "sqlx-sqlite",
    feature = "sqlx-postgres"
))]
use sqlx::Error;
use uuid::Uuid;

pub fn test_cake_error_sqlx(db: &DbConn) {
    let mud_cake = cake::ActiveModel {
        name: Set("Moldy Cake".to_owned()),
        price: Set(rust_dec(10.25)),
        gluten_free: Set(false),
        serial: Set(Uuid::new_v4()),
        bakery_id: Set(None),
        ..Default::default()
    };

    let cake = mud_cake.save(db).expect("could not insert cake");

    #[allow(unused_variables)]
    let error: DbErr = cake
        .into_active_model()
        .insert(db)
        .expect_err("inserting should fail due to duplicate primary key");

    check_error(&error);
}

fn check_error(error: &DbErr) {
    #[cfg(any(feature = "sqlx-mysql", feature = "sqlx-sqlite"))]
    match error {
        DbErr::Exec(RuntimeErr::SqlxError(error)) => match std::ops::Deref::deref(error) {
            Error::Database(e) => {
                #[cfg(feature = "sqlx-mysql")]
                assert_eq!(e.code().unwrap(), "23000");
                #[cfg(feature = "rusqlite")]
                assert_eq!(e.code().unwrap(), "1555");
            }
            _ => panic!("Unexpected sqlx-error kind"),
        },
        #[cfg(all(feature = "sqlx-sqlite", feature = "sqlite-use-returning-for-3_35"))]
        DbErr::Query(RuntimeErr::SqlxError(error)) => match std::ops::Deref::deref(error) {
            Error::Database(e) => assert_eq!(e.code().unwrap(), "1555"),
            _ => panic!("Unexpected sqlx-error kind"),
        },
        _ => panic!("Unexpected Error kind"),
    }
    #[cfg(feature = "sqlx-postgres")]
    match error {
        DbErr::Query(RuntimeErr::SqlxError(error)) => match std::ops::Deref::deref(error) {
            Error::Database(e) => assert_eq!(e.code().unwrap(), "23505"),
            _ => panic!("Unexpected sqlx-error kind"),
        },
        _ => panic!("Unexpected Error kind"),
    }
}