debian-mirror-gitlab/spec/workers/integrations/irker_worker_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

114 lines
3.1 KiB
Ruby
Raw Normal View History

2020-06-23 00:09:42 +05:30
# frozen_string_literal: true
require 'spec_helper'
2023-05-27 22:25:52 +05:30
RSpec.describe Integrations::IrkerWorker, '#perform', feature_category: :integrations do
2020-06-23 00:09:42 +05:30
let_it_be(:project) { create(:project, :repository) }
let_it_be(:user) { create(:user) }
let_it_be(:push_data) { HashWithIndifferentAccess.new(Gitlab::DataBuilder::Push.build_sample(project, user)) }
let_it_be(:channels) { ['irc://test.net/#test'] }
let_it_be(:server_settings) do
{
server_host: 'localhost',
server_port: 6659
}
end
let_it_be(:arguments) do
[
project.id,
channels,
false,
push_data,
2022-02-05 19:09:49 +05:30
HashWithIndifferentAccess.new(server_settings)
2020-06-23 00:09:42 +05:30
]
end
2022-07-23 23:45:48 +05:30
let(:tcp_socket) { instance_double(TCPSocket) }
2020-06-23 00:09:42 +05:30
subject(:worker) { described_class.new }
before do
allow(TCPSocket).to receive(:new).and_return(tcp_socket)
allow(tcp_socket).to receive(:puts).and_return(true)
allow(tcp_socket).to receive(:close).and_return(true)
end
2022-07-23 23:45:48 +05:30
context 'when local requests are not allowed' do
2022-02-05 19:09:49 +05:30
before do
allow(Gitlab::CurrentSettings).to receive(:allow_local_requests_from_web_hooks_and_services?).and_return(false)
end
it { expect(worker.perform(*arguments)).to be_falsey }
end
2022-07-23 23:45:48 +05:30
context 'when connection fails' do
2020-06-23 00:09:42 +05:30
before do
allow(TCPSocket).to receive(:new).and_raise(Errno::ECONNREFUSED.new('test'))
end
it { expect(subject.perform(*arguments)).to be_falsey }
end
2022-07-23 23:45:48 +05:30
context 'when connection successful' do
2022-02-05 19:09:49 +05:30
before do
allow(Gitlab::CurrentSettings)
.to receive(:allow_local_requests_from_web_hooks_and_services?).and_return(true)
end
2020-06-23 00:09:42 +05:30
it { expect(subject.perform(*arguments)).to be_truthy }
2022-07-23 23:45:48 +05:30
context 'with new branch' do
2020-06-23 00:09:42 +05:30
it 'sends a correct message with branches url' do
branches_url = Gitlab::Routing.url_helpers
.project_branches_url(project)
push_data['before'] = '0000000000000000000000000000000000000000'
message = "has created a new branch master: #{branches_url}"
expect(tcp_socket).to receive(:puts).with(wrap_message(message))
subject.perform(*arguments)
end
end
2022-07-23 23:45:48 +05:30
context 'with deleted branch' do
2020-06-23 00:09:42 +05:30
it 'sends a correct message' do
push_data['after'] = '0000000000000000000000000000000000000000'
message = "has deleted the branch master"
expect(tcp_socket).to receive(:puts).with(wrap_message(message))
subject.perform(*arguments)
end
end
2022-07-23 23:45:48 +05:30
context 'with new commits to existing branch' do
2020-06-23 00:09:42 +05:30
it 'sends a correct message with a compare url' do
2023-06-20 00:43:36 +05:30
compare_url = Gitlab::Routing.url_helpers.project_compare_url(
project,
from: Commit.truncate_sha(push_data[:before]),
to: Commit.truncate_sha(push_data[:after])
)
2020-06-23 00:09:42 +05:30
message = "pushed #{push_data['total_commits_count']} " \
"new commits to master: #{compare_url}"
expect(tcp_socket).to receive(:puts).with(wrap_message(message))
subject.perform(*arguments)
end
end
end
def wrap_message(text)
2023-07-09 08:55:56 +05:30
message = "[#{project.name}] #{push_data['user_name']} #{text}"
2020-06-23 00:09:42 +05:30
to_send = { to: channels, privmsg: message }
Gitlab::Json.dump(to_send)
end
end