Skip to content

Commit

Permalink
Setup pg_stat_statements
Browse files Browse the repository at this point in the history
  • Loading branch information
pawurb committed Jan 24, 2024
1 parent 954d6d8 commit 5e3738f
Showing 1 changed file with 18 additions and 3 deletions.
21 changes: 18 additions & 3 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -318,7 +318,7 @@ pub enum PgExtrasError {
#[error("Both $DATABASE_URL and $PG_EXTRAS_DATABASE_URL are not set")]
MissingConfigVars(),
#[error("Cannot connect to database")]
ConnectionError(),
DbConnectionError(),
#[error("Unknown pg-extras error")]
Unknown(String),
}
Expand All @@ -330,7 +330,7 @@ async fn get_rows<T: Tabular>(query: &str) -> Result<Vec<T>, PgExtrasError> {
.await
{
Ok(pool) => pool,
Err(_) => return Err(PgExtrasError::ConnectionError()),
Err(_) => return Err(PgExtrasError::DbConnectionError()),
};

Ok(match sqlx::query(query).fetch_all(&pool).await {
Expand All @@ -349,8 +349,23 @@ fn db_url() -> Result<String, PgExtrasError> {
mod tests {
use super::*;

async fn setup() -> Result<(), Box<dyn std::error::Error>> {
let pool = PgPoolOptions::new()
.max_connections(5)
.connect(db_url()?.as_str())
.await?;

sqlx::query("CREATE EXTENSION IF NOT EXISTS pg_stat_statements;")
.execute(&pool)
.await?;

Ok(())
}

#[tokio::test]
async fn it_works() -> Result<(), PgExtrasError> {
async fn it_works() -> Result<(), Box<dyn std::error::Error>> {
setup().await?;

render_table(cache_hit(None).await?);
render_table(bloat().await?);
render_table(blocking(None).await?);
Expand Down

0 comments on commit 5e3738f

Please sign in to comment.