mirror of https://github.com/pressly/goose.git
refactor: filter registered Go migrations by fs dirpath (#553)
parent
c9a67f620f
commit
928f577129
39
migrate.go
39
migrate.go
|
@ -255,18 +255,8 @@ func collectMigrationsFS(fsys fs.FS, dirpath string, current, target int64) (Mig
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Go migrations registered via goose.AddMigration().
|
|
||||||
for _, migration := range registeredGoMigrations {
|
|
||||||
v, err := NumericComponent(migration.Source)
|
|
||||||
if err != nil {
|
|
||||||
return nil, fmt.Errorf("could not parse go migration file %q: %w", migration.Source, err)
|
|
||||||
}
|
|
||||||
if versionFilter(v, current, target) {
|
|
||||||
migrations = append(migrations, migration)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Go migration files
|
// Go migration files
|
||||||
|
fsGoMigrations := map[int64]*Migration{}
|
||||||
goMigrationFiles, err := fs.Glob(fsys, path.Join(dirpath, "*.go"))
|
goMigrationFiles, err := fs.Glob(fsys, path.Join(dirpath, "*.go"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -281,17 +271,34 @@ func collectMigrationsFS(fsys fs.FS, dirpath string, current, target int64) (Mig
|
||||||
continue // Skip Go test files.
|
continue // Skip Go test files.
|
||||||
}
|
}
|
||||||
|
|
||||||
// Skip migrations already existing migrations registered via goose.AddMigration().
|
|
||||||
if _, ok := registeredGoMigrations[v]; ok {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
if versionFilter(v, current, target) {
|
if versionFilter(v, current, target) {
|
||||||
migration := &Migration{Version: v, Next: -1, Previous: -1, Source: file, Registered: false}
|
migration := &Migration{Version: v, Next: -1, Previous: -1, Source: file, Registered: false}
|
||||||
|
fsGoMigrations[v] = migration
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Go migrations registered via goose.AddMigration().
|
||||||
|
for _, migration := range registeredGoMigrations {
|
||||||
|
v, err := NumericComponent(migration.Source)
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("could not parse go migration file %q: %w", migration.Source, err)
|
||||||
|
}
|
||||||
|
if !versionFilter(v, current, target) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if _, ok := fsGoMigrations[v]; ok {
|
||||||
migrations = append(migrations, migration)
|
migrations = append(migrations, migration)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for _, fsMigration := range fsGoMigrations {
|
||||||
|
// Skip migrations already existing migrations registered via goose.AddMigration().
|
||||||
|
if _, ok := registeredGoMigrations[fsMigration.Version]; ok {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
migrations = append(migrations, fsMigration)
|
||||||
|
}
|
||||||
|
|
||||||
if len(migrations) == 0 {
|
if len(migrations) == 0 {
|
||||||
return nil, ErrNoMigrationFiles
|
return nil, ErrNoMigrationFiles
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue