Commit 7dc7bfa9 authored by Mark Chao's avatar Mark Chao

Remove approval_rules feature flag

Remove spec for haml rendering which are moved to vue

Remove unused overall_approer_groups
parent 09b63a22
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
> Introduced in [GitLab Enterprise Edition 7.12](https://about.gitlab.com/2015/06/22/gitlab-7-12-released/#merge-request-approvers-ee-only). > Introduced in [GitLab Enterprise Edition 7.12](https://about.gitlab.com/2015/06/22/gitlab-7-12-released/#merge-request-approvers-ee-only).
NOTE: **Note:** NOTE: **Note:**
If you are running a self-managed instance, the new interface shown on Prior to 12.0, if you are running a self-managed instance, the new interface shown on
this page will not be available unless the feature flag this page will not be available unless the feature flag
`approval_rules` is enabled, which can be done from the Rails console by `approval_rules` is enabled, which can be done from the Rails console by
instance administrators. instance administrators.
......
...@@ -9,7 +9,6 @@ module EE ...@@ -9,7 +9,6 @@ module EE
prepended do prepended do
before_action only: [:show] do before_action only: [:show] do
push_frontend_feature_flag(:approval_rules, merge_request.project, default_enabled: true)
push_frontend_feature_flag(:visual_review_app, merge_request.project, default_enabled: false) push_frontend_feature_flag(:visual_review_app, merge_request.project, default_enabled: false)
end end
...@@ -70,13 +69,10 @@ module EE ...@@ -70,13 +69,10 @@ module EE
def render_approvals_json def render_approvals_json
respond_to do |format| respond_to do |format|
format.json do format.json do
entity = if ::Feature.enabled?(:approval_rules, merge_request.project, default_enabled: true) render json: EE::API::Entities::ApprovalState.new(
EE::API::Entities::ApprovalState.new(merge_request.approval_state, current_user: current_user) merge_request.approval_state,
else current_user: current_user
EE::API::Entities::MergeRequestApprovals.new(merge_request, current_user: current_user) )
end
render json: entity
end end
end end
end end
......
...@@ -107,7 +107,6 @@ module EE ...@@ -107,7 +107,6 @@ module EE
end end
def validate_approval_rule_source def validate_approval_rule_source
return if ::Feature.disabled?(:approval_rules, project, default_enabled: true)
return unless approval_rules.any? return unless approval_rules.any?
local_project_rule_ids = approval_rules.map { |rule| rule.approval_merge_request_rule_source&.approval_project_rule_id } local_project_rule_ids = approval_rules.map { |rule| rule.approval_merge_request_rule_source&.approval_project_rule_id }
...@@ -126,16 +125,7 @@ module EE ...@@ -126,16 +125,7 @@ module EE
strong_memoize(:participant_approvers) do strong_memoize(:participant_approvers) do
next [] unless approval_needed? next [] unless approval_needed?
if ::Feature.enabled?(:approval_rules, project, default_enabled: true)
approval_state.filtered_approvers(code_owner: false, unactioned: true) approval_state.filtered_approvers(code_owner: false, unactioned: true)
else
approvers = [
*overall_approvers(exclude_code_owners: true),
*approvers_from_groups
]
::User.where(id: approvers.map(&:id)).where.not(id: approved_by_users.select(:id))
end
end end
end end
......
...@@ -324,8 +324,6 @@ module EE ...@@ -324,8 +324,6 @@ module EE
end end
def visible_regular_approval_rules def visible_regular_approval_rules
return approval_rules.none unless ::Feature.enabled?(:approval_rules, self, default_enabled: true)
strong_memoize(:visible_regular_approval_rules) do strong_memoize(:visible_regular_approval_rules) do
regular_rules = approval_rules.regular.order(:id) regular_rules = approval_rules.regular.order(:id)
......
...@@ -40,30 +40,11 @@ module EE ...@@ -40,30 +40,11 @@ module EE
def update_approvers def update_approvers
return yield unless project.feature_available?(:code_owners) return yield unless project.feature_available?(:code_owners)
if ::Feature.enabled?(:approval_rules, project, default_enabled: true)
results = yield results = yield
merge_requests_for_source_branch.each do |merge_request| merge_requests_for_source_branch.each do |merge_request|
::MergeRequests::SyncCodeOwnerApprovalRules.new(merge_request).execute ::MergeRequests::SyncCodeOwnerApprovalRules.new(merge_request).execute
end end
else
previous_diffs = fetch_latest_merge_request_diffs
results = yield
merge_requests = merge_requests_for_source_branch
ActiveRecord::Associations::Preloader.new.preload(merge_requests, :latest_merge_request_diff) # rubocop: disable CodeReuse/ActiveRecord)
merge_requests.each do |merge_request|
previous_diff = previous_diffs.find { |diff| diff.merge_request == merge_request }
previous_code_owners = ::Gitlab::CodeOwners.for_merge_request(merge_request, merge_request_diff: previous_diff)
new_code_owners = merge_request.code_owners - previous_code_owners
create_approvers(merge_request, new_code_owners)
merge_request.sync_code_owners_with_approvers
end
end
results results
end end
......
...@@ -15,7 +15,6 @@ module EE ...@@ -15,7 +15,6 @@ module EE
end end
merge_request = super(merge_request) merge_request = super(merge_request)
sync_approval_rules(merge_request)
if should_remove_old_approvers && merge_request.valid? if should_remove_old_approvers && merge_request.valid?
cleanup_approvers(merge_request, reload: true) cleanup_approvers(merge_request, reload: true)
...@@ -49,16 +48,6 @@ module EE ...@@ -49,16 +48,6 @@ module EE
merge_request.approvals.delete_all if target_project.reset_approvals_on_push merge_request.approvals.delete_all if target_project.reset_approvals_on_push
end end
# TODO remove after #1979 is closed
def sync_approval_rules(merge_request)
return if ::Feature.enabled?(:approval_rules, merge_request.target_project, default_enabled: true)
return if merge_request.merged?
return unless merge_request.previous_changes.include?(:approvals_before_merge)
approvals_required = merge_request.approvals_before_merge || merge_request.target_project.approvals_before_merge
merge_request.approval_rules.regular.update_all(approvals_required: approvals_required)
end
end end
end end
end end
...@@ -35,8 +35,6 @@ module EE ...@@ -35,8 +35,6 @@ module EE
sync_wiki_on_enable if !wiki_was_enabled && project.wiki_enabled? sync_wiki_on_enable if !wiki_was_enabled && project.wiki_enabled?
project.import_state.force_import_job! if params[:mirror].present? && project.mirror? project.import_state.force_import_job! if params[:mirror].present? && project.mirror?
project.remove_import_data if project.previous_changes.include?('mirror') && !project.mirror? project.remove_import_data if project.previous_changes.include?('mirror') && !project.mirror?
sync_approval_rules
end end
result result
...@@ -67,14 +65,6 @@ module EE ...@@ -67,14 +65,6 @@ module EE
def sync_wiki_on_enable def sync_wiki_on_enable
::Geo::RepositoryUpdatedService.new(project.wiki.repository).execute ::Geo::RepositoryUpdatedService.new(project.wiki.repository).execute
end end
# TODO remove after #1979 is closed
def sync_approval_rules
return if ::Feature.enabled?(:approval_rules, project, default_enabled: true)
return unless project.previous_changes.include?(:approvals_before_merge)
project.approval_rules.update_all(approvals_required: project.approvals_before_merge)
end
end end
end end
end end
- can_override_approvers = project.can_override_approvers? - can_override_approvers = project.can_override_approvers?
- if Feature.enabled?(:approval_rules, project, default_enabled: true) = render 'shared/merge_request_approvals_settings/multiple_rules_form', form: form, project: project
= render 'shared/merge_request_approvals_settings/multiple_rules_form', form: form, project: project
- else
= render 'shared/merge_request_approvals_settings/single_rule_form', form: form, project: project
- if project.code_owner_approval_required_available? - if project.code_owner_approval_required_available?
.form-group.require-code-owner-approval .form-group.require-code-owner-approval
......
...@@ -11,10 +11,7 @@ ...@@ -11,10 +11,7 @@
= form.label :approver_ids, class: 'col-form-label col-sm-2' do = form.label :approver_ids, class: 'col-form-label col-sm-2' do
Approvers Approvers
.col-sm-10 .col-sm-10
- if Feature.enabled?(:approval_rules, @target_project, default_enabled: true)
= render 'shared/issuable/approvals_multiple_rule', issuable: issuable, presenter: presenter = render 'shared/issuable/approvals_multiple_rule', issuable: issuable, presenter: presenter
- else
= render 'shared/issuable/approvals_single_rule', issuable: issuable, presenter: presenter, form: form
- if can_update_approvers - if can_update_approvers
- approver_presenter = MergeRequestApproverPresenter.new(issuable, skip_user: current_user) - approver_presenter = MergeRequestApproverPresenter.new(issuable, skip_user: current_user)
.form-text.text-muted.suggested-approvers .form-text.text-muted.suggested-approvers
......
- issuable = local_assigns.fetch(:issuable)
- presenter = local_assigns.fetch(:presenter)
- form = local_assigns.fetch(:form)
- can_update_approvers = can?(current_user, :update_approvers, issuable)
- if can_update_approvers
- skip_users = [*presenter.all_approvers_including_groups, (issuable.author unless presenter.authors_can_approve?), *(issuable.committers unless presenter.committers_can_approve?)].compact
= users_select_tag("merge_request[approver_ids]",
multiple: true,
class: 'input-large',
email_user: true,
skip_users: skip_users,
project: issuable.target_project)
.form-text.text-muted
= _('This merge request must be approved by these users. You can override the project settings by setting your own list of approvers.')
- skip_groups = presenter.overall_approver_groups.pluck(:group_id) # rubocop: disable CodeReuse/ActiveRecord
= groups_select_tag('merge_request[approver_group_ids]', multiple: true, data: { skip_groups: skip_groups, all_available: true, project: issuable.target_project }, class: 'input-large')
.form-text.text-muted
= _('This merge request must be approved by members of these groups. You can override the project settings by setting your own list of approvers.')
.card.prepend-top-10
.card-header
= _('Approvers')
%ul.content-list.approver-list.qa-approver-list
- if presenter.all_approvers_including_groups.empty?
%li.no-approvers= _('There are no approvers')
- else
- unsaved_approvers = !presenter.approvers_overwritten?
- item_classes = unsaved_approvers ? ['unsaved-approvers'] : []
- presenter.overall_approvers.each do |approver|
%li{ id: dom_id(approver), class: item_classes + ['approver'] }
= link_to approver.name, approver, class: 'qa-approver'
- if can_update_approvers
.float-right
- if unsaved_approvers
%button{ class: 'btn-sm btn btn-remove', title: _('Remove approver'), data: { confirm: _("Are you sure you want to remove approver %{name}") % { name: approver.name } } }
= icon("sign-out")
= _('Remove')
- else
= link_to project_merge_request_approver_via_user_id_path(@project, issuable, user_id: approver.id), data: { confirm: _("Are you sure you want to remove approver %{name}") % { name: approver.name } }, method: :delete, class: "btn-sm btn btn-remove", title: _('Remove approver') do
= icon("sign-out")
= _('Remove')
- presenter.overall_approver_groups.each do |approver_group|
%li{ id: dom_id(approver_group.group), class: item_classes + ['approver-group'] }
= _('Group:')
= link_to approver_group.group.name, approver_group.group
- if can_update_approvers
.float-right
- if unsaved_approvers
%button{ class: "btn-sm btn btn-remove", title: _('Remove group'), data: { confirm: _("Are you sure you want to remove group %{name}") % { name: approver_group.group.name } } }
= icon("sign-out")
= _('Remove')
- else
= link_to project_merge_request_approver_group_path(@project, issuable, approver_group), data: { confirm: _("Are you sure you want to remove group %{name}") % { name: approver_group.group.name } }, method: :delete, class: "btn-sm btn btn-remove", title: _('Remove group') do
= icon("sign-out")
= _('Remove')
.col-sm-12
.form-group.row
= form.label :approvals_before_merge, class: 'label-bold' do
= _('Approvals required')
= form.number_field :approvals_before_merge, class: 'form-control', value: issuable.approvals_required, readonly: !can_update_approvers
.form-group
= form.label :approver_ids, class: 'label-bold' do
= _("Add approvers")
= hidden_field_tag "project[approver_ids]"
= hidden_field_tag "project[approver_group_ids]"
.row
.col-md-9
.input-group.input-btn-group
= hidden_field_tag :approver_user_and_group_ids, '', { class: 'js-select-user-and-group input-large', tabindex: 1, 'data-name': 'project', :style => "max-width: unset;" }
%button.btn.btn-success.js-add-approvers.js-dirty-submit{ type: 'button', title: _('Add approver(s)') }
= _("Add")
.form-text.text-muted
= _("Add users or groups who are allowed to approve every merge request")
.card.prepend-top-10.js-current-approvers
.load-wrapper.hidden
= icon('spinner spin', class: 'approver-list-loader')
.card-header
= _("Approvers")
%span.badge.badge-pill
- ids = []
- project.approvers.each do |user|
- ids << user.user_id
- project.approver_groups.each do |group|
- group.users.each do |user|
- unless ids.include?(user.id)
- ids << user.id
= ids.count
%ul.content-list.approver-list
- project.approvers.each do |approver|
%li.approver.settings-flex-row.js-approver{ data: { id: approver.user_id } }
= link_to approver.user.name, approver.user
.float-right
- confirm_message = _("Are you sure you want to remove approver %{name}?") % { name: approver.user.name }
%button{ href: project_approver_path(project, approver), data: { confirm: confirm_message }, class: "btn btn-remove js-approver-remove", title: _("Remove approver") }
= icon("trash")
- project.approver_groups.each do |approver_group|
%li.approver-group.settings-flex-row.js-approver-group{ data: { id: approver_group.group.id } }
%span
%span.light
= _("Group:")
= link_to approver_group.group.name, approver_group.group
%span.badge.badge-pill
= approver_group.group.members.count
.float-right
- confirm_message = _("Are you sure you want to remove group %{name}?") % { name: approver_group.group.name }
%button{ href: project_approver_group_path(project, approver_group), data: { confirm: confirm_message }, class: "btn btn-remove js-approver-remove", title: _("Remove group") }
= icon("trash")
- if project.approvers.empty? && project.approver_groups.empty?
%li= _("There are no approvers")
.form-group
= form.label :approvals_before_merge, class: 'label-bold' do
= _("Approvals required")
= form.number_field :approvals_before_merge, class: "form-control w-auto", min: 0
.form-text.text-muted
= _("Set number of approvers required before open merge requests can be merged")
---
title: Remove old approver system in favor of new approval rule system
merge_request: 12436
author:
type: removed
...@@ -4,11 +4,7 @@ module API ...@@ -4,11 +4,7 @@ module API
module Helpers module Helpers
module ApprovalHelpers module ApprovalHelpers
def present_approval(merge_request) def present_approval(merge_request)
if Feature.enabled?(:approval_rules, merge_request.project, default_enabled: true)
present merge_request.approval_state, with: ::EE::API::Entities::ApprovalState, current_user: current_user present merge_request.approval_state, with: ::EE::API::Entities::ApprovalState, current_user: current_user
else
present merge_request.present(current_user: current_user), with: ::EE::API::Entities::MergeRequestApprovals, current_user: current_user
end
end end
end end
end end
......
...@@ -54,8 +54,6 @@ module API ...@@ -54,8 +54,6 @@ module API
hidden: true hidden: true
} }
get 'approval_settings' do get 'approval_settings' do
not_found! unless ::Feature.enabled?(:approval_rules, user_project, default_enabled: true)
merge_request = find_merge_request_with_access(params[:merge_request_iid]) merge_request = find_merge_request_with_access(params[:merge_request_iid])
present merge_request.approval_state, with: ::EE::API::Entities::MergeRequestApprovalRules, current_user: current_user present merge_request.approval_state, with: ::EE::API::Entities::MergeRequestApprovalRules, current_user: current_user
......
...@@ -3,7 +3,6 @@ ...@@ -3,7 +3,6 @@
module API module API
class ProjectApprovalRules < ::Grape::API class ProjectApprovalRules < ::Grape::API
before { authenticate! } before { authenticate! }
before { not_found! unless ::Feature.enabled?(:approval_rules, user_project, default_enabled: true) }
ARRAY_COERCION_LAMBDA = ->(val) { val.empty? ? [] : Array.wrap(val) } ARRAY_COERCION_LAMBDA = ->(val) { val.empty? ? [] : Array.wrap(val) }
......
...@@ -5,12 +5,12 @@ shared_examples 'approvals' do ...@@ -5,12 +5,12 @@ shared_examples 'approvals' do
JSON.parse(response.body) JSON.parse(response.body)
end end
let!(:approver) { create(:approver, target: project) } let!(:approver) { create(:user) }
let!(:user_approver) { create(:approver, target: project, user: user) } let!(:approval_rule) { create(:approval_project_rule, project: project, users: [approver, user], approvals_required: 2) }
before do before do
merge_request.update_attribute :approvals_before_merge, 2 # merge_request.update_attribute :approvals_before_merge, 2
project.add_developer(approver.user) project.add_developer(approver)
end end
describe 'approve' do describe 'approve' do
...@@ -34,12 +34,12 @@ shared_examples 'approvals' do ...@@ -34,12 +34,12 @@ shared_examples 'approvals' do
expect(approvals['user_has_approved']).to be true expect(approvals['user_has_approved']).to be true
expect(approvals['user_can_approve']).to be false expect(approvals['user_can_approve']).to be false
expect(approvals['suggested_approvers'].size).to eq 1 expect(approvals['suggested_approvers'].size).to eq 1
expect(approvals['suggested_approvers'][0]['username']).to eq approver.user.username expect(approvals['suggested_approvers'][0]['username']).to eq approver.username
end end
end end
describe 'approvals' do describe 'approvals' do
let!(:approval) { create(:approval, merge_request: merge_request, user: approver.user) } let!(:approval) { create(:approval, merge_request: merge_request, user: approver) }
def get_approvals def get_approvals
get :approvals, get :approvals,
...@@ -59,29 +59,12 @@ shared_examples 'approvals' do ...@@ -59,29 +59,12 @@ shared_examples 'approvals' do
expect(response).to be_success expect(response).to be_success
expect(approvals['approvals_left']).to eq 1 expect(approvals['approvals_left']).to eq 1
expect(approvals['approved_by'].size).to eq 1 expect(approvals['approved_by'].size).to eq 1
expect(approvals['approved_by'][0]['user']['username']).to eq approver.user.username expect(approvals['approved_by'][0]['user']['username']).to eq approver.username
expect(approvals['user_has_approved']).to be false expect(approvals['user_has_approved']).to be false
expect(approvals['user_can_approve']).to be true expect(approvals['user_can_approve']).to be true
expect(approvals['suggested_approvers'].size).to eq 1 expect(approvals['suggested_approvers'].size).to eq 1
expect(approvals['suggested_approvers'][0]['username']).to eq user.username expect(approvals['suggested_approvers'][0]['username']).to eq user.username
end end
context 'with unauthorized group' do
let(:private_group) { create(:group_with_members, :private) }
before do
create(:approver_group, target: merge_request, group: private_group)
end
it 'does not expose approvers from a private group the current user has no access to' do
get_approvals
approvals = json_response
expect(response).to be_success
expect(approvals['suggested_approvers'].size).to eq(0)
end
end
end end
describe 'unapprove' do describe 'unapprove' do
...@@ -119,7 +102,6 @@ describe Projects::MergeRequestsController do ...@@ -119,7 +102,6 @@ describe Projects::MergeRequestsController do
let(:viewer) { user } let(:viewer) { user }
before do before do
stub_feature_flags(approval_rules: false)
sign_in(viewer) sign_in(viewer)
end end
......
...@@ -46,17 +46,15 @@ describe "User creates a merge request", :js do ...@@ -46,17 +46,15 @@ describe "User creates a merge request", :js do
end end
# TODO: Fix https://gitlab.com/gitlab-org/gitlab-ee/issues/11527 # TODO: Fix https://gitlab.com/gitlab-org/gitlab-ee/issues/11527
=begin # page.within(".suggested-approvers") do
page.within(".suggested-approvers") do # expect(page).to have_content(user2.name)
expect(page).to have_content(user2.name) # end
end #
# click_link(user2.name)
click_link(user2.name) #
# page.within("ul.approver-list") do
page.within("ul.approver-list") do # expect(page).to have_content(user2.name)
expect(page).to have_content(user2.name) # end
end
=end
fill_in("Title", with: title) fill_in("Title", with: title)
click_button("Submit merge request") click_button("Submit merge request")
...@@ -65,10 +63,8 @@ describe "User creates a merge request", :js do ...@@ -65,10 +63,8 @@ describe "User creates a merge request", :js do
click_link("Edit", match: :first) click_link("Edit", match: :first)
end end
=begin # page.within("ul.approver-list") do
page.within("ul.approver-list") do # expect(page).to have_content(user2.name)
expect(page).to have_content(user2.name) # end
end
=end
end end
end end
...@@ -2,37 +2,13 @@ require 'rails_helper' ...@@ -2,37 +2,13 @@ require 'rails_helper'
describe 'Merge request > User sets approvers', :js do describe 'Merge request > User sets approvers', :js do
include ProjectForksHelper include ProjectForksHelper
include FeatureApprovalHelper
let(:user) { create(:user) } let(:user) { create(:user) }
let(:project) { create(:project, :public, :repository, approvals_before_merge: 1) } let(:project) { create(:project, :public, :repository, approvals_before_merge: 1) }
let!(:config_selector) { '.js-approval-rules' } let!(:config_selector) { '.js-approval-rules' }
let!(:modal_selector) { '#mr-edit-approvals-create-modal' } let!(:modal_selector) { '#mr-edit-approvals-create-modal' }
def open_modal
page.execute_script "document.querySelector('#{config_selector}').scrollIntoView()"
within(config_selector) do
click_on('Edit')
end
end
def open_approver_select
within(modal_selector) do
find('.select2-input').click
end
wait_for_requests
end
def close_approver_select
within(modal_selector) do
find('.select2-input').send_keys :escape
end
end
def remove_approver(name)
el = page.find("#{modal_selector} .content-list li", text: /#{name}/i)
el.find('button').click
end
context 'when editing an MR with a different author' do context 'when editing an MR with a different author' do
let(:author) { create(:user) } let(:author) { create(:user) }
let(:merge_request) { create(:merge_request, author: author, source_project: project) } let(:merge_request) { create(:merge_request, author: author, source_project: project) }
...@@ -72,7 +48,6 @@ describe 'Merge request > User sets approvers', :js do ...@@ -72,7 +48,6 @@ describe 'Merge request > User sets approvers', :js do
open_approver_select open_approver_select
expect(find('.select2-results')).to have_content(other_user.name) expect(find('.select2-results')).to have_content(other_user.name)
# expect(find('.select2-results')).not_to have_content(user.name) # TODO
expect(find('.select2-results')).not_to have_content(non_member.name) expect(find('.select2-results')).not_to have_content(non_member.name)
end end
end end
...@@ -111,7 +86,7 @@ describe 'Merge request > User sets approvers', :js do ...@@ -111,7 +86,7 @@ describe 'Merge request > User sets approvers', :js do
click_button 'Update approvers' click_button 'Update approvers'
click_on("Submit merge request") click_on("Submit merge request")
wait_for_requests wait_for_all_requests
expect(page).to have_content("Requires approval.") expect(page).to have_content("Requires approval.")
expect(page).to have_selector("img[alt='#{other_user.name}']") expect(page).to have_selector("img[alt='#{other_user.name}']")
...@@ -136,13 +111,12 @@ describe 'Merge request > User sets approvers', :js do ...@@ -136,13 +111,12 @@ describe 'Merge request > User sets approvers', :js do
click_button 'Update approvers' click_button 'Update approvers'
click_on("Submit merge request") click_on("Submit merge request")
wait_for_requests wait_for_all_requests
click_on("View eligible approvers") if page.has_button?("View eligible approvers") click_on("View eligible approvers") if page.has_button?("View eligible approvers")
wait_for_requests wait_for_requests
expect(page).not_to have_selector(".js-approvers img[alt='#{other_user.name}']") expect(page).not_to have_selector(".js-approvers img[alt='#{other_user.name}']")
expect(page).to have_selector(".js-approvers img[alt='#{approver.name}']") expect(page).to have_selector(".js-approvers img[alt='#{approver.name}']")
expect(page).to have_content("Requires approval.")
end end
end end
...@@ -179,7 +153,7 @@ describe 'Merge request > User sets approvers', :js do ...@@ -179,7 +153,7 @@ describe 'Merge request > User sets approvers', :js do
click_button 'Update approvers' click_button 'Update approvers'
click_on("Save changes") click_on("Save changes")
wait_for_requests wait_for_all_requests
expect(page).to have_content("Requires approval.") expect(page).to have_content("Requires approval.")
expect(page).to have_selector("img[alt='#{other_user.name}']") expect(page).to have_selector("img[alt='#{other_user.name}']")
...@@ -205,7 +179,7 @@ describe 'Merge request > User sets approvers', :js do ...@@ -205,7 +179,7 @@ describe 'Merge request > User sets approvers', :js do
click_button 'Update approvers' click_button 'Update approvers'
click_on("Save changes") click_on("Save changes")
wait_for_requests wait_for_all_requests
click_on("View eligible approvers") click_on("View eligible approvers")
wait_for_requests wait_for_requests
...@@ -235,7 +209,7 @@ describe 'Merge request > User sets approvers', :js do ...@@ -235,7 +209,7 @@ describe 'Merge request > User sets approvers', :js do
click_button 'Update approvers' click_button 'Update approvers'
click_on('Save changes') click_on('Save changes')
wait_for_requests wait_for_all_requests
# new MR setting on the show MR page # new MR setting on the show MR page
expect(page).to have_content("Requires 3 more approvals") expect(page).to have_content("Requires 3 more approvals")
......
...@@ -2,6 +2,7 @@ require 'spec_helper' ...@@ -2,6 +2,7 @@ require 'spec_helper'
describe 'Project settings > [EE] Merge Requests', :js do describe 'Project settings > [EE] Merge Requests', :js do
include GitlabRoutingHelper include GitlabRoutingHelper
include FeatureApprovalHelper
let(:user) { create(:user) } let(:user) { create(:user) }
let(:project) { create(:project, approvals_before_merge: 1) } let(:project) { create(:project, approvals_before_merge: 1) }
...@@ -11,45 +12,6 @@ describe 'Project settings > [EE] Merge Requests', :js do ...@@ -11,45 +12,6 @@ describe 'Project settings > [EE] Merge Requests', :js do
let!(:config_selector) { '.js-approval-rules' } let!(:config_selector) { '.js-approval-rules' }
let!(:modal_selector) { '#project-settings-approvals-create-modal' } let!(:modal_selector) { '#project-settings-approvals-create-modal' }
def open_modal
page.execute_script "document.querySelector('#{config_selector}').scrollIntoView()"
within(config_selector) do
click_on('Edit')
end
end
def open_approver_select
within(modal_selector) do
find('.select2-input').click
end
wait_for_requests
end
def close_approver_select
within(modal_selector) do
find('.select2-input').send_keys :escape
end
end
def remove_approver(name)
el = page.find("#{modal_selector} .content-list li", text: /#{name}/i)
el.find('button').click
end
def expect_avatar(container, users)
users = Array(users)
members = container.all('.js-members img.avatar').map do |member|
member['alt']
end
users.each do |user|
expect(members).to include(user.name)
end
expect(members.size).to eq(users.size)
end
before do before do
sign_in(user) sign_in(user)
project.add_maintainer(user) project.add_maintainer(user)
......
import $ from 'jquery';
import setup from 'ee/approvals/setup_single_rule_approvals';
describe('EE setup_single_rule_approvals', () => {
preloadFixtures('merge_requests_ee/merge_request_edit.html');
let $approversEl;
let $suggestionEl;
beforeEach(() => {
loadFixtures('merge_requests_ee/merge_request_edit.html');
$approversEl = $('ul.approver-list');
$suggestionEl = $('.suggested-approvers');
setup();
});
describe('add suggested approver', () => {
it('should add approver when suggested user is clicked', () => {
expect($approversEl.find('li.approver').length).toEqual(0);
$suggestionEl
.find('a')
.first()
.click();
$suggestionEl
.find('a')
.last()
.click();
expect($approversEl.find('li.approver').length).toEqual(2);
});
it('only adds approver once when the same suggested user is clicked multiple times', () => {
expect($approversEl.find('li.approver').length).toEqual(0);
$suggestionEl
.find('a')
.first()
.click();
$suggestionEl
.find('a')
.first()
.click();
expect($approversEl.find('li.approver').length).toEqual(1);
});
});
describe('remove unsaved approver', () => {
beforeEach(() => {
$suggestionEl.find('a').click(); // Adds two approvers
});
it('should remove approver if confirm window result is positive', () => {
spyOn(window, 'confirm').and.returnValue(true);
$approversEl
.find('.unsaved-approvers.approver .btn-remove')
.first()
.click();
expect($approversEl.find('li.approver').length).toEqual(1);
});
it('should not remove approver if confirm window result is negative', () => {
spyOn(window, 'confirm').and.returnValue(false);
$approversEl
.find('.unsaved-approvers.approver .btn-remove')
.first()
.click();
expect($approversEl.find('li.approver').length).toEqual(2);
});
});
describe('remove unsaved approver group', () => {
it('should remove approver group if confirm window result is positive', () => {
spyOn(window, 'confirm').and.returnValue(true);
expect($approversEl.find('li.approver-group').length).toEqual(1);
$approversEl
.find('.unsaved-approvers.approver-group .btn-remove')
.first()
.click();
expect($approversEl.find('li.approver-group').length).toEqual(0);
});
it('should not remove approver group if confirm window result is negative', () => {
spyOn(window, 'confirm').and.returnValue(false);
expect($approversEl.find('li.approver-group').length).toEqual(1);
$approversEl
.find('.unsaved-approvers.approver-group .btn-remove')
.first()
.click();
expect($approversEl.find('li.approver-group').length).toEqual(1);
});
});
});
...@@ -170,7 +170,6 @@ describe MergeRequest do ...@@ -170,7 +170,6 @@ describe MergeRequest do
let(:code_owners) { [double(:code_owner)] } let(:code_owners) { [double(:code_owner)] }
before do before do
stub_feature_flags(approval_rules: false)
allow(subject).to receive(:code_owners).and_return(code_owners) allow(subject).to receive(:code_owners).and_return(code_owners)
end end
...@@ -536,36 +535,6 @@ describe MergeRequest do ...@@ -536,36 +535,6 @@ describe MergeRequest do
end end
end end
describe "#overall_approver_groups" do
it 'returns a merge request group approver' do
project = create :project
create :approver_group, target: project
merge_request = create :merge_request, target_project: project, source_project: project
approver_group2 = create :approver_group, target: merge_request
expect(merge_request.overall_approver_groups).to eq([approver_group2])
end
it 'returns a project group approver' do
project = create :project
approver_group1 = create :approver_group, target: project
merge_request = create :merge_request, target_project: project, source_project: project
expect(merge_request.overall_approver_groups).to eq([approver_group1])
end
it 'returns a merge request approver if there is no project group approver' do
project = create :project
merge_request = create :merge_request, target_project: project, source_project: project
approver_group1 = create :approver_group, target: merge_request
expect(merge_request.overall_approver_groups).to eq([approver_group1])
end
end
describe '#all_approvers_including_groups' do describe '#all_approvers_including_groups' do
it 'returns correct set of users' do it 'returns correct set of users' do
user = create :user user = create :user
......
...@@ -1024,16 +1024,6 @@ describe Project do ...@@ -1024,16 +1024,6 @@ describe Project do
expect(project.visible_regular_approval_rules).to contain_exactly(approval_rules.first) expect(project.visible_regular_approval_rules).to contain_exactly(approval_rules.first)
end end
end end
context 'when approval rules are disabled' do
before do
stub_feature_flags(approval_rules: false)
end
it 'does not return any approval rules' do
expect(project.visible_regular_approval_rules).to be_empty
end
end
end end
describe '#min_fallback_approvals' do describe '#min_fallback_approvals' do
...@@ -1060,12 +1050,6 @@ describe Project do ...@@ -1060,12 +1050,6 @@ describe Project do
expect(project.min_fallback_approvals).to eq(2) expect(project.min_fallback_approvals).to eq(2)
end end
it 'returns approvals before merge when code owner rules is disabled' do
stub_feature_flags(approval_rules: false)
expect(project.min_fallback_approvals).to eq(1)
end
end end
end end
......
...@@ -84,110 +84,36 @@ describe MergeRequestPresenter do ...@@ -84,110 +84,36 @@ describe MergeRequestPresenter do
describe '#approvers_left' do describe '#approvers_left' do
let!(:private_group) { create(:group_with_members, :private) } let!(:private_group) { create(:group_with_members, :private) }
let!(:public_group) { create(:group_with_members) } let!(:public_group) { create(:group_with_members) }
let!(:public_approver_group) { create(:approver_group, target: merge_request, group: public_group) } let!(:approver) { create(:user) }
let!(:private_approver_group) { create(:approver_group, target: merge_request, group: private_group) } let!(:approval_rule) { create(:approval_merge_request_rule, merge_request: merge_request, users: [approver], groups: [private_group, public_group]) }
let!(:approver) { create(:approver, target: merge_request) }
before do before do
stub_feature_flags(approval_rules: false) merge_request.approvals.create!(user: approver)
merge_request.approvals.create!(user: approver.user)
end
subject { described_class.new(merge_request, current_user: user).approvers_left }
it { is_expected.to match_array(public_approver_group.users) }
context 'when user has access to private group' do
before do
private_group.add_user(user, Gitlab::Access::DEVELOPER)
end
it do
approvers = public_approver_group.users + private_approver_group.users - [user]
is_expected.to match_array(approvers)
end
end
end
describe '#approvers_left with approval_rule enabled' do
let!(:private_group) { create(:group_with_members, :private) }
let!(:public_group) { create(:group_with_members) }
let!(:public_approver_group) { create(:approver_group, target: merge_request, group: public_group) }
let!(:private_approver_group) { create(:approver_group, target: merge_request, group: private_group) }
let!(:approver) { create(:approver, target: merge_request) }
before do
merge_request.approvals.create!(user: approver.user)
end end
subject { described_class.new(merge_request, current_user: user).approvers_left } subject { described_class.new(merge_request, current_user: user).approvers_left }
it 'contains all approvers' do it 'contains all approvers' do
approvers = public_approver_group.users + private_approver_group.users - [user] approvers = public_group.users + private_group.users - [user]
is_expected.to match_array(approvers) is_expected.to match_array(approvers)
end end
end end
describe '#overall_approver_groups' do describe '#all_approvers_including_groups with approval_rule enabled' do
let!(:private_group) { create(:group_with_members, :private) }
let!(:public_group) { create(:group_with_members) }
let!(:public_approver_group) { create(:approver_group, target: merge_request, group: public_group) }
let!(:private_approver_group) { create(:approver_group, target: merge_request, group: private_group) }
subject { described_class.new(merge_request, current_user: user).overall_approver_groups }
it { is_expected.to match_array([public_approver_group]) }
context 'when user has access to private group' do
before do
private_group.add_user(user, Gitlab::Access::DEVELOPER)
end
it { is_expected.to match_array([public_approver_group, private_approver_group]) }
end
end
describe '#all_approvers_including_groups' do
let!(:private_group) { create(:group_with_members, :private) } let!(:private_group) { create(:group_with_members, :private) }
let!(:public_group) { create(:group_with_members) } let!(:public_group) { create(:group_with_members) }
let!(:public_approver_group) { create(:approver_group, target: merge_request, group: public_group) } let!(:approver) { create(:user) }
let!(:private_approver_group) { create(:approver_group, target: merge_request, group: private_group) } let!(:approval_rule) { create(:approval_merge_request_rule, merge_request: merge_request, users: [approver], groups: [private_group, public_group]) }
let!(:approver) { create(:approver, target: merge_request) }
subject { described_class.new(merge_request, current_user: user).all_approvers_including_groups }
before do
stub_feature_flags(approval_rules: false)
end
it { is_expected.to match_array(public_approver_group.users + [approver.user]) }
context 'when user has access to private group' do
before do before do
private_group.add_user(user, Gitlab::Access::DEVELOPER) project.add_developer(approver)
end
it do
approvers = [public_approver_group.users, private_approver_group.users, approver.user].flatten - [user]
is_expected.to match_array(approvers)
end end
end
end
describe '#all_approvers_including_groups with approval_rule enabled' do
let!(:private_group) { create(:group_with_members, :private) }
let!(:public_group) { create(:group_with_members) }
let!(:public_approver_group) { create(:approver_group, target: merge_request, group: public_group) }
let!(:private_approver_group) { create(:approver_group, target: merge_request, group: private_group) }
let!(:approver) { create(:approver, target: merge_request) }
subject { described_class.new(merge_request, current_user: user).all_approvers_including_groups } subject { described_class.new(merge_request, current_user: user).all_approvers_including_groups }
it do it do
approvers = [public_approver_group.users, private_approver_group.users, approver.user].flatten - [user] approvers = [public_group.users, private_group.users, approver].flatten - [user]
is_expected.to match_array(approvers) is_expected.to match_array(approvers)
end end
......
...@@ -10,15 +10,10 @@ describe API::ProjectApprovals do ...@@ -10,15 +10,10 @@ describe API::ProjectApprovals do
let(:url) { "/projects/#{project.id}/approvals" } let(:url) { "/projects/#{project.id}/approvals" }
before do describe 'GET /projects/:id/approvals' do
stub_feature_flags(approval_rules: false)
end
describe 'GET /projects/:id/approvers' do
context 'when the request is correct' do context 'when the request is correct' do
before do before do
project.approvers.create(user: approver) create(:approval_project_rule, project: project, users: [approver], groups: [group])
project.approver_groups.create(group: group)
get api(url, user) get api(url, user)
end end
...@@ -34,7 +29,7 @@ describe API::ProjectApprovals do ...@@ -34,7 +29,7 @@ describe API::ProjectApprovals do
it 'only shows approver groups that are visible to the user' do it 'only shows approver groups that are visible to the user' do
private_group = create(:group, :private) private_group = create(:group, :private)
project.approver_groups.create(group: private_group) create(:approval_project_rule, project: project, users: [approver], groups: [private_group])
get api(url, user) get api(url, user)
...@@ -43,7 +38,7 @@ describe API::ProjectApprovals do ...@@ -43,7 +38,7 @@ describe API::ProjectApprovals do
end end
end end
describe 'POST /projects/:id/approvers' do describe 'POST /projects/:id/approvals' do
shared_examples_for 'a user with access' do shared_examples_for 'a user with access' do
context 'when missing parameters' do context 'when missing parameters' do
it 'returns 400 status' do it 'returns 400 status' do
......
...@@ -73,72 +73,7 @@ describe MergeRequests::RefreshService do ...@@ -73,72 +73,7 @@ describe MergeRequests::RefreshService do
end end
end end
context 'when code owners enabled, with approval_rule disabled' do context 'when code owners enabled' do
let(:old_owners) { [] }
let(:new_owners) { [] }
let(:relevant_merge_requests) { [merge_request, another_merge_request] }
before do
stub_feature_flags(approval_rules: false)
relevant_merge_requests.each do |merge_request|
expect(::Gitlab::CodeOwners).to receive(:for_merge_request).with(merge_request).and_return(new_owners)
expect(::Gitlab::CodeOwners).to receive(:for_merge_request).with(merge_request, merge_request_diff: anything).and_wrap_original do |m, *args|
expect(args.last[:merge_request_diff]).to eq(merge_request.merge_request_diffs.order(id: :desc).offset(1).first)
old_owners
end
end
[forked_merge_request].each do |merge_request|
expect(::Gitlab::CodeOwners).not_to receive(:for_merge_request).with(merge_request, anything)
end
expect(service.todo_service).not_to receive(:add_merge_request_approvers)
expect(service.notification_service).not_to receive(:add_merge_request_approvers)
end
context 'merge request has overwritten approvers' do
context 'when new owners are being added' do
let(:new_owners) { [owner] }
it 'does not create Approver' do
expect { subject }.not_to change { Approver.count }
rule = merge_request.approval_rules.code_owner.first
expect(rule.users).to eq(new_owners)
end
end
end
context 'merge request has default approvers' do
let(:existing_approver) { create(:user) }
before do
create(:approver, target: merge_request, user: existing_approver)
end
context 'when new owners are being added' do
let(:new_owners) { [owner] }
it 'creates Approver' do
expect { subject }.to change { Approver.count }.by(1)
new_approver = merge_request.approvers.last
expect(merge_request.approvers.first.user).to eq(existing_approver)
expect(new_approver.user).to eq(owner)
expect(new_approver.created_at).to be_present
expect(new_approver.updated_at).to be_present
rule = merge_request.approval_rules.code_owner.first
expect(rule.users).to eq(new_owners)
end
end
end
end
context 'when code owners enabled, with approval_rule enabled' do
let(:relevant_merge_requests) { [merge_request, another_merge_request] } let(:relevant_merge_requests) { [merge_request, another_merge_request] }
it 'refreshes the code owner rules for all relevant merge requests' do it 'refreshes the code owner rules for all relevant merge requests' do
......
...@@ -491,8 +491,6 @@ describe EE::NotificationService, :mailer do ...@@ -491,8 +491,6 @@ describe EE::NotificationService, :mailer do
end end
before do before do
stub_feature_flags(approval_rules: false)
project.add_maintainer(merge_request.author) project.add_maintainer(merge_request.author)
merge_request.assignees.each { |assignee| project.add_maintainer(assignee) } merge_request.assignees.each { |assignee| project.add_maintainer(assignee) }
build_team(merge_request.target_project) build_team(merge_request.target_project)
...@@ -511,10 +509,10 @@ describe EE::NotificationService, :mailer do ...@@ -511,10 +509,10 @@ describe EE::NotificationService, :mailer do
context 'when the target project has approvers set' do context 'when the target project has approvers set' do
let(:project_approvers) { create_list(:user, 3) } let(:project_approvers) { create_list(:user, 3) }
let!(:rule) { create(:approval_project_rule, project: project, users: project_approvers, approvals_required: 1 )}
before do before do
merge_request.target_project.update(approvals_before_merge: 1) merge_request.target_project.update(approvals_before_merge: 1)
project_approvers.each { |approver| create(:approver, user: approver, target: merge_request.target_project) }
reset_delivered_emails! reset_delivered_emails!
end end
...@@ -525,7 +523,7 @@ describe EE::NotificationService, :mailer do ...@@ -525,7 +523,7 @@ describe EE::NotificationService, :mailer do
end end
it 'does not email the approvers when approval is not necessary' do it 'does not email the approvers when approval is not necessary' do
merge_request.target_project.update(approvals_before_merge: 0) rule.update(approvals_required: 0)
notification.new_merge_request(merge_request, @u_disabled) notification.new_merge_request(merge_request, @u_disabled)
project_approvers.each { |approver| should_not_email(approver) } project_approvers.each { |approver| should_not_email(approver) }
...@@ -533,9 +531,9 @@ describe EE::NotificationService, :mailer do ...@@ -533,9 +531,9 @@ describe EE::NotificationService, :mailer do
context 'when the merge request has approvers set' do context 'when the merge request has approvers set' do
let(:mr_approvers) { create_list(:user, 3) } let(:mr_approvers) { create_list(:user, 3) }
let!(:mr_rule) { create(:approval_merge_request_rule, merge_request: merge_request, users: mr_approvers, approvals_required: 1 )}
before do before do
mr_approvers.each { |approver| create(:approver, user: approver, target: merge_request) }
reset_delivered_emails! reset_delivered_emails!
end end
......
...@@ -8,10 +8,6 @@ describe MergeRequests::RemoveApprovalService do ...@@ -8,10 +8,6 @@ describe MergeRequests::RemoveApprovalService do
subject(:service) { described_class.new(project, user) } subject(:service) { described_class.new(project, user) }
before do
stub_feature_flags(approval_rules: false)
end
def execute! def execute!
service.execute(merge_request) service.execute(merge_request)
end end
......
...@@ -60,32 +60,6 @@ describe MergeRequests::UpdateService, :mailer do ...@@ -60,32 +60,6 @@ describe MergeRequests::UpdateService, :mailer do
context 'when approvals_before_merge changes' do context 'when approvals_before_merge changes' do
using RSpec::Parameterized::TableSyntax using RSpec::Parameterized::TableSyntax
context 'when approval_rules is disabled' do
before do
stub_feature_flags(approval_rules: false)
end
where(:project_value, :mr_before_value, :mr_after_value, :result) do
3 | 4 | 5 | 5
3 | 4 | nil | 3
3 | nil | 5 | 5
end
with_them do
let(:project) { create(:project, :repository, approvals_before_merge: project_value) }
it "updates approval_rules' approvals_required" do
merge_request.update(approvals_before_merge: mr_before_value)
rule = create(:approval_merge_request_rule, merge_request: merge_request)
update_merge_request(approvals_before_merge: mr_after_value)
expect(rule.reload.approvals_required).to eq(result)
end
end
end
context 'when approval_rules is enabled' do
where(:project_value, :mr_before_value, :mr_after_value, :result) do where(:project_value, :mr_before_value, :mr_after_value, :result) do
3 | 4 | 5 | 5 3 | 4 | 5 | 5
3 | 4 | nil | 3 3 | 4 | nil | 3
...@@ -105,13 +79,8 @@ describe MergeRequests::UpdateService, :mailer do ...@@ -105,13 +79,8 @@ describe MergeRequests::UpdateService, :mailer do
end end
end end
end end
end
context 'merge' do context 'merge' do
before do
stub_feature_flags(approval_rules: false)
end
let(:opts) { { merge: merge_request.diff_head_sha } } let(:opts) { { merge: merge_request.diff_head_sha } }
context 'when not approved' do context 'when not approved' do
...@@ -150,8 +119,6 @@ describe MergeRequests::UpdateService, :mailer do ...@@ -150,8 +119,6 @@ describe MergeRequests::UpdateService, :mailer do
let(:new_approver) { create(:user) } let(:new_approver) { create(:user) }
before do before do
stub_feature_flags(approval_rules: false)
project.add_developer(existing_approver) project.add_developer(existing_approver)
project.add_developer(removed_approver) project.add_developer(removed_approver)
project.add_developer(new_approver) project.add_developer(new_approver)
......
...@@ -177,40 +177,6 @@ describe Projects::UpdateService, '#execute' do ...@@ -177,40 +177,6 @@ describe Projects::UpdateService, '#execute' do
end end
end end
context 'with approval_rules' do
context 'when approval_rules is disabled' do
it "updates approval_rules' approvals_required" do
stub_feature_flags(approval_rules: false)
rule = create(:approval_project_rule, project: project)
update_project(project, user, approvals_before_merge: 42)
expect(rule.reload.approvals_required).to eq(42)
end
end
context 'when approval_rules is enabled' do
it 'does not update' do
rule = create(:approval_project_rule, project: project)
update_project(project, user, approvals_before_merge: 42)
expect(rule.reload.approvals_required).to eq(0)
end
end
context 'when approval_rule feature is enabled' do
it "does not update approval_rules' approvals_required" do
rule = create(:approval_project_rule, project: project)
expect do
update_project(project, user, approvals_before_merge: 42)
end.not_to change { rule.reload.approvals_required }
end
end
end
describe 'repository_storage' do describe 'repository_storage' do
let(:admin_user) { create(:user, admin: true) } let(:admin_user) { create(:user, admin: true) }
let(:user) { create(:user) } let(:user) { create(:user) }
......
# frozen_string_literal: true
module FeatureApprovalHelper
def open_modal
page.execute_script "document.querySelector('#{config_selector}').scrollIntoView()"
within(config_selector) do
click_on('Edit')
end
end
def open_approver_select
within(modal_selector) do
find('.select2-input').click
end
wait_for_requests
end
def close_approver_select
within(modal_selector) do
find('.select2-input').send_keys :escape
end
end
def remove_approver(name)
el = page.find("#{modal_selector} .content-list li", text: /#{name}/i)
el.find('button').click
end
def expect_avatar(container, users)
users = Array(users)
members = container.all('.js-members img.avatar').map do |member|
member['alt']
end
users.each do |user|
expect(members).to include(user.name)
end
expect(members.size).to eq(users.size)
end
end
...@@ -17,15 +17,10 @@ describe 'shared/issuable/_approvals.html.haml' do ...@@ -17,15 +17,10 @@ describe 'shared/issuable/_approvals.html.haml' do
allow(form).to receive(:number_field) allow(form).to receive(:number_field)
allow(MergeRequestApproverPresenter).to receive(:new).and_return(approver_presenter) allow(MergeRequestApproverPresenter).to receive(:new).and_return(approver_presenter)
assign(:project, project) assign(:project, project)
assign(:target_project, project)
end end
context 'has no approvers' do context 'has no approvers' do
it 'shows empty approvers list' do
render 'shared/issuable/approvals', form: form, issuable: merge_request, presenter: presenter
expect(rendered).to have_text('There are no approvers')
end
context 'can override approvers' do context 'can override approvers' do
before do before do
render 'shared/issuable/approvals', form: form, issuable: merge_request, presenter: presenter render 'shared/issuable/approvals', form: form, issuable: merge_request, presenter: presenter
...@@ -34,14 +29,6 @@ describe 'shared/issuable/_approvals.html.haml' do ...@@ -34,14 +29,6 @@ describe 'shared/issuable/_approvals.html.haml' do
it 'shows suggested approvers' do it 'shows suggested approvers' do
expect(rendered).to have_css('.suggested-approvers') expect(rendered).to have_css('.suggested-approvers')
end end
it 'shows select approvers field' do
expect(rendered).to have_css('#merge_request_approver_ids', visible: false)
end
it 'shows select approver groups field' do
expect(rendered).to have_css('#merge_request_approver_group_ids', visible: false)
end
end end
context 'can not override approvers' do context 'can not override approvers' do
...@@ -82,14 +69,6 @@ describe 'shared/issuable/_approvals.html.haml' do ...@@ -82,14 +69,6 @@ describe 'shared/issuable/_approvals.html.haml' do
expect(rendered).to have_text(approver_group[:name]) expect(rendered).to have_text(approver_group[:name])
end end
context 'can override approvers' do
it 'shows remove button for approver' do
render 'shared/issuable/approvals', form: form, issuable: merge_request, presenter: presenter
expect(rendered).to have_css('.btn-remove')
end
end
context 'can not override approvers' do context 'can not override approvers' do
it 'hides remove button' do it 'hides remove button' do
allow(view).to receive(:can?).with(user, :update_approvers, merge_request).and_return(false) allow(view).to receive(:can?).with(user, :update_approvers, merge_request).and_return(false)
......
...@@ -693,9 +693,6 @@ msgstr "" ...@@ -693,9 +693,6 @@ msgstr ""
msgid "Add an SSH key" msgid "Add an SSH key"
msgstr "" msgstr ""
msgid "Add approver(s)"
msgstr ""
msgid "Add approvers" msgid "Add approvers"
msgstr "" msgstr ""
...@@ -750,9 +747,6 @@ msgstr "" ...@@ -750,9 +747,6 @@ msgstr ""
msgid "Add user(s) to the group:" msgid "Add user(s) to the group:"
msgstr "" msgstr ""
msgid "Add users or groups who are allowed to approve every merge request"
msgstr ""
msgid "Add users to group" msgid "Add users to group"
msgstr "" msgstr ""
...@@ -1082,9 +1076,6 @@ msgstr "" ...@@ -1082,9 +1076,6 @@ msgstr ""
msgid "An error occurred when updating the issue weight" msgid "An error occurred when updating the issue weight"
msgstr "" msgstr ""
msgid "An error occurred while adding approver"
msgstr ""
msgid "An error occurred while deleting the approvers group" msgid "An error occurred while deleting the approvers group"
msgstr "" msgstr ""
...@@ -1193,9 +1184,6 @@ msgstr "" ...@@ -1193,9 +1184,6 @@ msgstr ""
msgid "An error occurred while parsing recent searches" msgid "An error occurred while parsing recent searches"
msgstr "" msgstr ""
msgid "An error occurred while removing approver"
msgstr ""
msgid "An error occurred while removing epics." msgid "An error occurred while removing epics."
msgstr "" msgstr ""
...@@ -1414,12 +1402,6 @@ msgstr "" ...@@ -1414,12 +1402,6 @@ msgstr ""
msgid "Approvals" msgid "Approvals"
msgstr "" msgstr ""
msgid "Approvals required"
msgstr ""
msgid "Approvers"
msgstr ""
msgid "Apr" msgid "Apr"
msgstr "" msgstr ""
...@@ -1483,18 +1465,6 @@ msgstr "" ...@@ -1483,18 +1465,6 @@ msgstr ""
msgid "Are you sure you want to remove %{group_name}?" msgid "Are you sure you want to remove %{group_name}?"
msgstr "" msgstr ""
msgid "Are you sure you want to remove approver %{name}"
msgstr ""
msgid "Are you sure you want to remove approver %{name}?"
msgstr ""
msgid "Are you sure you want to remove group %{name}"
msgstr ""
msgid "Are you sure you want to remove group %{name}?"
msgstr ""
msgid "Are you sure you want to remove the attachment?" msgid "Are you sure you want to remove the attachment?"
msgstr "" msgstr ""
...@@ -10760,9 +10730,6 @@ msgstr "" ...@@ -10760,9 +10730,6 @@ msgstr ""
msgid "Remove all or specific label(s)" msgid "Remove all or specific label(s)"
msgstr "" msgstr ""
msgid "Remove approver"
msgstr ""
msgid "Remove approvers" msgid "Remove approvers"
msgstr "" msgstr ""
...@@ -11699,9 +11666,6 @@ msgstr "" ...@@ -11699,9 +11666,6 @@ msgstr ""
msgid "Set notification email for abuse reports." msgid "Set notification email for abuse reports."
msgstr "" msgstr ""
msgid "Set number of approvers required before open merge requests can be merged"
msgstr ""
msgid "Set requirements for a user to sign-in. Enable mandatory two-factor authentication." msgid "Set requirements for a user to sign-in. Enable mandatory two-factor authentication."
msgstr "" msgstr ""
...@@ -13083,9 +13047,6 @@ msgstr "" ...@@ -13083,9 +13047,6 @@ msgstr ""
msgid "There are no SSH keys with access to your account." msgid "There are no SSH keys with access to your account."
msgstr "" msgstr ""
msgid "There are no approvers"
msgstr ""
msgid "There are no archived projects yet" msgid "There are no archived projects yet"
msgstr "" msgstr ""
...@@ -13377,12 +13338,6 @@ msgstr "" ...@@ -13377,12 +13338,6 @@ msgstr ""
msgid "This merge request is locked." msgid "This merge request is locked."
msgstr "" msgstr ""
msgid "This merge request must be approved by members of these groups. You can override the project settings by setting your own list of approvers."
msgstr ""
msgid "This merge request must be approved by these users. You can override the project settings by setting your own list of approvers."
msgstr ""
msgid "This namespace has already been taken! Please choose another one." msgid "This namespace has already been taken! Please choose another one."
msgstr "" msgstr ""
...@@ -15922,9 +15877,6 @@ msgstr "" ...@@ -15922,9 +15877,6 @@ msgstr ""
msgid "mrWidget|%{metricsLinkStart} Memory %{metricsLinkEnd} usage is %{emphasisStart} unchanged %{emphasisEnd} at %{memoryFrom}MB" msgid "mrWidget|%{metricsLinkStart} Memory %{metricsLinkEnd} usage is %{emphasisStart} unchanged %{emphasisEnd} at %{memoryFrom}MB"
msgstr "" msgstr ""
msgid "mrWidget|Add approval"
msgstr ""
msgid "mrWidget|Allows commits from members who can merge to the target branch" msgid "mrWidget|Allows commits from members who can merge to the target branch"
msgstr "" msgstr ""
...@@ -16018,15 +15970,9 @@ msgstr "" ...@@ -16018,15 +15970,9 @@ msgstr ""
msgid "mrWidget|Merge locally" msgid "mrWidget|Merge locally"
msgstr "" msgstr ""
msgid "mrWidget|Merge request approved"
msgstr ""
msgid "mrWidget|Merge request approved." msgid "mrWidget|Merge request approved."
msgstr "" msgstr ""
msgid "mrWidget|Merge request approved; you can approve additionally"
msgstr ""
msgid "mrWidget|Merged by" msgid "mrWidget|Merged by"
msgstr "" msgstr ""
...@@ -16057,22 +16003,9 @@ msgstr "" ...@@ -16057,22 +16003,9 @@ msgstr ""
msgid "mrWidget|Refreshing now" msgid "mrWidget|Refreshing now"
msgstr "" msgstr ""
msgid "mrWidget|Remove your approval"
msgstr ""
msgid "mrWidget|Request to merge" msgid "mrWidget|Request to merge"
msgstr "" msgstr ""
msgid "mrWidget|Requires 1 more approval"
msgid_plural "mrWidget|Requires %d more approvals"
msgstr[0] ""
msgstr[1] ""
msgid "mrWidget|Requires 1 more approval by"
msgid_plural "mrWidget|Requires %d more approvals by"
msgstr[0] ""
msgstr[1] ""
msgid "mrWidget|Resolve conflicts" msgid "mrWidget|Resolve conflicts"
msgstr "" msgstr ""
......
...@@ -32,10 +32,6 @@ module QA ...@@ -32,10 +32,6 @@ module QA
element :review_preview_toggle element :review_preview_toggle
end end
view 'ee/app/views/shared/issuable/_approvals_single_rule.html.haml' do
element :approver_list
end
def start_review def start_review
click_element :start_review click_element :start_review
end end
......
...@@ -6,7 +6,6 @@ describe 'Project' do ...@@ -6,7 +6,6 @@ describe 'Project' do
before do before do
stub_feature_flags(vue_file_list: false) stub_feature_flags(vue_file_list: false)
stub_feature_flags(approval_rules: false)
end end
describe 'creating from template' do describe 'creating from template' 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