2019-07-25 01:24:42 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2019-08-29 03:56:52 -04:00
|
|
|
require 'spec_helper'
|
2017-04-12 11:02:53 -04:00
|
|
|
|
2020-06-16 14:09:01 -04:00
|
|
|
RSpec.describe 'Merge request > User posts notes', :js do
|
2017-06-07 14:33:50 -04:00
|
|
|
include NoteInteractionHelpers
|
|
|
|
|
2020-02-26 13:09:24 -05:00
|
|
|
let_it_be(:project) { create(:project, :repository) }
|
2017-08-01 14:03:07 -04:00
|
|
|
let(:user) { project.creator }
|
2017-04-12 11:02:53 -04:00
|
|
|
let(:merge_request) do
|
|
|
|
create(:merge_request, source_project: project, target_project: project)
|
|
|
|
end
|
2020-08-10 23:11:00 -04:00
|
|
|
|
2017-04-12 11:02:53 -04:00
|
|
|
let!(:note) do
|
|
|
|
create(:note_on_merge_request, :with_attachment, noteable: merge_request,
|
|
|
|
project: project)
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
2018-07-11 10:36:08 -04:00
|
|
|
project.add_maintainer(user)
|
2017-08-01 14:03:07 -04:00
|
|
|
sign_in(user)
|
2017-07-06 12:20:50 -04:00
|
|
|
visit project_merge_request_path(project, merge_request)
|
2017-04-12 11:02:53 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
subject { page }
|
|
|
|
|
|
|
|
describe 'the note form' do
|
|
|
|
it 'is valid' do
|
|
|
|
is_expected.to have_css('.js-main-target-form', visible: true, count: 1)
|
2018-06-21 08:22:40 -04:00
|
|
|
expect(find('.js-main-target-form')).to have_selector('button', text: 'Comment')
|
2017-04-12 11:02:53 -04:00
|
|
|
page.within('.js-main-target-form') do
|
2018-06-21 08:22:40 -04:00
|
|
|
expect(page).not_to have_button('Cancel')
|
2017-04-12 11:02:53 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'with text' do
|
2019-09-06 11:49:13 -04:00
|
|
|
let(:text) { 'This is awesome' }
|
|
|
|
|
2017-04-12 11:02:53 -04:00
|
|
|
before do
|
|
|
|
page.within('.js-main-target-form') do
|
2019-09-06 11:49:13 -04:00
|
|
|
fill_in 'note[note]', with: text
|
2017-04-12 11:02:53 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-09-06 11:49:13 -04:00
|
|
|
it 'has enable submit button, preview button and saves content to local storage' do
|
2017-04-12 11:02:53 -04:00
|
|
|
page.within('.js-main-target-form') do
|
|
|
|
expect(page).not_to have_css('.js-comment-button[disabled]')
|
|
|
|
expect(page).to have_css('.js-md-preview-button', visible: true)
|
|
|
|
end
|
2019-09-06 11:49:13 -04:00
|
|
|
|
|
|
|
expect(page.evaluate_script("localStorage['autosave/Note/MergeRequest/#{merge_request.id}']")).to eq(text)
|
2017-04-12 11:02:53 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'when posting a note' do
|
|
|
|
before do
|
|
|
|
page.within('.js-main-target-form') do
|
|
|
|
fill_in 'note[note]', with: 'This is awesome!'
|
|
|
|
find('.js-md-preview-button').click
|
|
|
|
click_button 'Comment'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'is added and form reset' do
|
|
|
|
is_expected.to have_content('This is awesome!')
|
|
|
|
page.within('.js-main-target-form') do
|
|
|
|
expect(page).to have_no_field('note[note]', with: 'This is awesome!')
|
2018-06-21 08:22:40 -04:00
|
|
|
expect(page).to have_css('.js-vue-md-preview', visible: :hidden)
|
2017-04-12 11:02:53 -04:00
|
|
|
end
|
2018-06-21 08:22:40 -04:00
|
|
|
wait_for_requests
|
2017-04-12 11:02:53 -04:00
|
|
|
page.within('.js-main-target-form') do
|
|
|
|
is_expected.to have_css('.js-note-text', visible: true)
|
|
|
|
end
|
|
|
|
end
|
2019-02-06 05:31:46 -05:00
|
|
|
|
2019-04-02 22:00:18 -04:00
|
|
|
describe 'reply button' do
|
2019-02-06 05:31:46 -05:00
|
|
|
before do
|
|
|
|
visit project_merge_request_path(project, merge_request)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'shows a reply button' do
|
|
|
|
reply_button = find('.js-reply-button', match: :first)
|
|
|
|
|
2020-08-20 17:10:18 -04:00
|
|
|
expect(reply_button).to have_selector('[data-testid="comment-icon"]')
|
2019-02-06 05:31:46 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'shows reply placeholder when clicking reply button' do
|
|
|
|
reply_button = find('.js-reply-button', match: :first)
|
|
|
|
|
|
|
|
reply_button.click
|
|
|
|
|
|
|
|
expect(page).to have_selector('.discussion-reply-holder')
|
|
|
|
end
|
|
|
|
end
|
2017-04-12 11:02:53 -04:00
|
|
|
end
|
|
|
|
|
2020-08-18 17:09:57 -04:00
|
|
|
describe 'replying to a comment' do
|
|
|
|
it 'makes the discussion resolvable' do
|
2019-12-12 19:08:05 -05:00
|
|
|
find('.js-reply-button').click
|
|
|
|
|
|
|
|
page.within('.discussion-reply-holder') do
|
|
|
|
fill_in 'note[note]', with: 'A reply'
|
2020-06-01 02:08:21 -04:00
|
|
|
click_button 'Add comment now'
|
2020-08-18 17:09:57 -04:00
|
|
|
|
|
|
|
expect(page).to have_button('Resolve thread')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when comment is deleted' do
|
|
|
|
it 'shows an error message' do
|
|
|
|
find('.js-reply-button').click
|
|
|
|
|
|
|
|
page.within('.discussion-reply-holder') do
|
|
|
|
fill_in 'note[note]', with: 'A reply'
|
2020-08-18 20:10:34 -04:00
|
|
|
|
|
|
|
note.delete
|
|
|
|
|
2020-08-18 17:09:57 -04:00
|
|
|
click_button 'Add comment now'
|
|
|
|
|
|
|
|
expect(page).to have_content('Your comment could not be submitted because discussion to reply to cannot be found')
|
|
|
|
end
|
2019-12-12 19:08:05 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-12-20 14:29:44 -05:00
|
|
|
describe 'when previewing a note' do
|
|
|
|
it 'shows the toolbar buttons when editing a note' do
|
|
|
|
page.within('.js-main-target-form') do
|
|
|
|
expect(page).to have_css('.md-header-toolbar.active')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'hides the toolbar buttons when previewing a note' do
|
2018-06-21 08:22:40 -04:00
|
|
|
wait_for_requests
|
2017-12-20 14:29:44 -05:00
|
|
|
find('.js-md-preview-button').click
|
|
|
|
page.within('.js-main-target-form') do
|
|
|
|
expect(page).not_to have_css('.md-header-toolbar.active')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-04-12 11:02:53 -04:00
|
|
|
describe 'when editing a note' do
|
|
|
|
describe 'editing the note' do
|
|
|
|
before do
|
|
|
|
find('.note').hover
|
2017-06-07 14:33:50 -04:00
|
|
|
|
2017-04-12 11:02:53 -04:00
|
|
|
find('.js-note-edit').click
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'shows the note edit form and hide the note body' do
|
|
|
|
page.within("#note_#{note.id}") do
|
|
|
|
expect(find('.current-note-edit-form', visible: true)).to be_visible
|
|
|
|
expect(find('.note-edit-form', visible: true)).to be_visible
|
|
|
|
expect(find(:css, '.note-body > .note-text', visible: false)).not_to be_visible
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'resets the edit note form textarea with the original content of the note if cancelled' do
|
|
|
|
within('.current-note-edit-form') do
|
|
|
|
fill_in 'note[note]', with: 'Some new content'
|
2020-05-05 17:09:42 -04:00
|
|
|
|
|
|
|
accept_confirm do
|
|
|
|
find('.btn-cancel').click
|
|
|
|
end
|
2017-04-12 11:02:53 -04:00
|
|
|
end
|
2018-06-21 08:22:40 -04:00
|
|
|
expect(find('.js-note-text').text).to eq ''
|
2017-04-12 11:02:53 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'allows using markdown buttons after saving a note and then trying to edit it again' do
|
|
|
|
page.within('.current-note-edit-form') do
|
|
|
|
fill_in 'note[note]', with: 'This is the new content'
|
2018-09-18 05:58:22 -04:00
|
|
|
find('.btn-success').click
|
2017-04-12 11:02:53 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
find('.note').hover
|
2018-06-21 08:22:40 -04:00
|
|
|
wait_for_requests
|
2017-06-07 14:33:50 -04:00
|
|
|
|
2017-04-12 11:02:53 -04:00
|
|
|
find('.js-note-edit').click
|
|
|
|
|
|
|
|
page.within('.current-note-edit-form') do
|
2020-01-14 07:07:41 -05:00
|
|
|
expect(find('#note_note').value).to include('This is the new content')
|
2019-06-14 09:01:24 -04:00
|
|
|
first('.js-md').click
|
2020-01-14 07:07:41 -05:00
|
|
|
expect(find('#note_note').value).to include('This is the new content****')
|
2017-04-12 11:02:53 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'appends the edited at time to the note' do
|
|
|
|
page.within('.current-note-edit-form') do
|
|
|
|
fill_in 'note[note]', with: 'Some new content'
|
2018-09-18 05:58:22 -04:00
|
|
|
find('.btn-success').click
|
2017-04-12 11:02:53 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
page.within("#note_#{note.id}") do
|
|
|
|
is_expected.to have_css('.note_edited_ago')
|
2017-06-21 09:48:12 -04:00
|
|
|
expect(find('.note_edited_ago').text)
|
2018-06-03 10:45:26 -04:00
|
|
|
.to match(/just now/)
|
2017-04-12 11:02:53 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-02-27 19:10:43 -05:00
|
|
|
describe 'deleting attachment on legacy diff note' do
|
2017-04-12 11:02:53 -04:00
|
|
|
before do
|
|
|
|
find('.note').hover
|
2017-06-07 14:33:50 -04:00
|
|
|
|
2017-04-12 11:02:53 -04:00
|
|
|
find('.js-note-edit').click
|
|
|
|
end
|
|
|
|
|
2019-09-18 10:02:45 -04:00
|
|
|
# TODO: https://gitlab.com/gitlab-org/gitlab-foss/issues/48034
|
2018-06-21 08:22:40 -04:00
|
|
|
xit 'shows the delete link' do
|
2017-04-12 11:02:53 -04:00
|
|
|
page.within('.note-attachment') do
|
|
|
|
is_expected.to have_css('.js-note-attachment-delete')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-09-18 10:02:45 -04:00
|
|
|
# TODO: https://gitlab.com/gitlab-org/gitlab-foss/issues/48034
|
2018-06-21 08:22:40 -04:00
|
|
|
xit 'removes the attachment div and resets the edit form' do
|
2017-09-27 08:46:48 -04:00
|
|
|
accept_confirm { find('.js-note-attachment-delete').click }
|
2017-04-12 11:02:53 -04:00
|
|
|
is_expected.not_to have_css('.note-attachment')
|
|
|
|
is_expected.not_to have_css('.current-note-edit-form')
|
2017-05-17 14:25:13 -04:00
|
|
|
wait_for_requests
|
2017-04-12 11:02:53 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|