|
| 1 | +# start-example |
| 2 | +from sqlspec.adapters.sqlite import SqliteConfig |
| 3 | + |
| 4 | +__all__ = ("test_sync_methods",) |
| 5 | + |
| 6 | + |
| 7 | +config = SqliteConfig( |
| 8 | + pool_config={"database": "myapp.db"}, migration_config={"enabled": True, "script_location": "migrations"} |
| 9 | +) |
| 10 | + |
| 11 | +# Apply migrations (no await needed) |
| 12 | +config.migrate_up("head") |
| 13 | +# Or use the alias |
| 14 | +config.upgrade("head") |
| 15 | + |
| 16 | +# Rollback one revision |
| 17 | +config.migrate_down("-1") |
| 18 | +# Or use the alias |
| 19 | +config.downgrade("-1") |
| 20 | + |
| 21 | +# Check current version |
| 22 | +current = config.get_current_migration(verbose=True) |
| 23 | +print(current) |
| 24 | + |
| 25 | +# Create new migration |
| 26 | +config.create_migration("add users table", file_type="sql") |
| 27 | + |
| 28 | +# Initialize migrations directory |
| 29 | +config.init_migrations() |
| 30 | + |
| 31 | +# Stamp database to specific revision |
| 32 | +config.stamp_migration("0003") |
| 33 | + |
| 34 | +# Convert timestamp to sequential migrations |
| 35 | +config.fix_migrations(dry_run=False, update_database=True, yes=True) |
| 36 | +# end-example |
| 37 | + |
| 38 | + |
| 39 | +def test_sync_methods() -> None: |
| 40 | + # Smoke tests for method presence, not actual DB calls |
| 41 | + assert hasattr(config, "migrate_up") |
| 42 | + assert hasattr(config, "upgrade") |
| 43 | + assert hasattr(config, "migrate_down") |
| 44 | + assert hasattr(config, "downgrade") |
| 45 | + assert hasattr(config, "get_current_migration") |
| 46 | + assert hasattr(config, "create_migration") |
| 47 | + assert hasattr(config, "init_migrations") |
| 48 | + assert hasattr(config, "stamp_migration") |
| 49 | + assert hasattr(config, "fix_migrations") |
0 commit comments