Commit d27e1b5e authored by Felipe Artur's avatar Felipe Artur

Block assign quick action for test cases

Prevent assign quick action
for issues with test case type
parent f006fea3
...@@ -196,6 +196,10 @@ module Issuable ...@@ -196,6 +196,10 @@ module Issuable
is_a?(Issue) is_a?(Issue)
end end
def supports_assignee?
false
end
def severity def severity
return IssuableSeverity::DEFAULT unless supports_severity? return IssuableSeverity::DEFAULT unless supports_severity?
......
...@@ -9,7 +9,9 @@ module IssueAvailableFeatures ...@@ -9,7 +9,9 @@ module IssueAvailableFeatures
class_methods do class_methods do
# EE only features are listed on EE::IssueAvailableFeatures # EE only features are listed on EE::IssueAvailableFeatures
def available_features_for_issue_types def available_features_for_issue_types
{}.with_indifferent_access {
assignee: %w(issue incident)
}.with_indifferent_access
end end
end end
......
...@@ -434,6 +434,10 @@ class Issue < ApplicationRecord ...@@ -434,6 +434,10 @@ class Issue < ApplicationRecord
moved_to || duplicated_to moved_to || duplicated_to
end end
def supports_assignee?
issue_type_supports?(:assignee)
end
private private
def ensure_metrics def ensure_metrics
......
...@@ -1774,6 +1774,10 @@ class MergeRequest < ApplicationRecord ...@@ -1774,6 +1774,10 @@ class MergeRequest < ApplicationRecord
false false
end end
def supports_assignee?
true
end
private private
def with_rebase_lock def with_rebase_lock
......
...@@ -6,7 +6,7 @@ module EE ...@@ -6,7 +6,7 @@ module EE
extend ::Gitlab::Utils::Override extend ::Gitlab::Utils::Override
def supports_epic? def supports_epic?
is_a?(Issue) && issue_type_supports?(:epics) && project.group.present? false
end end
def supports_health_status? def supports_health_status?
......
...@@ -251,6 +251,11 @@ module EE ...@@ -251,6 +251,11 @@ module EE
super || promoted_to_epic super || promoted_to_epic
end end
override :supports_epic?
def supports_epic?
issue_type_supports?(:epics) && project.group.present?
end
private private
def blocking_issues_ids def blocking_issues_ids
......
---
title: Block /assign quick action for test cases
merge_request: 50396
author:
type: other
...@@ -14,7 +14,8 @@ module EE ...@@ -14,7 +14,8 @@ module EE
params '@user1 @user2' params '@user1 @user2'
types Issue, MergeRequest types Issue, MergeRequest
condition do condition do
quick_action_target.allows_multiple_assignees? && quick_action_target.supports_assignee? &&
quick_action_target.allows_multiple_assignees? &&
quick_action_target.persisted? && quick_action_target.persisted? &&
current_user.can?(:"admin_#{quick_action_target.to_ability_name}", project) current_user.can?(:"admin_#{quick_action_target.to_ability_name}", project)
end end
......
...@@ -44,6 +44,16 @@ RSpec.describe QuickActions::InterpretService do ...@@ -44,6 +44,16 @@ RSpec.describe QuickActions::InterpretService do
expect(updates[:assignee_ids]).to match_array([user.id, user3.id]) expect(updates[:assignee_ids]).to match_array([user.id, user3.id])
end end
context 'with test_case issue type' do
it 'does not mark to update assignee' do
test_case = create(:quality_test_case, project: project)
_, updates = service.execute("/assign @#{user3.username}", test_case)
expect(updates[:assignee_ids]).to eq(nil)
end
end
context 'assign command with multiple assignees' do context 'assign command with multiple assignees' do
it 'fetches assignee and populates assignee_ids if content contains /assign' do it 'fetches assignee and populates assignee_ids if content contains /assign' do
issue.update!(assignee_ids: [user.id]) issue.update!(assignee_ids: [user.id])
...@@ -207,6 +217,16 @@ RSpec.describe QuickActions::InterpretService do ...@@ -207,6 +217,16 @@ RSpec.describe QuickActions::InterpretService do
expect(updates[:assignee_ids]).to match_array([current_user.id]) expect(updates[:assignee_ids]).to match_array([current_user.id])
end end
context 'with test_case issue type' do
it 'does not mark to update assignee' do
test_case = create(:quality_test_case, project: project)
_, updates = service.execute("/reassign @#{current_user.username}", test_case)
expect(updates[:assignee_ids]).to eq(nil)
end
end
end end
end end
......
...@@ -26,7 +26,7 @@ module Gitlab ...@@ -26,7 +26,7 @@ module Gitlab
end end
types Issue, MergeRequest types Issue, MergeRequest
condition do condition do
current_user.can?(:"admin_#{quick_action_target.to_ability_name}", project) quick_action_target.supports_assignee? && current_user.can?(:"admin_#{quick_action_target.to_ability_name}", project)
end end
parse_params do |assignee_param| parse_params do |assignee_param|
extract_users(assignee_param) extract_users(assignee_param)
......
...@@ -777,6 +777,11 @@ RSpec.describe QuickActions::InterpretService do ...@@ -777,6 +777,11 @@ RSpec.describe QuickActions::InterpretService do
let(:issuable) { issue } let(:issuable) { issue }
end end
it_behaves_like 'assign command' do
let(:content) { "/assign @#{developer.username}" }
let(:issuable) { create(:incident, project: project) }
end
it_behaves_like 'assign command' do it_behaves_like 'assign command' do
let(:content) { "/assign @#{developer.username}" } let(:content) { "/assign @#{developer.username}" }
let(:issuable) { merge_request } let(:issuable) { merge_request }
......
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