mirror of
https://github.com/launchbadge/sqlx.git
synced 2025-12-29 21:00:54 +00:00
* refactor: introduce `SqlSafeStr` API * rebase main * Add SqlStr + remove Statement lifetime * Update the definition of Executor and AnyConnectionBackend + update Postgres driver * Update MySql driver * Update Sqlite driver * remove debug clone count * Reduce the amount of SqlStr clones * improve QueryBuilder error message * cargo fmt * fix clippy warnings * fix doc test * Avoid panic in `QueryBuilder::reset` * Use `QueryBuilder` when removing all test db's * Add comment to `SqlStr` Co-authored-by: Austin Bonander <austin.bonander@gmail.com> * Update sqlx-core/src/query_builder.rs Co-authored-by: Austin Bonander <austin.bonander@gmail.com> * Add `Clone` as supertrait to `Statement` * Move `Connection`, `AnyConnectionBackend` and `TransactionManager` to `SqlStr` * Replace `sql_cloned` with `sql` in `Statement` * Update `Executor` trait * Update unit tests + QueryBuilder changes * Remove code in comments * Update comment in `QueryBuilder` * Fix clippy warnings * Update `Migrate` comment * Small changes * Move `Migration` to `SqlStr` --------- Co-authored-by: Austin Bonander <austin.bonander@gmail.com>
145 lines
3.3 KiB
Rust
145 lines
3.3 KiB
Rust
use sqlx::any::AnyRow;
|
|
use sqlx::{Any, Connection, Executor, Row};
|
|
use sqlx_core::sql_str::AssertSqlSafe;
|
|
use sqlx_test::new;
|
|
|
|
#[sqlx_macros::test]
|
|
async fn it_connects() -> anyhow::Result<()> {
|
|
sqlx::any::install_default_drivers();
|
|
|
|
let mut conn = new::<Any>().await?;
|
|
|
|
let value = sqlx::query("select 1 + 5")
|
|
.try_map(|row: AnyRow| row.try_get::<i32, _>(0))
|
|
.fetch_one(&mut conn)
|
|
.await?;
|
|
|
|
assert_eq!(6i32, value);
|
|
|
|
conn.close().await?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
#[sqlx_macros::test]
|
|
async fn it_pings() -> anyhow::Result<()> {
|
|
sqlx::any::install_default_drivers();
|
|
|
|
let mut conn = new::<Any>().await?;
|
|
|
|
conn.ping().await?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
#[sqlx_macros::test]
|
|
async fn it_executes_with_pool() -> anyhow::Result<()> {
|
|
sqlx::any::install_default_drivers();
|
|
|
|
let pool = sqlx_test::pool::<Any>().await?;
|
|
|
|
let rows = pool.fetch_all("SELECT 1; SElECT 2").await?;
|
|
|
|
assert_eq!(rows.len(), 2);
|
|
|
|
Ok(())
|
|
}
|
|
|
|
#[sqlx_macros::test]
|
|
async fn it_does_not_stop_stream_after_decoding_error() -> anyhow::Result<()> {
|
|
use futures_util::stream::StreamExt;
|
|
|
|
sqlx::any::install_default_drivers();
|
|
|
|
// see https://github.com/launchbadge/sqlx/issues/1884
|
|
let pool = sqlx_test::pool::<Any>().await?;
|
|
|
|
#[derive(Debug, PartialEq)]
|
|
struct MyType;
|
|
impl<'a> sqlx::FromRow<'a, AnyRow> for MyType {
|
|
fn from_row(row: &'a AnyRow) -> sqlx::Result<Self> {
|
|
let n = row.try_get::<i32, _>(0)?;
|
|
if n == 1 {
|
|
Err(sqlx::Error::RowNotFound)
|
|
} else {
|
|
Ok(MyType)
|
|
}
|
|
}
|
|
}
|
|
|
|
let rows = sqlx::query_as("SELECT 0 UNION ALL SELECT 1 UNION ALL SELECT 2")
|
|
.fetch(&pool)
|
|
.map(|r| r.ok())
|
|
.collect::<Vec<_>>()
|
|
.await;
|
|
|
|
assert_eq!(rows, vec![Some(MyType), None, Some(MyType)]);
|
|
Ok(())
|
|
}
|
|
|
|
#[sqlx_macros::test]
|
|
async fn it_gets_by_name() -> anyhow::Result<()> {
|
|
sqlx::any::install_default_drivers();
|
|
|
|
let mut conn = new::<Any>().await?;
|
|
|
|
let row = conn.fetch_one("SELECT 1 as _1").await?;
|
|
let val: i32 = row.get("_1");
|
|
|
|
assert_eq!(val, 1);
|
|
|
|
Ok(())
|
|
}
|
|
|
|
#[sqlx_macros::test]
|
|
async fn it_can_fail_and_recover() -> anyhow::Result<()> {
|
|
sqlx::any::install_default_drivers();
|
|
|
|
let mut conn = new::<Any>().await?;
|
|
|
|
for i in 0..10 {
|
|
// make a query that will fail
|
|
let res = conn
|
|
.execute("INSERT INTO not_found (column) VALUES (10)")
|
|
.await;
|
|
|
|
assert!(res.is_err());
|
|
|
|
// now try and use the connection
|
|
let val: i32 = conn
|
|
.fetch_one(AssertSqlSafe(format!("SELECT {i}")))
|
|
.await?
|
|
.get_unchecked(0);
|
|
|
|
assert_eq!(val, i);
|
|
}
|
|
|
|
Ok(())
|
|
}
|
|
|
|
#[sqlx_macros::test]
|
|
async fn it_can_fail_and_recover_with_pool() -> anyhow::Result<()> {
|
|
sqlx::any::install_default_drivers();
|
|
|
|
let pool = sqlx_test::pool::<Any>().await?;
|
|
|
|
for i in 0..10 {
|
|
// make a query that will fail
|
|
let res = pool
|
|
.execute("INSERT INTO not_found (column) VALUES (10)")
|
|
.await;
|
|
|
|
assert!(res.is_err());
|
|
|
|
// now try and use the connection
|
|
let val: i32 = pool
|
|
.fetch_one(AssertSqlSafe(format!("SELECT {i}")))
|
|
.await?
|
|
.get_unchecked(0);
|
|
|
|
assert_eq!(val, i);
|
|
}
|
|
|
|
Ok(())
|
|
}
|