2019-04-11 12:17:24 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-06-11 20:45:16 +00:00
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-24 15:08:50 +00:00
|
|
|
RSpec.describe MergeRequests::DeleteNonLatestDiffsService, :clean_gitlab_redis_shared_state do
|
2018-06-11 20:45:16 +00:00
|
|
|
let(:merge_request) { create(:merge_request) }
|
|
|
|
|
|
|
|
let!(:subject) { described_class.new(merge_request) }
|
|
|
|
|
|
|
|
describe '#execute' do
|
|
|
|
before do
|
|
|
|
stub_const("#{described_class.name}::BATCH_SIZE", 2)
|
|
|
|
|
|
|
|
3.times { merge_request.create_merge_request_diff }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'schedules non-latest merge request diffs removal' do
|
|
|
|
diffs = merge_request.merge_request_diffs
|
|
|
|
|
|
|
|
expect(diffs.count).to eq(4)
|
|
|
|
|
2020-08-31 15:10:41 +00:00
|
|
|
freeze_time do
|
2018-06-11 20:45:16 +00:00
|
|
|
expect(DeleteDiffFilesWorker)
|
|
|
|
.to receive(:bulk_perform_in)
|
|
|
|
.with(5.minutes, [[diffs.first.id], [diffs.second.id]])
|
|
|
|
expect(DeleteDiffFilesWorker)
|
|
|
|
.to receive(:bulk_perform_in)
|
|
|
|
.with(10.minutes, [[diffs.third.id]])
|
|
|
|
|
|
|
|
subject.execute
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'schedules no removal if it is already cleaned' do
|
|
|
|
merge_request.merge_request_diffs.each(&:clean!)
|
|
|
|
|
|
|
|
expect(DeleteDiffFilesWorker).not_to receive(:bulk_perform_in)
|
|
|
|
|
|
|
|
subject.execute
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'schedules no removal if it is empty' do
|
|
|
|
merge_request.merge_request_diffs.each { |diff| diff.update!(state: :empty) }
|
|
|
|
|
|
|
|
expect(DeleteDiffFilesWorker).not_to receive(:bulk_perform_in)
|
|
|
|
|
|
|
|
subject.execute
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'schedules no removal if there is no non-latest diffs' do
|
2020-05-28 21:08:22 +00:00
|
|
|
# rubocop: disable Cop/DestroyAll
|
2018-06-11 20:45:16 +00:00
|
|
|
merge_request
|
|
|
|
.merge_request_diffs
|
|
|
|
.where.not(id: merge_request.latest_merge_request_diff_id)
|
|
|
|
.destroy_all
|
2020-05-28 21:08:22 +00:00
|
|
|
# rubocop: enable Cop/DestroyAll
|
2018-06-11 20:45:16 +00:00
|
|
|
|
|
|
|
expect(DeleteDiffFilesWorker).not_to receive(:bulk_perform_in)
|
|
|
|
|
|
|
|
subject.execute
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|