2019-12-04 20:38:33 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe Gitlab::BackgroundMigration::FixPromotedEpicsDiscussionIds, schema: 20190715193142 do
|
2019-12-04 20:38:33 +05:30
|
|
|
let(:namespaces) { table(:namespaces) }
|
|
|
|
let(:users) { table(:users) }
|
|
|
|
let(:epics) { table(:epics) }
|
|
|
|
let(:notes) { table(:notes) }
|
|
|
|
|
|
|
|
let(:user) { users.create!(email: 'test@example.com', projects_limit: 100, username: 'test') }
|
|
|
|
let(:namespace) { namespaces.create!(name: 'gitlab', path: 'gitlab-org') }
|
|
|
|
let(:epic1) { epics.create!(id: 1, author_id: user.id, iid: 1, group_id: namespace.id, title: 'Epic with discussion', title_html: 'Epic with discussion') }
|
|
|
|
|
|
|
|
def create_note(discussion_id)
|
|
|
|
notes.create!(note: 'note comment',
|
|
|
|
noteable_id: epic1.id,
|
|
|
|
noteable_type: 'Epic',
|
|
|
|
discussion_id: discussion_id)
|
|
|
|
end
|
|
|
|
|
|
|
|
def expect_valid_discussion_id(id)
|
|
|
|
expect(id).to match(/\A\h{40}\z/)
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#perform with batch of discussion ids' do
|
|
|
|
it 'updates discussion ids' do
|
|
|
|
note1 = create_note('00000000')
|
|
|
|
note2 = create_note('00000000')
|
|
|
|
note3 = create_note('10000000')
|
|
|
|
|
|
|
|
subject.perform(%w(00000000 10000000))
|
|
|
|
|
|
|
|
expect_valid_discussion_id(note1.reload.discussion_id)
|
|
|
|
expect_valid_discussion_id(note2.reload.discussion_id)
|
|
|
|
expect_valid_discussion_id(note3.reload.discussion_id)
|
|
|
|
expect(note1.discussion_id).to eq(note2.discussion_id)
|
|
|
|
expect(note1.discussion_id).not_to eq(note3.discussion_id)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'skips notes with discussion id not in range' do
|
|
|
|
note4 = create_note('20000000')
|
|
|
|
|
|
|
|
subject.perform(%w(00000000 10000000))
|
|
|
|
|
|
|
|
expect(note4.reload.discussion_id).to eq('20000000')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|