Commit d492a8ad authored by Alex Ives's avatar Alex Ives

Fix regenerate-schema to work with schema_migrations

Add a method to the script so that it removes added files from
db/schema_migrations when regenerating the schema.

Relates to https://gitlab.com/gitlab-org/gitlab/issues/233778
parent 422fa39a
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
# frozen_string_literal: true # frozen_string_literal: true
require 'open3' require 'open3'
require 'fileutils'
require 'uri' require 'uri'
class SchemaRegenerator class SchemaRegenerator
...@@ -19,11 +20,19 @@ class SchemaRegenerator ...@@ -19,11 +20,19 @@ class SchemaRegenerator
# these to disable/enable migrations. # these to disable/enable migrations.
MIGRATION_DIRS = %w[db/migrate db/post_migrate].freeze MIGRATION_DIRS = %w[db/migrate db/post_migrate].freeze
##
# Directory where we store schema versions
#
# The remove_schema_migration_files removes files added in this
# directory when it runs.
SCHEMA_MIGRATIONS_DIR = 'db/schema_migrations/'
def execute def execute
Dir.chdir(File.expand_path('..', __dir__)) do Dir.chdir(File.expand_path('..', __dir__)) do
checkout_ref checkout_ref
checkout_clean_schema checkout_clean_schema
hide_migrations hide_migrations
remove_schema_migration_files
reset_db reset_db
unhide_migrations unhide_migrations
migrate migrate
...@@ -110,6 +119,18 @@ class SchemaRegenerator ...@@ -110,6 +119,18 @@ class SchemaRegenerator
raise error if error raise error if error
end end
##
# Remove files added to db/schema_migrations
#
# In order to properly reset the database and re-run migrations
# the schema migrations for new migrations must be removed.
def remove_schema_migration_files
git_command = "git diff --name-only --diff-filter=A #{source_ref} -- #{SCHEMA_MIGRATIONS_DIR}"
run(git_command).chomp.split("\n").each do |schema_migration|
FileUtils.rm(schema_migration)
end
end
## ##
# Run rake task to reset the database. # Run rake task to reset the database.
def reset_db def reset_db
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment