diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-07-20 15:26:25 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-07-20 15:26:25 +0300 |
commit | a09983ae35713f5a2bbb100981116d31ce99826e (patch) | |
tree | 2ee2af7bd104d57086db360a7e6d8c9d5d43667a /spec/features/merge_request/user_approves_spec.rb | |
parent | 18c5ab32b738c0b6ecb4d0df3994000482f34bd8 (diff) |
Add latest changes from gitlab-org/gitlab@13-2-stable-ee
Diffstat (limited to 'spec/features/merge_request/user_approves_spec.rb')
-rw-r--r-- | spec/features/merge_request/user_approves_spec.rb | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/spec/features/merge_request/user_approves_spec.rb b/spec/features/merge_request/user_approves_spec.rb new file mode 100644 index 00000000000..d319fdcb87b --- /dev/null +++ b/spec/features/merge_request/user_approves_spec.rb @@ -0,0 +1,41 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe 'Merge request > User approves', :js do + let(:user) { create(:user) } + let(:project) { create(:project, :public, :repository) } + let(:merge_request) { create(:merge_request, source_project: project) } + + before do + project.add_developer(user) + + sign_in(user) + + visit project_merge_request_path(project, merge_request) + end + + it 'approves merge request' do + click_approval_button('Approve') + expect(page).to have_content('Merge request approved') + + verify_approvals_count_on_index! + + click_approval_button('Revoke approval') + expect(page).to have_content('No approval required; you can still approve') + end + + def verify_approvals_count_on_index! + visit(project_merge_requests_path(project, state: :all)) + expect(page.all('li').any? { |item| item["title"] == "1 approver (you've approved)"}).to be true + visit project_merge_request_path(project, merge_request) + end + + def click_approval_button(action) + page.within('.mr-state-widget') do + click_button(action) + end + + wait_for_requests + end +end |