summaryrefslogtreecommitdiff
path: root/lib/gitlab/database/schema_migrations/migrations.rb
diff options
context:
space:
mode:
Diffstat (limited to 'lib/gitlab/database/schema_migrations/migrations.rb')
-rw-r--r--lib/gitlab/database/schema_migrations/migrations.rb52
1 files changed, 52 insertions, 0 deletions
diff --git a/lib/gitlab/database/schema_migrations/migrations.rb b/lib/gitlab/database/schema_migrations/migrations.rb
new file mode 100644
index 00000000000..3b16b7f1b81
--- /dev/null
+++ b/lib/gitlab/database/schema_migrations/migrations.rb
@@ -0,0 +1,52 @@
+# frozen_string_literal: true
+
+module Gitlab
+ module Database
+ module SchemaMigrations
+ class Migrations
+ MIGRATION_VERSION_GLOB = '20[0-9][0-9]*'
+
+ def initialize(context)
+ @context = context
+ end
+
+ def touch_all
+ return unless @context.versions_to_create.any?
+
+ version_filepaths = version_filenames.map { |f| File.join(schema_directory, f) }
+ FileUtils.rm(version_filepaths)
+
+ @context.versions_to_create.each do |version|
+ version_filepath = File.join(schema_directory, version)
+
+ File.open(version_filepath, 'w') do |file|
+ file << Digest::SHA256.hexdigest(version)
+ end
+ end
+ end
+
+ def load_all
+ return if version_filenames.empty?
+
+ values = version_filenames.map { |vf| "('#{@context.connection.quote_string(vf)}')" }
+
+ @context.connection.execute(<<~SQL)
+ INSERT INTO schema_migrations (version)
+ VALUES #{values.join(',')}
+ ON CONFLICT DO NOTHING
+ SQL
+ end
+
+ private
+
+ def schema_directory
+ @context.schema_directory
+ end
+
+ def version_filenames
+ @version_filenames ||= Dir.glob(MIGRATION_VERSION_GLOB, base: schema_directory)
+ end
+ end
+ end
+ end
+end