summaryrefslogtreecommitdiff
path: root/spec/features/merge_request/user_sees_merge_button_depending_on_unresolved_discussions_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/features/merge_request/user_sees_merge_button_depending_on_unresolved_discussions_spec.rb')
-rw-r--r--spec/features/merge_request/user_sees_merge_button_depending_on_unresolved_discussions_spec.rb61
1 files changed, 61 insertions, 0 deletions
diff --git a/spec/features/merge_request/user_sees_merge_button_depending_on_unresolved_discussions_spec.rb b/spec/features/merge_request/user_sees_merge_button_depending_on_unresolved_discussions_spec.rb
new file mode 100644
index 00000000000..85df43df38e
--- /dev/null
+++ b/spec/features/merge_request/user_sees_merge_button_depending_on_unresolved_discussions_spec.rb
@@ -0,0 +1,61 @@
+require 'rails_helper'
+
+describe 'Merge request > User sees merge button depending on unresolved discussions', :js do
+ let(:project) { create(:project, :repository) }
+ let(:user) { project.creator }
+ let!(:merge_request) { create(:merge_request_with_diff_notes, source_project: project, author: user) }
+
+ before do
+ project.add_master(user)
+ sign_in(user)
+ end
+
+ context 'when project.only_allow_merge_if_all_discussions_are_resolved == true' do
+ before do
+ project.update_column(:only_allow_merge_if_all_discussions_are_resolved, true)
+ visit project_merge_request_path(project, merge_request)
+ end
+
+ context 'with unresolved discussions' do
+ it 'does not allow to merge' do
+ expect(page).not_to have_button 'Merge'
+ expect(page).to have_content('There are unresolved discussions.')
+ end
+ end
+
+ context 'with all discussions resolved' do
+ before do
+ merge_request.discussions.each { |d| d.resolve!(user) }
+ visit project_merge_request_path(project, merge_request)
+ end
+
+ it 'allows MR to be merged' do
+ expect(page).to have_button 'Merge'
+ end
+ end
+ end
+
+ context 'when project.only_allow_merge_if_all_discussions_are_resolved == false' do
+ before do
+ project.update_column(:only_allow_merge_if_all_discussions_are_resolved, false)
+ visit project_merge_request_path(project, merge_request)
+ end
+
+ context 'with unresolved discussions' do
+ it 'does not allow to merge' do
+ expect(page).to have_button 'Merge'
+ end
+ end
+
+ context 'with all discussions resolved' do
+ before do
+ merge_request.discussions.each { |d| d.resolve!(user) }
+ visit project_merge_request_path(project, merge_request)
+ end
+
+ it 'allows MR to be merged' do
+ expect(page).to have_button 'Merge'
+ end
+ end
+ end
+end