2015-04-26 12:48:37 +05:30
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: services
|
|
|
|
#
|
|
|
|
# id :integer not null, primary key
|
|
|
|
# type :string(255)
|
|
|
|
# title :string(255)
|
2015-09-11 14:41:01 +05:30
|
|
|
# project_id :integer
|
2015-04-26 12:48:37 +05:30
|
|
|
# created_at :datetime
|
|
|
|
# updated_at :datetime
|
|
|
|
# active :boolean default(FALSE), not null
|
|
|
|
# properties :text
|
2015-09-11 14:41:01 +05:30
|
|
|
# template :boolean default(FALSE)
|
2015-04-26 12:48:37 +05:30
|
|
|
# push_events :boolean default(TRUE)
|
|
|
|
# issues_events :boolean default(TRUE)
|
|
|
|
# merge_requests_events :boolean default(TRUE)
|
|
|
|
# tag_push_events :boolean default(TRUE)
|
2015-09-11 14:41:01 +05:30
|
|
|
# note_events :boolean default(TRUE), not null
|
2015-04-26 12:48:37 +05:30
|
|
|
#
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2015-12-23 02:04:40 +05:30
|
|
|
describe HipchatService, models: true do
|
2015-04-26 12:48:37 +05:30
|
|
|
describe "Associations" do
|
|
|
|
it { is_expected.to belong_to :project }
|
|
|
|
it { is_expected.to have_one :service_hook }
|
|
|
|
end
|
|
|
|
|
2016-06-02 11:05:42 +05:30
|
|
|
describe 'Validations' do
|
|
|
|
context 'when service is active' do
|
|
|
|
before { subject.active = true }
|
|
|
|
|
|
|
|
it { is_expected.to validate_presence_of(:token) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when service is inactive' do
|
|
|
|
before { subject.active = false }
|
|
|
|
|
|
|
|
it { is_expected.not_to validate_presence_of(:token) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-04-26 12:48:37 +05:30
|
|
|
describe "Execute" do
|
|
|
|
let(:hipchat) { HipchatService.new }
|
|
|
|
let(:user) { create(:user, username: 'username') }
|
|
|
|
let(:project) { create(:project, name: 'project') }
|
|
|
|
let(:api_url) { 'https://hipchat.example.com/v2/room/123456/notification?auth_token=verySecret' }
|
|
|
|
let(:project_name) { project.name_with_namespace.gsub(/\s/, '') }
|
2015-09-11 14:41:01 +05:30
|
|
|
let(:token) { 'verySecret' }
|
|
|
|
let(:server_url) { 'https://hipchat.example.com'}
|
2016-09-13 17:45:13 +05:30
|
|
|
let(:push_sample_data) do
|
|
|
|
Gitlab::DataBuilder::Push.build_sample(project, user)
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
before(:each) do
|
2015-09-11 14:41:01 +05:30
|
|
|
allow(hipchat).to receive_messages(
|
2015-04-26 12:48:37 +05:30
|
|
|
project_id: project.id,
|
|
|
|
project: project,
|
|
|
|
room: 123456,
|
2015-09-11 14:41:01 +05:30
|
|
|
server: server_url,
|
|
|
|
token: token
|
2015-04-26 12:48:37 +05:30
|
|
|
)
|
|
|
|
WebMock.stub_request(:post, api_url)
|
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it 'tests and return errors' do
|
2015-09-11 14:41:01 +05:30
|
|
|
allow(hipchat).to receive(:execute).and_raise(StandardError, 'no such room')
|
|
|
|
result = hipchat.test(push_sample_data)
|
|
|
|
|
|
|
|
expect(result[:success]).to be_falsey
|
|
|
|
expect(result[:result].to_s).to eq('no such room')
|
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it 'uses v1 if version is provided' do
|
2015-09-11 14:41:01 +05:30
|
|
|
allow(hipchat).to receive(:api_version).and_return('v1')
|
2015-12-23 02:04:40 +05:30
|
|
|
expect(HipChat::Client).to receive(:new).with(
|
|
|
|
token,
|
|
|
|
api_version: 'v1',
|
|
|
|
server_url: server_url
|
|
|
|
).and_return(double(:hipchat_service).as_null_object)
|
2015-09-11 14:41:01 +05:30
|
|
|
hipchat.execute(push_sample_data)
|
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it 'uses v2 as the version when nothing is provided' do
|
2015-09-11 14:41:01 +05:30
|
|
|
allow(hipchat).to receive(:api_version).and_return('')
|
2015-12-23 02:04:40 +05:30
|
|
|
expect(HipChat::Client).to receive(:new).with(
|
|
|
|
token,
|
|
|
|
api_version: 'v2',
|
|
|
|
server_url: server_url
|
|
|
|
).and_return(double(:hipchat_service).as_null_object)
|
2015-09-11 14:41:01 +05:30
|
|
|
hipchat.execute(push_sample_data)
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2015-09-11 14:41:01 +05:30
|
|
|
context 'push events' do
|
2016-09-13 17:45:13 +05:30
|
|
|
it "calls Hipchat API for push events" do
|
2015-04-26 12:48:37 +05:30
|
|
|
hipchat.execute(push_sample_data)
|
|
|
|
|
|
|
|
expect(WebMock).to have_requested(:post, api_url).once
|
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "creates a push message" do
|
2015-04-26 12:48:37 +05:30
|
|
|
message = hipchat.send(:create_push_message, push_sample_data)
|
|
|
|
|
2015-10-24 18:46:33 +05:30
|
|
|
push_sample_data[:object_attributes]
|
2015-04-26 12:48:37 +05:30
|
|
|
branch = push_sample_data[:ref].gsub('refs/heads/', '')
|
|
|
|
expect(message).to include("#{user.name} pushed to branch " \
|
|
|
|
"<a href=\"#{project.web_url}/commits/#{branch}\">#{branch}</a> of " \
|
|
|
|
"<a href=\"#{project.web_url}\">#{project_name}</a>")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'tag_push events' do
|
2016-09-13 17:45:13 +05:30
|
|
|
let(:push_sample_data) do
|
|
|
|
Gitlab::DataBuilder::Push.build(
|
|
|
|
project,
|
|
|
|
user,
|
|
|
|
Gitlab::Git::BLANK_SHA,
|
|
|
|
'1' * 40,
|
|
|
|
'refs/tags/test',
|
|
|
|
[])
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "calls Hipchat API for tag push events" do
|
2015-04-26 12:48:37 +05:30
|
|
|
hipchat.execute(push_sample_data)
|
|
|
|
|
|
|
|
expect(WebMock).to have_requested(:post, api_url).once
|
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "creates a tag push message" do
|
2015-04-26 12:48:37 +05:30
|
|
|
message = hipchat.send(:create_push_message, push_sample_data)
|
|
|
|
|
2015-10-24 18:46:33 +05:30
|
|
|
push_sample_data[:object_attributes]
|
2015-04-26 12:48:37 +05:30
|
|
|
expect(message).to eq("#{user.name} pushed new tag " \
|
|
|
|
"<a href=\"#{project.web_url}/commits/test\">test</a> to " \
|
|
|
|
"<a href=\"#{project.web_url}\">#{project_name}</a>\n")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'issue events' do
|
|
|
|
let(:issue) { create(:issue, title: 'Awesome issue', description: 'please fix') }
|
|
|
|
let(:issue_service) { Issues::CreateService.new(project, user) }
|
|
|
|
let(:issues_sample_data) { issue_service.hook_data(issue, 'open') }
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "calls Hipchat API for issue events" do
|
2015-04-26 12:48:37 +05:30
|
|
|
hipchat.execute(issues_sample_data)
|
|
|
|
|
|
|
|
expect(WebMock).to have_requested(:post, api_url).once
|
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "creates an issue message" do
|
2015-04-26 12:48:37 +05:30
|
|
|
message = hipchat.send(:create_issue_message, issues_sample_data)
|
|
|
|
|
|
|
|
obj_attr = issues_sample_data[:object_attributes]
|
|
|
|
expect(message).to eq("#{user.name} opened " \
|
|
|
|
"<a href=\"#{obj_attr[:url]}\">issue ##{obj_attr["iid"]}</a> in " \
|
|
|
|
"<a href=\"#{project.web_url}\">#{project_name}</a>: " \
|
|
|
|
"<b>Awesome issue</b>" \
|
|
|
|
"<pre>please fix</pre>")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'merge request events' do
|
|
|
|
let(:merge_request) { create(:merge_request, description: 'please fix', title: 'Awesome merge request', target_project: project, source_project: project) }
|
|
|
|
let(:merge_service) { MergeRequests::CreateService.new(project, user) }
|
|
|
|
let(:merge_sample_data) { merge_service.hook_data(merge_request, 'open') }
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "calls Hipchat API for merge requests events" do
|
2015-04-26 12:48:37 +05:30
|
|
|
hipchat.execute(merge_sample_data)
|
|
|
|
|
|
|
|
expect(WebMock).to have_requested(:post, api_url).once
|
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "creates a merge request message" do
|
2015-04-26 12:48:37 +05:30
|
|
|
message = hipchat.send(:create_merge_request_message,
|
|
|
|
merge_sample_data)
|
|
|
|
|
|
|
|
obj_attr = merge_sample_data[:object_attributes]
|
|
|
|
expect(message).to eq("#{user.name} opened " \
|
2016-06-02 11:05:42 +05:30
|
|
|
"<a href=\"#{obj_attr[:url]}\">merge request !#{obj_attr["iid"]}</a> in " \
|
2015-04-26 12:48:37 +05:30
|
|
|
"<a href=\"#{project.web_url}\">#{project_name}</a>: " \
|
|
|
|
"<b>Awesome merge request</b>" \
|
|
|
|
"<pre>please fix</pre>")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "Note events" do
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:project) { create(:project, creator_id: user.id) }
|
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
context 'when commit comment event triggered' do
|
|
|
|
let(:commit_note) do
|
|
|
|
create(:note_on_commit, author: user, project: project,
|
|
|
|
commit_id: project.repository.commit.id,
|
|
|
|
note: 'a comment on a commit')
|
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "calls Hipchat API for commit comment events" do
|
|
|
|
data = Gitlab::DataBuilder::Note.build(commit_note, user)
|
2016-06-16 23:09:34 +05:30
|
|
|
hipchat.execute(data)
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
expect(WebMock).to have_requested(:post, api_url).once
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
message = hipchat.send(:create_message, data)
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
obj_attr = data[:object_attributes]
|
|
|
|
commit_id = Commit.truncate_sha(data[:commit][:id])
|
|
|
|
title = hipchat.send(:format_title, data[:commit][:message])
|
|
|
|
|
|
|
|
expect(message).to eq("#{user.name} commented on " \
|
|
|
|
"<a href=\"#{obj_attr[:url]}\">commit #{commit_id}</a> in " \
|
|
|
|
"<a href=\"#{project.web_url}\">#{project_name}</a>: " \
|
|
|
|
"#{title}" \
|
|
|
|
"<pre>a comment on a commit</pre>")
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
context 'when merge request comment event triggered' do
|
|
|
|
let(:merge_request) do
|
|
|
|
create(:merge_request, source_project: project,
|
|
|
|
target_project: project)
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
let(:merge_request_note) do
|
|
|
|
create(:note_on_merge_request, noteable: merge_request,
|
|
|
|
project: project,
|
|
|
|
note: "merge request note")
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "calls Hipchat API for merge request comment events" do
|
|
|
|
data = Gitlab::DataBuilder::Note.build(merge_request_note, user)
|
2016-06-16 23:09:34 +05:30
|
|
|
hipchat.execute(data)
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
expect(WebMock).to have_requested(:post, api_url).once
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
message = hipchat.send(:create_message, data)
|
|
|
|
|
|
|
|
obj_attr = data[:object_attributes]
|
|
|
|
merge_id = data[:merge_request]['iid']
|
|
|
|
title = data[:merge_request]['title']
|
|
|
|
|
|
|
|
expect(message).to eq("#{user.name} commented on " \
|
|
|
|
"<a href=\"#{obj_attr[:url]}\">merge request !#{merge_id}</a> in " \
|
|
|
|
"<a href=\"#{project.web_url}\">#{project_name}</a>: " \
|
|
|
|
"<b>#{title}</b>" \
|
|
|
|
"<pre>merge request note</pre>")
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
context 'when issue comment event triggered' do
|
|
|
|
let(:issue) { create(:issue, project: project) }
|
|
|
|
let(:issue_note) do
|
|
|
|
create(:note_on_issue, noteable: issue, project: project,
|
|
|
|
note: "issue note")
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "calls Hipchat API for issue comment events" do
|
|
|
|
data = Gitlab::DataBuilder::Note.build(issue_note, user)
|
2016-06-16 23:09:34 +05:30
|
|
|
hipchat.execute(data)
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
message = hipchat.send(:create_message, data)
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
obj_attr = data[:object_attributes]
|
|
|
|
issue_id = data[:issue]['iid']
|
|
|
|
title = data[:issue]['title']
|
|
|
|
|
|
|
|
expect(message).to eq("#{user.name} commented on " \
|
|
|
|
"<a href=\"#{obj_attr[:url]}\">issue ##{issue_id}</a> in " \
|
|
|
|
"<a href=\"#{project.web_url}\">#{project_name}</a>: " \
|
|
|
|
"<b>#{title}</b>" \
|
|
|
|
"<pre>issue note</pre>")
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
context 'when snippet comment event triggered' do
|
|
|
|
let(:snippet) { create(:project_snippet, project: project) }
|
|
|
|
let(:snippet_note) do
|
|
|
|
create(:note_on_project_snippet, noteable: snippet,
|
|
|
|
project: project,
|
|
|
|
note: "snippet note")
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "calls Hipchat API for snippet comment events" do
|
|
|
|
data = Gitlab::DataBuilder::Note.build(snippet_note, user)
|
2016-06-16 23:09:34 +05:30
|
|
|
hipchat.execute(data)
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
expect(WebMock).to have_requested(:post, api_url).once
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
message = hipchat.send(:create_message, data)
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
obj_attr = data[:object_attributes]
|
|
|
|
snippet_id = data[:snippet]['id']
|
|
|
|
title = data[:snippet]['title']
|
|
|
|
|
|
|
|
expect(message).to eq("#{user.name} commented on " \
|
|
|
|
"<a href=\"#{obj_attr[:url]}\">snippet ##{snippet_id}</a> in " \
|
|
|
|
"<a href=\"#{project.web_url}\">#{project_name}</a>: " \
|
|
|
|
"<b>#{title}</b>" \
|
|
|
|
"<pre>snippet note</pre>")
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|
2015-09-11 14:41:01 +05:30
|
|
|
|
2015-12-23 02:04:40 +05:30
|
|
|
context 'build events' do
|
2016-09-13 17:45:13 +05:30
|
|
|
let(:pipeline) { create(:ci_empty_pipeline) }
|
|
|
|
let(:build) { create(:ci_build, pipeline: pipeline) }
|
|
|
|
let(:data) { Gitlab::DataBuilder::Build.build(build) }
|
2015-12-23 02:04:40 +05:30
|
|
|
|
|
|
|
context 'for failed' do
|
|
|
|
before { build.drop }
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "calls Hipchat API" do
|
2015-12-23 02:04:40 +05:30
|
|
|
hipchat.execute(data)
|
|
|
|
|
|
|
|
expect(WebMock).to have_requested(:post, api_url).once
|
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "creates a build message" do
|
2015-12-23 02:04:40 +05:30
|
|
|
message = hipchat.send(:create_build_message, data)
|
|
|
|
|
|
|
|
project_url = project.web_url
|
|
|
|
project_name = project.name_with_namespace.gsub(/\s/, '')
|
|
|
|
sha = data[:sha]
|
|
|
|
ref = data[:ref]
|
|
|
|
ref_type = data[:tag] ? 'tag' : 'branch'
|
|
|
|
duration = data[:commit][:duration]
|
|
|
|
|
|
|
|
expect(message).to eq("<a href=\"#{project_url}\">#{project_name}</a>: " \
|
|
|
|
"Commit <a href=\"#{project_url}/commit/#{sha}/builds\">#{Commit.truncate_sha(sha)}</a> " \
|
|
|
|
"of <a href=\"#{project_url}/commits/#{ref}\">#{ref}</a> #{ref_type} " \
|
|
|
|
"by #{data[:commit][:author_name]} failed in #{duration} second(s)")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'for succeeded' do
|
|
|
|
before do
|
|
|
|
build.success
|
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "calls Hipchat API" do
|
2015-12-23 02:04:40 +05:30
|
|
|
hipchat.notify_only_broken_builds = false
|
|
|
|
hipchat.execute(data)
|
|
|
|
expect(WebMock).to have_requested(:post, api_url).once
|
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "notifies only broken" do
|
2015-12-23 02:04:40 +05:30
|
|
|
hipchat.notify_only_broken_builds = true
|
|
|
|
hipchat.execute(data)
|
2016-06-16 23:09:34 +05:30
|
|
|
expect(WebMock).not_to have_requested(:post, api_url).once
|
2015-12-23 02:04:40 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-09-11 14:41:01 +05:30
|
|
|
context "#message_options" do
|
2016-09-13 17:45:13 +05:30
|
|
|
it "is set to the defaults" do
|
|
|
|
expect(hipchat.__send__(:message_options)).to eq({ notify: false, color: 'yellow' })
|
2015-09-11 14:41:01 +05:30
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "sets notify to true" do
|
2015-09-11 14:41:01 +05:30
|
|
|
allow(hipchat).to receive(:notify).and_return('1')
|
2016-09-13 17:45:13 +05:30
|
|
|
|
|
|
|
expect(hipchat.__send__(:message_options)).to eq({ notify: true, color: 'yellow' })
|
2015-09-11 14:41:01 +05:30
|
|
|
end
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
it "sets the color" do
|
2015-09-11 14:41:01 +05:30
|
|
|
allow(hipchat).to receive(:color).and_return('red')
|
2016-09-13 17:45:13 +05:30
|
|
|
|
|
|
|
expect(hipchat.__send__(:message_options)).to eq({ notify: false, color: 'red' })
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a successful build' do
|
|
|
|
it 'uses the green color' do
|
|
|
|
build_data = { object_kind: 'build', commit: { status: 'success' } }
|
|
|
|
|
|
|
|
expect(hipchat.__send__(:message_options, build_data)).to eq({ notify: false, color: 'green' })
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a failed build' do
|
|
|
|
it 'uses the red color' do
|
|
|
|
build_data = { object_kind: 'build', commit: { status: 'failed' } }
|
|
|
|
|
|
|
|
expect(hipchat.__send__(:message_options, build_data)).to eq({ notify: false, color: 'red' })
|
|
|
|
end
|
2015-09-11 14:41:01 +05:30
|
|
|
end
|
|
|
|
end
|
2015-04-26 12:48:37 +05:30
|
|
|
end
|
|
|
|
end
|