2015-04-26 12:48:37 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
describe "User Feed" do
|
2015-04-26 12:48:37 +05:30
|
|
|
describe "GET /" do
|
|
|
|
let!(:user) { create(:user) }
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
context 'user atom feed via personal access token' do
|
2016-09-13 17:45:13 +05:30
|
|
|
it "renders user atom feed" do
|
2018-03-17 18:26:18 +05:30
|
|
|
personal_access_token = create(:personal_access_token, user: user)
|
|
|
|
|
|
|
|
visit user_path(user, :atom, private_token: personal_access_token.token)
|
2015-04-26 12:48:37 +05:30
|
|
|
expect(body).to have_selector('feed title')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
context 'user atom feed via feed token' do
|
2017-09-10 17:25:29 +05:30
|
|
|
it "renders user atom feed" do
|
2018-11-08 19:23:39 +05:30
|
|
|
visit user_path(user, :atom, feed_token: user.feed_token)
|
2017-09-10 17:25:29 +05:30
|
|
|
expect(body).to have_selector('feed title')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-04-26 12:48:37 +05:30
|
|
|
context 'feed content' do
|
2017-09-10 17:25:29 +05:30
|
|
|
let(:project) { create(:project, :repository) }
|
2015-04-26 12:48:37 +05:30
|
|
|
let(:issue) do
|
2015-09-11 14:41:01 +05:30
|
|
|
create(:issue,
|
|
|
|
project: project,
|
|
|
|
author: user,
|
|
|
|
description: "Houston, we have a bug!\n\n***\n\nI guess.")
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
let(:note) do
|
2015-09-11 14:41:01 +05:30
|
|
|
create(:note,
|
|
|
|
noteable: issue,
|
|
|
|
author: user,
|
|
|
|
note: 'Bug confirmed :+1:',
|
|
|
|
project: project)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
let(:merge_request) do
|
|
|
|
create(:merge_request,
|
2015-09-11 14:41:01 +05:30
|
|
|
title: 'Fix bug',
|
|
|
|
author: user,
|
|
|
|
source_project: project,
|
|
|
|
target_project: project,
|
2015-04-26 12:48:37 +05:30
|
|
|
description: "Here is the fix: ![an image](image.png)")
|
|
|
|
end
|
2017-09-10 17:25:29 +05:30
|
|
|
let(:push_event) { create(:push_event, project: project, author: user) }
|
|
|
|
let!(:push_event_payload) { create(:push_event_payload, event: push_event) }
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
before do
|
2018-11-18 11:00:15 +05:30
|
|
|
project.add_maintainer(user)
|
2015-04-26 12:48:37 +05:30
|
|
|
issue_event(issue, user)
|
|
|
|
note_event(note, user)
|
|
|
|
merge_request_event(merge_request, user)
|
2018-11-08 19:23:39 +05:30
|
|
|
visit user_path(user, :atom, feed_token: user.feed_token)
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it 'has issue opened event' do
|
2015-04-26 12:48:37 +05:30
|
|
|
expect(body).to have_content("#{safe_name} opened issue ##{issue.iid}")
|
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it 'has issue comment event' do
|
2017-09-10 17:25:29 +05:30
|
|
|
expect(body)
|
|
|
|
.to have_content("#{safe_name} commented on issue ##{issue.iid}")
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it 'has XHTML summaries in issue descriptions' do
|
2018-03-17 18:26:18 +05:30
|
|
|
expect(body).to match %r{<hr ?/>}
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it 'has XHTML summaries in notes' do
|
2017-08-17 22:00:37 +05:30
|
|
|
expect(body).to match /Bug confirmed <gl-emoji[^>]*>/
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it 'has XHTML summaries in merge request descriptions' do
|
2018-03-17 18:26:18 +05:30
|
|
|
expect(body).to match %r{Here is the fix: <a[^>]*><img[^>]*/></a>}
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
2017-09-10 17:25:29 +05:30
|
|
|
|
|
|
|
it 'has push event commit ID' do
|
|
|
|
expect(body).to have_content(Commit.truncate_sha(push_event.commit_id))
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def issue_event(issue, user)
|
|
|
|
EventCreateService.new.open_issue(issue, user)
|
|
|
|
end
|
|
|
|
|
|
|
|
def note_event(note, user)
|
|
|
|
EventCreateService.new.leave_note(note, user)
|
|
|
|
end
|
|
|
|
|
|
|
|
def merge_request_event(request, user)
|
|
|
|
EventCreateService.new.open_mr(request, user)
|
|
|
|
end
|
|
|
|
|
|
|
|
def safe_name
|
|
|
|
html_escape(user.name)
|
|
|
|
end
|
|
|
|
end
|