bsql 0.17.0

Safe SQL for Rust — if it compiles, the SQL is correct
Documentation
//! Integration tests: read/write splitting.
//!
//! With bsql-driver, read/write splitting is not yet implemented at the driver
//! level. These tests verify that all queries work on a primary-only pool.
//!
//! Requires a running PostgreSQL with the test schema.
//! Set BSQL_DATABASE_URL=postgres://bsql:bsql@localhost/bsql_test

use bsql::Pool;

fn pool() -> Pool {
    Pool::connect("postgres://bsql:bsql@localhost/bsql_test")
        .expect("Failed to connect to test database. Is PostgreSQL running?")
}

/// SELECT queries work on a primary-only pool.
#[test]
fn select_works_without_replicas() {
    let pool = pool();

    let users = bsql::query!("SELECT id, login FROM users ORDER BY id")
        .fetch_all(&pool)
        .unwrap();
    assert!(users.len() >= 2);
}

/// INSERT works on a primary-only pool.
#[test]
fn insert_uses_primary() {
    let pool = pool();
    let title = "rw-split-test";
    let uid = 1i32;
    let ticket = bsql::query!(
        "INSERT INTO tickets (title, status, created_by_user_id)
         VALUES ($title: &str, 'new', $uid: i32)
         RETURNING id"
    )
    .fetch_one(&pool)
    .unwrap();
    assert!(ticket.id > 0);

    // Clean up
    let ticket_id = ticket.id;
    bsql::query!("DELETE FROM tickets WHERE id = $ticket_id: i32")
        .execute(&pool)
        .unwrap();
}

/// UPDATE works on primary.
#[test]
fn update_uses_primary() {
    let pool = pool();
    let desc = "rw-split-update";
    let id = 1i32;
    let affected = bsql::query!("UPDATE tickets SET description = $desc: &str WHERE id = $id: i32")
        .execute(&pool)
        .unwrap();
    assert_eq!(affected, 1);
}

/// DELETE works on primary.
#[test]
fn delete_uses_primary() {
    let pool = pool();
    let title = "rw-split-delete";
    let uid = 1i32;
    let ticket = bsql::query!(
        "INSERT INTO tickets (title, status, created_by_user_id)
         VALUES ($title: &str, 'new', $uid: i32)
         RETURNING id"
    )
    .fetch_one(&pool)
    .unwrap();

    let ticket_id = ticket.id;
    let affected = bsql::query!("DELETE FROM tickets WHERE id = $ticket_id: i32")
        .execute(&pool)
        .unwrap();
    assert_eq!(affected, 1);
}

/// Transaction queries work.
#[test]
fn transaction_uses_primary() {
    let pool = pool();

    let txn = pool.begin().unwrap();

    let users = bsql::query!("SELECT id, login FROM users ORDER BY id")
        .fetch_all(&txn)
        .unwrap();
    assert!(users.len() >= 2);

    txn.rollback().unwrap();
}

/// PoolConnection queries work.
#[test]
fn pool_connection_uses_primary() {
    let pool = pool();
    let conn = pool.acquire().unwrap();

    let users = bsql::query!("SELECT id, login FROM users ORDER BY id")
        .fetch_all(&conn)
        .unwrap();
    assert!(users.len() >= 2);
}

/// Pool status reflects connection counts.
#[test]
fn pool_status_reports_metrics() {
    let pool = pool();
    let status = pool.status();
    assert!(status.max_size > 0, "max_size should be positive");
}