debian-mirror-gitlab/spec/services/issuable/process_assignees_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

83 lines
3.8 KiB
Ruby
Raw Normal View History

2021-04-17 20:07:23 +05:30
# frozen_string_literal: true
require 'spec_helper'
2023-05-27 22:25:52 +05:30
RSpec.describe Issuable::ProcessAssignees, feature_category: :team_planning do
2021-04-17 20:07:23 +05:30
describe '#execute' do
2021-04-29 21:17:54 +05:30
it 'returns assignee_ids when add_assignee_ids and remove_assignee_ids are not specified' do
2021-04-17 20:07:23 +05:30
process = Issuable::ProcessAssignees.new(assignee_ids: %w(5 7 9),
2021-04-29 21:17:54 +05:30
add_assignee_ids: nil,
remove_assignee_ids: nil,
2021-04-17 20:07:23 +05:30
existing_assignee_ids: %w(1 3 9),
extra_assignee_ids: %w(2 5 12))
result = process.execute
2022-11-25 23:54:43 +05:30
expect(result).to contain_exactly(5, 7, 9)
2021-04-17 20:07:23 +05:30
end
2021-04-29 21:17:54 +05:30
it 'combines other ids when assignee_ids is nil' do
process = Issuable::ProcessAssignees.new(assignee_ids: nil,
add_assignee_ids: nil,
remove_assignee_ids: nil,
2021-04-17 20:07:23 +05:30
existing_assignee_ids: %w(1 3 11),
extra_assignee_ids: %w(2 5 12))
result = process.execute
2022-11-25 23:54:43 +05:30
expect(result).to contain_exactly(1, 2, 3, 5, 11, 12)
2021-04-17 20:07:23 +05:30
end
2021-04-29 21:17:54 +05:30
it 'combines other ids when both add_assignee_ids and remove_assignee_ids are not empty' do
process = Issuable::ProcessAssignees.new(assignee_ids: %w(5 7 9),
2021-04-17 20:07:23 +05:30
add_assignee_ids: %w(2 4 6),
remove_assignee_ids: %w(4 7 11),
existing_assignee_ids: %w(1 3 11),
extra_assignee_ids: %w(2 5 12))
result = process.execute
2022-11-25 23:54:43 +05:30
expect(result).to contain_exactly(1, 2, 3, 5, 6, 12)
2021-04-17 20:07:23 +05:30
end
2021-04-29 21:17:54 +05:30
it 'combines other ids when remove_assignee_ids is not empty' do
process = Issuable::ProcessAssignees.new(assignee_ids: %w(5 7 9),
2021-04-17 20:07:23 +05:30
add_assignee_ids: nil,
remove_assignee_ids: %w(4 7 11),
existing_assignee_ids: %w(1 3 11),
extra_assignee_ids: %w(2 5 12))
result = process.execute
2022-11-25 23:54:43 +05:30
expect(result).to contain_exactly(1, 2, 3, 5, 12)
2021-04-17 20:07:23 +05:30
end
2021-04-29 21:17:54 +05:30
it 'combines other ids when add_assignee_ids is not empty' do
process = Issuable::ProcessAssignees.new(assignee_ids: %w(5 7 9),
2021-04-17 20:07:23 +05:30
add_assignee_ids: %w(2 4 6),
remove_assignee_ids: nil,
existing_assignee_ids: %w(1 3 11),
extra_assignee_ids: %w(2 5 12))
result = process.execute
2022-11-25 23:54:43 +05:30
expect(result).to contain_exactly(1, 2, 4, 3, 5, 6, 11, 12)
2021-04-17 20:07:23 +05:30
end
2021-04-29 21:17:54 +05:30
it 'combines ids when existing_assignee_ids and extra_assignee_ids are omitted' do
process = Issuable::ProcessAssignees.new(assignee_ids: %w(5 7 9),
2021-04-17 20:07:23 +05:30
add_assignee_ids: %w(2 4 6),
remove_assignee_ids: %w(4 7 11))
result = process.execute
2022-11-25 23:54:43 +05:30
expect(result.sort).to eq([2, 6].sort)
end
it 'handles mixed string and integer arrays' do
process = Issuable::ProcessAssignees.new(assignee_ids: %w(5 7 9),
add_assignee_ids: [2, 4, 6],
remove_assignee_ids: %w(4 7 11),
existing_assignee_ids: [1, 3, 11],
extra_assignee_ids: %w(2 5 12))
result = process.execute
expect(result).to contain_exactly(1, 2, 3, 5, 6, 12)
2021-04-17 20:07:23 +05:30
end
end
end