sqlx/sqlx-cli/tests/migrate.rs
Ameer Ghani 84f21e99ef
cli: add --target-version CLI flags for migrate run/revert (#2538)
* cli: add --target-version CLI flags for migrate run/revert

* cli: fix broken test

* cli: test harness for `sqlx migrate` along with --target-version tests

* cli: Fail if version supplied to run/revert is too old/new

After some discussion with my coworkers, we thought about the behavior a bit more:

The behavior is now that for a run, if the provided version is too old, the CLI
will return with failure rather than being a no-op. This gives feedback to the
operator instead of being quiet.

It is still valid to up/downgrade to the latest version, this will still be a no-op
to allow for idempotency.
2023-07-31 12:49:53 -07:00

148 lines
4.9 KiB
Rust

mod common;
use common::TestDatabase;
#[tokio::test]
async fn run_reversible_migrations() {
let all_migrations: Vec<i64> = vec![
20230101000000,
20230201000000,
20230301000000,
20230401000000,
20230501000000,
];
// Without --target-version specified.k
{
let db = TestDatabase::new("migrate_run_reversible_latest", "migrations_reversible");
db.run_migration(false, None, false).success();
assert_eq!(db.applied_migrations().await, all_migrations);
}
// With --target-version specified.
{
let db = TestDatabase::new(
"migrate_run_reversible_latest_explicit",
"migrations_reversible",
);
// Move to latest, explicitly specified.
db.run_migration(false, Some(20230501000000), false)
.success();
assert_eq!(db.applied_migrations().await, all_migrations);
// Move to latest when we're already at the latest.
db.run_migration(false, Some(20230501000000), false)
.success();
assert_eq!(db.applied_migrations().await, all_migrations);
// Upgrade to an old version.
db.run_migration(false, Some(20230301000000), false)
.failure();
assert_eq!(db.applied_migrations().await, all_migrations);
}
// With --target-version, incrementally upgrade.
{
let db = TestDatabase::new(
"migrate_run_reversible_incremental",
"migrations_reversible",
);
// First version
db.run_migration(false, Some(20230101000000), false)
.success();
assert_eq!(db.applied_migrations().await, vec![20230101000000]);
// Dry run upgrade to latest.
db.run_migration(false, None, true).success();
assert_eq!(db.applied_migrations().await, vec![20230101000000]);
// Dry run upgrade + 2
db.run_migration(false, Some(20230301000000), true)
.success();
assert_eq!(db.applied_migrations().await, vec![20230101000000]);
// Upgrade to non-existent version.
db.run_migration(false, Some(20230901000000999), false)
.failure();
assert_eq!(db.applied_migrations().await, vec![20230101000000]);
// Upgrade + 1
db.run_migration(false, Some(20230201000000), false)
.success();
assert_eq!(
db.applied_migrations().await,
vec![20230101000000, 20230201000000]
);
// Upgrade + 2
db.run_migration(false, Some(20230401000000), false)
.success();
assert_eq!(db.applied_migrations().await, all_migrations[..4]);
}
}
#[tokio::test]
async fn revert_migrations() {
let all_migrations: Vec<i64> = vec![
20230101000000,
20230201000000,
20230301000000,
20230401000000,
20230501000000,
];
// Without --target-version
{
let db = TestDatabase::new("migrate_revert_incremental", "migrations_reversible");
db.run_migration(false, None, false).success();
// Dry-run
db.run_migration(true, None, true).success();
assert_eq!(db.applied_migrations().await, all_migrations);
// Downgrade one
db.run_migration(true, None, false).success();
assert_eq!(db.applied_migrations().await, all_migrations[..4]);
// Downgrade one
db.run_migration(true, None, false).success();
assert_eq!(db.applied_migrations().await, all_migrations[..3]);
}
// With --target-version
{
let db = TestDatabase::new("migrate_revert_incremental", "migrations_reversible");
db.run_migration(false, None, false).success();
// Dry-run downgrade to version 3.
db.run_migration(true, Some(20230301000000), true).success();
assert_eq!(db.applied_migrations().await, all_migrations);
// Downgrade to version 3.
db.run_migration(true, Some(20230301000000), false)
.success();
assert_eq!(db.applied_migrations().await, all_migrations[..3]);
// Try downgrading to the same version.
db.run_migration(true, Some(20230301000000), false)
.success();
assert_eq!(db.applied_migrations().await, all_migrations[..3]);
// Try downgrading to a newer version.
db.run_migration(true, Some(20230401000000), false)
.failure();
assert_eq!(db.applied_migrations().await, all_migrations[..3]);
// Try downgrading to a non-existent version.
db.run_migration(true, Some(9999), false).failure();
assert_eq!(db.applied_migrations().await, all_migrations[..3]);
// Ensure we can still upgrade
db.run_migration(false, Some(20230401000000), false)
.success();
assert_eq!(db.applied_migrations().await, all_migrations[..4]);
// Downgrade to zero.
db.run_migration(true, Some(0), false).success();
assert_eq!(db.applied_migrations().await, vec![] as Vec<i64>);
}
}