Commit 6abf99ae authored by Markus Koller's avatar Markus Koller

Merge branch 'delete-rescheduled-background-migrations' into 'master'

Add helper to delete queued background migrations when rescheduling

See merge request gitlab-org/gitlab!54341
parents 87ff1bdd 95051ada
...@@ -142,6 +142,14 @@ migration performing the scheduling. Otherwise the background migration would be ...@@ -142,6 +142,14 @@ migration performing the scheduling. Otherwise the background migration would be
scheduled multiple times on systems that are upgrading multiple patch releases at scheduled multiple times on systems that are upgrading multiple patch releases at
once. once.
When you start the second post-deployment migration, you should delete any
previously queued jobs from the initial migration with the provided
helper:
```ruby
delete_queued_jobs('BackgroundMigrationClassName')
```
## Cleaning Up ## Cleaning Up
NOTE: NOTE:
......
...@@ -236,6 +236,14 @@ module Gitlab ...@@ -236,6 +236,14 @@ module Gitlab
Gitlab::ApplicationContext.with_context(caller_id: self.class.to_s, &block) Gitlab::ApplicationContext.with_context(caller_id: self.class.to_s, &block)
end end
def delete_queued_jobs(class_name)
Gitlab::BackgroundMigration.steal(class_name) do |job|
job.delete
false
end
end
private private
def track_in_database(class_name, arguments) def track_in_database(class_name, arguments)
......
...@@ -431,4 +431,21 @@ RSpec.describe Gitlab::Database::Migrations::BackgroundMigrationHelpers do ...@@ -431,4 +431,21 @@ RSpec.describe Gitlab::Database::Migrations::BackgroundMigrationHelpers do
model.bulk_migrate_in(10.minutes, [%w(Class hello world)]) model.bulk_migrate_in(10.minutes, [%w(Class hello world)])
end end
end end
describe '#delete_queued_jobs' do
let(:job1) { double }
let(:job2) { double }
it 'deletes all queued jobs for the given background migration' do
expect(Gitlab::BackgroundMigration).to receive(:steal).with('BackgroundMigrationClassName') do |&block|
expect(block.call(job1)).to be(false)
expect(block.call(job2)).to be(false)
end
expect(job1).to receive(:delete)
expect(job2).to receive(:delete)
model.delete_queued_jobs('BackgroundMigrationClassName')
end
end
end end
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