(t *testing.T)
| 270 | } |
| 271 | |
| 272 | func TestMigratorValidateStatement(t *testing.T) { |
| 273 | t.Run("add-column", func(t *testing.T) { |
| 274 | migrationContext := base.NewMigrationContext() |
| 275 | migrator := NewMigrator(migrationContext, "1.2.3") |
| 276 | require.Nil(t, migrator.parser.ParseAlterStatement(`ALTER TABLE test ADD test_new VARCHAR(64) NOT NULL`)) |
| 277 | |
| 278 | require.Nil(t, migrator.validateAlterStatement()) |
| 279 | require.Len(t, migrator.migrationContext.DroppedColumnsMap, 0) |
| 280 | }) |
| 281 | |
| 282 | t.Run("drop-column", func(t *testing.T) { |
| 283 | migrationContext := base.NewMigrationContext() |
| 284 | migrator := NewMigrator(migrationContext, "1.2.3") |
| 285 | require.Nil(t, migrator.parser.ParseAlterStatement(`ALTER TABLE test DROP abc`)) |
| 286 | |
| 287 | require.Nil(t, migrator.validateAlterStatement()) |
| 288 | require.Len(t, migrator.migrationContext.DroppedColumnsMap, 1) |
| 289 | _, exists := migrator.migrationContext.DroppedColumnsMap["abc"] |
| 290 | require.True(t, exists) |
| 291 | }) |
| 292 | |
| 293 | t.Run("rename-column", func(t *testing.T) { |
| 294 | migrationContext := base.NewMigrationContext() |
| 295 | migrator := NewMigrator(migrationContext, "1.2.3") |
| 296 | require.Nil(t, migrator.parser.ParseAlterStatement(`ALTER TABLE test CHANGE test123 test1234 bigint unsigned`)) |
| 297 | |
| 298 | err := migrator.validateAlterStatement() |
| 299 | require.Error(t, err) |
| 300 | require.True(t, strings.HasPrefix(err.Error(), "gh-ost believes the ALTER statement renames columns")) |
| 301 | require.Len(t, migrator.migrationContext.DroppedColumnsMap, 0) |
| 302 | }) |
| 303 | |
| 304 | t.Run("rename-column-approved", func(t *testing.T) { |
| 305 | migrationContext := base.NewMigrationContext() |
| 306 | migrator := NewMigrator(migrationContext, "1.2.3") |
| 307 | migrator.migrationContext.ApproveRenamedColumns = true |
| 308 | require.Nil(t, migrator.parser.ParseAlterStatement(`ALTER TABLE test CHANGE test123 test1234 bigint unsigned`)) |
| 309 | |
| 310 | require.Nil(t, migrator.validateAlterStatement()) |
| 311 | require.Len(t, migrator.migrationContext.DroppedColumnsMap, 0) |
| 312 | }) |
| 313 | |
| 314 | t.Run("rename-table", func(t *testing.T) { |
| 315 | migrationContext := base.NewMigrationContext() |
| 316 | migrator := NewMigrator(migrationContext, "1.2.3") |
| 317 | require.Nil(t, migrator.parser.ParseAlterStatement(`ALTER TABLE test RENAME TO test_new`)) |
| 318 | |
| 319 | err := migrator.validateAlterStatement() |
| 320 | require.Error(t, err) |
| 321 | require.True(t, errors.Is(err, ErrMigratorUnsupportedRenameAlter)) |
| 322 | require.Len(t, migrator.migrationContext.DroppedColumnsMap, 0) |
| 323 | }) |
| 324 | } |
| 325 | |
| 326 | func TestMigratorCreateFlagFiles(t *testing.T) { |
| 327 | tmpdir, err := os.MkdirTemp("", t.Name()) |
nothing calls this directly
no test coverage detected
searching dependent graphs…