BigW Consortium Gitlab

Fixed reportable_note_shared_example for the reportable_note/snippets_spec

parent 0bfe78d7
...@@ -22,12 +22,13 @@ describe 'Reportable note on snippets', :feature, :js do ...@@ -22,12 +22,13 @@ describe 'Reportable note on snippets', :feature, :js do
describe 'on personal snippet' do describe 'on personal snippet' do
let(:snippet) { create(:personal_snippet, :public, author: user) } let(:snippet) { create(:personal_snippet, :public, author: user) }
let!(:note) { create(:note_on_personal_snippet, noteable: snippet, author: user) } let!(:note) { create(:note_on_personal_snippet, noteable: snippet) }
let!(:owners_note) { create(:note_on_personal_snippet, noteable: snippet, author: user) }
before do before do
visit snippet_path(snippet) visit snippet_path(snippet)
end end
it_behaves_like 'reportable note' it_behaves_like 'reportable note', true
end end
end end
require 'spec_helper' require 'spec_helper'
shared_examples 'reportable note' do shared_examples 'reportable note' do |is_a_personal_snippet|
include NotesHelper include NotesHelper
let(:comment) { find("##{ActionView::RecordIdentifier.dom_id(note)}") } let(:comment) { find("##{ActionView::RecordIdentifier.dom_id(note)}") }
...@@ -11,26 +11,47 @@ shared_examples 'reportable note' do ...@@ -11,26 +11,47 @@ shared_examples 'reportable note' do
expect(comment).to have_selector(more_actions_selector) expect(comment).to have_selector(more_actions_selector)
end end
it 'dropdown has Edit, Report and Delete links' do if is_a_personal_snippet
it 'dropdown has Report link on other users comment' do
dropdown = comment.find(more_actions_selector) dropdown = comment.find(more_actions_selector)
open_dropdown(dropdown)
dropdown.click expect(dropdown).to have_link('Report as abuse', href: abuse_report_path)
dropdown.find('.dropdown-menu li', match: :first) end
it 'dropdown has Edit and Delete links on the owners comment' do
find('#notes-list .note', match: :first)
other_comment = all('#notes-list .note').last
dropdown = other_comment.find(more_actions_selector)
open_dropdown(dropdown)
expect(dropdown).to have_button('Edit comment')
expect(dropdown).to have_link('Delete comment', href: note_url(owners_note, project))
end
else
it 'dropdown has Edit, Report and Delete links' do
dropdown = comment.find(more_actions_selector)
open_dropdown(dropdown)
expect(dropdown).to have_button('Edit comment') expect(dropdown).to have_button('Edit comment')
expect(dropdown).to have_link('Report as abuse', href: abuse_report_path) expect(dropdown).to have_link('Report as abuse', href: abuse_report_path)
expect(dropdown).to have_link('Delete comment', href: note_url(note, project)) expect(dropdown).to have_link('Delete comment', href: note_url(note, project))
end end
end
it 'Report button links to a report page' do it 'Report button links to a report page' do
dropdown = comment.find(more_actions_selector) dropdown = comment.find(more_actions_selector)
open_dropdown(dropdown)
dropdown.click
dropdown.find('.dropdown-menu li', match: :first)
dropdown.click_link('Report as abuse') dropdown.click_link('Report as abuse')
expect(find('#user_name')['value']).to match(note.author.username) expect(find('#user_name')['value']).to match(note.author.username)
expect(find('#abuse_report_message')['value']).to match(noteable_note_url(note)) expect(find('#abuse_report_message')['value']).to match(noteable_note_url(note))
end end
def open_dropdown(dropdown)
dropdown.click
dropdown.find('.dropdown-menu li', match: :first)
end
end end
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