#postgresql #sqlx #database #testing

sqlx_mock

A simple tool to test sqlx with postgres. It will automatically create a database and drop it after the test.

3 releases

0.1.2 Dec 12, 2022
0.1.1 Dec 9, 2022
0.1.0 Dec 8, 2022

#51 in #postgres

31 downloads per month

MIT license

17KB
108 lines

sqlx-mock

This a tool to test sqlx with postgres. It only supports tokio runtime at this moment.

How to use it

You should first create a TestPostgres data structure in your tests. It will automatically create a database and a connection pool for you. You could then get the connection string or connection pool from it to use in your own code. When TestPostgres gets dropped, it will automatically drop the database.

#[tokio::test]
fn some_awesom_test() {
    let tdb = TestPostgres::new("postgres://tosei:tosei@localhost:5432".into(), Path::new("./migrations"));
    let pool = tdb.get_pool().await;
    // do something with the pool

    // when tdb gets dropped, the database will be dropped
}

Have fun with this crate!

License

This project is distributed under the terms of MIT.

See LICENSE for details.

Copyright 2022 Xinyang Wang

Dependencies

~18–31MB
~559K SLoC