mirror of
				https://github.com/launchbadge/sqlx.git
				synced 2025-10-25 02:24:49 +00:00 
			
		
		
		
	 40aef6da2c
			
		
	
	
		40aef6da2c
		
			
		
	
	
	
	
		
			
			* test: add a failing test * feat: add no_tx to migration struct * feat: execute migration with no tx block * fix: expected string literal compilation error * test: update no tx to content comment * refactor: use the sql comment instead of file name semantics * docs: remove no_tx from file format comment * fix: remove filename matches * fix: messed up merge * refactor: dedupe migration * fix: move comment to where it makes sense * fix: linter error
		
			
				
	
	
		
			99 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
| use sqlx::migrate::Migrator;
 | |
| use sqlx::pool::PoolConnection;
 | |
| use sqlx::postgres::{PgConnection, Postgres};
 | |
| use sqlx::Executor;
 | |
| use sqlx::Row;
 | |
| use std::path::Path;
 | |
| 
 | |
| #[sqlx::test(migrations = false)]
 | |
| async fn simple(mut conn: PoolConnection<Postgres>) -> anyhow::Result<()> {
 | |
|     clean_up(&mut conn).await?;
 | |
| 
 | |
|     let migrator = Migrator::new(Path::new("tests/postgres/migrations_simple")).await?;
 | |
| 
 | |
|     // run migration
 | |
|     migrator.run(&mut conn).await?;
 | |
| 
 | |
|     // check outcome
 | |
|     let res: String = conn
 | |
|         .fetch_one("SELECT some_payload FROM migrations_simple_test")
 | |
|         .await?
 | |
|         .get(0);
 | |
|     assert_eq!(res, "110_suffix");
 | |
| 
 | |
|     // running it a 2nd time should still work
 | |
|     migrator.run(&mut conn).await?;
 | |
| 
 | |
|     Ok(())
 | |
| }
 | |
| 
 | |
| #[sqlx::test(migrations = false)]
 | |
| async fn reversible(mut conn: PoolConnection<Postgres>) -> anyhow::Result<()> {
 | |
|     clean_up(&mut conn).await?;
 | |
| 
 | |
|     let migrator = Migrator::new(Path::new("tests/postgres/migrations_reversible")).await?;
 | |
| 
 | |
|     // run migration
 | |
|     migrator.run(&mut conn).await?;
 | |
| 
 | |
|     // check outcome
 | |
|     let res: i64 = conn
 | |
|         .fetch_one("SELECT some_payload FROM migrations_reversible_test")
 | |
|         .await?
 | |
|         .get(0);
 | |
|     assert_eq!(res, 101);
 | |
| 
 | |
|     // roll back nothing (last version)
 | |
|     migrator.undo(&mut conn, 20220721125033).await?;
 | |
| 
 | |
|     // check outcome
 | |
|     let res: i64 = conn
 | |
|         .fetch_one("SELECT some_payload FROM migrations_reversible_test")
 | |
|         .await?
 | |
|         .get(0);
 | |
|     assert_eq!(res, 101);
 | |
| 
 | |
|     // roll back one version
 | |
|     migrator.undo(&mut conn, 20220721124650).await?;
 | |
| 
 | |
|     // check outcome
 | |
|     let res: i64 = conn
 | |
|         .fetch_one("SELECT some_payload FROM migrations_reversible_test")
 | |
|         .await?
 | |
|         .get(0);
 | |
|     assert_eq!(res, 100);
 | |
| 
 | |
|     Ok(())
 | |
| }
 | |
| 
 | |
| #[sqlx::test(migrations = false)]
 | |
| async fn no_tx(mut conn: PoolConnection<Postgres>) -> anyhow::Result<()> {
 | |
|     clean_up(&mut conn).await?;
 | |
|     let migrator = Migrator::new(Path::new("tests/postgres/migrations_no_tx")).await?;
 | |
| 
 | |
|     // run migration
 | |
|     migrator.run(&mut conn).await?;
 | |
| 
 | |
|     // check outcome
 | |
|     let res: String = conn
 | |
|         .fetch_one("SELECT datname FROM pg_database WHERE datname = 'test_db'")
 | |
|         .await?
 | |
|         .get(0);
 | |
| 
 | |
|     assert_eq!(res, "test_db");
 | |
| 
 | |
|     Ok(())
 | |
| }
 | |
| 
 | |
| /// Ensure that we have a clean initial state.
 | |
| async fn clean_up(conn: &mut PgConnection) -> anyhow::Result<()> {
 | |
|     conn.execute("DROP DATABASE IF EXISTS test_db").await.ok();
 | |
|     conn.execute("DROP TABLE migrations_simple_test").await.ok();
 | |
|     conn.execute("DROP TABLE migrations_reversible_test")
 | |
|         .await
 | |
|         .ok();
 | |
|     conn.execute("DROP TABLE _sqlx_migrations").await.ok();
 | |
| 
 | |
|     Ok(())
 | |
| }
 |