Commit 3ffc71d5 authored by Sean McGivern's avatar Sean McGivern

Merge branch '11235-quick-actions-do-not-work-when-issues-are-opened-from-alerts' into 'master'

Resolve "Quick actions do not work when issues are opened from alerts"

Closes #11235

See merge request gitlab-org/gitlab-ee!12127
parents abfac0dd 03bdabb5
...@@ -44,7 +44,6 @@ class GlobalPolicy < BasePolicy ...@@ -44,7 +44,6 @@ class GlobalPolicy < BasePolicy
prevent :access_api prevent :access_api
prevent :access_git prevent :access_git
prevent :receive_notifications prevent :receive_notifications
prevent :use_quick_actions
end end
rule { required_terms_not_accepted }.policy do rule { required_terms_not_accepted }.policy do
......
...@@ -11,6 +11,9 @@ module EE ...@@ -11,6 +11,9 @@ module EE
with_scope :user with_scope :user
condition(:support_bot, score: 0) { @user&.support_bot? } condition(:support_bot, score: 0) { @user&.support_bot? }
with_scope :user
condition(:alert_bot, score: 0) { @user&.alert_bot? }
with_scope :global with_scope :global
condition(:license_block) { License.block_changes? } condition(:license_block) { License.block_changes? }
end end
......
...@@ -14,6 +14,8 @@ module EE ...@@ -14,6 +14,8 @@ module EE
enable :read_licenses enable :read_licenses
enable :destroy_licenses enable :destroy_licenses
end end
rule { support_bot }.prevent :use_quick_actions
end end
end end
end end
...@@ -9,5 +9,9 @@ module EE ...@@ -9,5 +9,9 @@ module EE
def support_bot? def support_bot?
false false
end end
def alert_bot?
false
end
end end
end end
...@@ -80,6 +80,8 @@ module EE ...@@ -80,6 +80,8 @@ module EE
prevent :read_project prevent :read_project
end end
rule { alert_bot }.enable :reporter_access
rule { license_block }.policy do rule { license_block }.policy do
prevent :create_issue prevent :create_issue
prevent :create_merge_request_in prevent :create_merge_request_in
......
---
title: Enable alert bot to use quick actions
merge_request: 12127
author:
type: fixed
...@@ -503,4 +503,10 @@ describe ProjectPolicy do ...@@ -503,4 +503,10 @@ describe ProjectPolicy do
projects: [clusterable]) projects: [clusterable])
end end
end end
context 'alert bot' do
let(:current_user) { User.alert_bot }
it { is_expected.to be_allowed(:reporter_access) }
end
end end
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
require 'spec_helper' require 'spec_helper'
describe IncidentManagement::CreateIssueService do describe IncidentManagement::CreateIssueService do
set(:project) { create(:project, :repository, create_templates: :issue) } let(:project) { create(:project, :repository) }
let(:service) { described_class.new(project, nil, alert_payload) } let(:service) { described_class.new(project, nil, alert_payload) }
let(:alert_title) { 'TITLE' } let(:alert_title) { 'TITLE' }
let(:alert_payload) do let(:alert_payload) do
...@@ -17,7 +17,8 @@ describe IncidentManagement::CreateIssueService do ...@@ -17,7 +17,8 @@ describe IncidentManagement::CreateIssueService do
subject { service.execute } subject { service.execute }
context 'when create_issue enabled' do context 'when create_issue enabled' do
let(:user) { create(:user) } let(:issue) { subject[:issue] }
let(:summary_separator) { "---\n\n" }
before do before do
setting.update!(create_issue: true) setting.update!(create_issue: true)
...@@ -27,26 +28,68 @@ describe IncidentManagement::CreateIssueService do ...@@ -27,26 +28,68 @@ describe IncidentManagement::CreateIssueService do
it 'creates an issue with alert summary only' do it 'creates an issue with alert summary only' do
expect(subject).to include(status: :success) expect(subject).to include(status: :success)
issue = subject[:issue]
expect(issue.author).to eq(User.alert_bot) expect(issue.author).to eq(User.alert_bot)
expect(issue.title).to eq(alert_title) expect(issue.title).to eq(alert_title)
expect(issue.description).to include('Summary') expect(issue.description).to include('Summary')
expect(issue.description).to include(alert_title) expect(issue.description).to include(alert_title)
expect(issue.description).not_to include("---\n\n") expect(issue.description).not_to include(summary_separator)
end end
end end
context 'with issue_template_content' do context 'with issue_template_content' do
before do before do
create_issue_template('bug', issue_template_content)
setting.update!(issue_template_key: 'bug') setting.update!(issue_template_key: 'bug')
end end
it 'creates an issue appending issue template' do context 'plain content' do
expect(subject).to include(status: :success) let(:issue_template_content) { 'some content' }
it 'creates an issue appending issue template' do
expect(subject).to include(status: :success)
expect(issue.description).to include('Summary')
expect(issue.description).to include(alert_title)
expect(issue.description).to include(summary_separator)
expect(issue.description).to include(issue_template_content)
end
end
context 'quick actions' do
let(:user) { create(:user) }
let(:plain_text) { 'some content' }
let(:issue_template_content) do
<<~CONTENT
#{plain_text}
/due tomorrow
/assign @#{user.username}
CONTENT
end
before do
project.add_maintainer(user)
end
it 'creates an issue interpreting quick actions' do
expect(subject).to include(status: :success)
expect(issue.description).to include(plain_text)
expect(issue.due_date).to be_present
expect(issue.assignees).to eq([user])
end
end
private
issue = subject[:issue] def create_issue_template(name, content)
expect(issue.description).to include("---\n\n") project.repository.create_file(
expect(issue.description).to include(setting.issue_template_content) project.creator,
".gitlab/issue_templates/#{name}.md",
content,
message: 'message',
branch_name: 'master'
)
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