Commit 6d755dd7 authored by Kerri Miller's avatar Kerri Miller Committed by Robert Speicher

Update API responses to include "section" of ApprovalMergeRequestRule

parent 9b9570f7
...@@ -37,6 +37,10 @@ class ApprovalProjectRule < ApplicationRecord ...@@ -37,6 +37,10 @@ class ApprovalProjectRule < ApplicationRecord
nil nil
end end
def section
nil
end
def apply_report_approver_rules_to(merge_request) def apply_report_approver_rules_to(merge_request)
report_type = report_type_for(self) report_type = report_type_for(self)
rule = merge_request rule = merge_request
......
...@@ -11,7 +11,7 @@ class ApprovalWrappedRule ...@@ -11,7 +11,7 @@ class ApprovalWrappedRule
def_delegators(:@approval_rule, def_delegators(:@approval_rule,
:regular?, :any_approver?, :code_owner?, :report_approver?, :regular?, :any_approver?, :code_owner?, :report_approver?,
:overridden?, :id, :name, :users, :groups, :code_owner, :overridden?, :id, :name, :users, :groups, :code_owner,
:source_rule, :rule_type, :approvals_required) :source_rule, :rule_type, :approvals_required, :section)
def self.wrap(merge_request, rule) def self.wrap(merge_request, rule)
if rule.any_approver? if rule.any_approver?
......
...@@ -8,6 +8,7 @@ module EE ...@@ -8,6 +8,7 @@ module EE
expose :approvals_required expose :approvals_required
end end
expose :section
expose :source_rule, using: MergeRequestApprovalRule::SourceRule expose :source_rule, using: MergeRequestApprovalRule::SourceRule
expose :overridden?, as: :overridden expose :overridden?, as: :overridden
end end
......
...@@ -6,6 +6,7 @@ ...@@ -6,6 +6,7 @@
"approvals_required": { "type": "integer" }, "approvals_required": { "type": "integer" },
"contains_hidden_groups": { "type": "boolean" }, "contains_hidden_groups": { "type": "boolean" },
"rule_type": { "type": "string" }, "rule_type": { "type": "string" },
"section": { "type": ["null", "string"] },
"source_rule": { "source_rule": {
"type":["null", "object"], "type":["null", "object"],
"properties": {} "properties": {}
......
...@@ -98,6 +98,7 @@ describe API::MergeRequestApprovalRules do ...@@ -98,6 +98,7 @@ describe API::MergeRequestApprovalRules do
expect(rules.first['name']).to eq(mr_approval_rule.name) expect(rules.first['name']).to eq(mr_approval_rule.name)
expect(rules.first['approvals_required']).to eq(mr_approval_rule.approvals_required) expect(rules.first['approvals_required']).to eq(mr_approval_rule.approvals_required)
expect(rules.first['rule_type']).to eq(mr_approval_rule.rule_type) expect(rules.first['rule_type']).to eq(mr_approval_rule.rule_type)
expect(rules.first['section']).to be_nil
expect(rules.first['contains_hidden_groups']).to eq(false) expect(rules.first['contains_hidden_groups']).to eq(false)
expect(rules.first['source_rule']).to be_nil expect(rules.first['source_rule']).to be_nil
expect(rules.first['eligible_approvers']).to match([hash_including('id' => approver.id)]) expect(rules.first['eligible_approvers']).to match([hash_including('id' => approver.id)])
......
...@@ -174,7 +174,28 @@ describe API::MergeRequestApprovals do ...@@ -174,7 +174,28 @@ describe API::MergeRequestApprovals do
expect(rule_response['name']).to eq('foo') expect(rule_response['name']).to eq('foo')
expect(rule_response['approvers'][0]['username']).to eq(approver.username) expect(rule_response['approvers'][0]['username']).to eq(approver.username)
expect(rule_response['approved_by'][0]['username']).to eq(approver.username) expect(rule_response['approved_by'][0]['username']).to eq(approver.username)
expect(rule_response['source_rule']).to eq(nil) expect(rule_response['source_rule']).to be_nil
expect(rule_response['section']).to be_nil
end
context "when rule has a section" do
let(:rule) do
create(
:code_owner_rule,
merge_request: merge_request,
approvals_required: 2,
name: "foo",
section: "Example Section"
)
end
it "exposes the value of section when set" do
get api(url, user)
rule_response = json_response["rules"].first
expect(rule_response["section"]).to eq(rule.section)
end
end end
context 'when target_branch is specified' do context 'when target_branch is specified' do
......
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