2015-09-25 12:07:36 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2015-12-23 02:04:40 +05:30
|
|
|
describe DroneCiService, models: true do
|
2015-09-25 12:07:36 +05:30
|
|
|
describe 'associations' do
|
|
|
|
it { is_expected.to belong_to(:project) }
|
|
|
|
it { is_expected.to have_one(:service_hook) }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'validations' do
|
|
|
|
context 'active' do
|
2016-06-02 11:05:42 +05:30
|
|
|
before { subject.active = true }
|
2015-09-25 12:07:36 +05:30
|
|
|
|
|
|
|
it { is_expected.to validate_presence_of(:token) }
|
|
|
|
it { is_expected.to validate_presence_of(:drone_url) }
|
2016-06-02 11:05:42 +05:30
|
|
|
it_behaves_like 'issue tracker service URL attribute', :drone_url
|
2015-09-25 12:07:36 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
context 'inactive' do
|
2016-06-02 11:05:42 +05:30
|
|
|
before { subject.active = false }
|
2015-09-25 12:07:36 +05:30
|
|
|
|
|
|
|
it { is_expected.not_to validate_presence_of(:token) }
|
|
|
|
it { is_expected.not_to validate_presence_of(:drone_url) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
shared_context :drone_ci_service do
|
|
|
|
let(:drone) { DroneCiService.new }
|
|
|
|
let(:project) { create(:project, name: 'project') }
|
|
|
|
let(:path) { "#{project.namespace.path}/#{project.path}" }
|
|
|
|
let(:drone_url) { 'http://drone.example.com' }
|
|
|
|
let(:sha) { '2ab7834c' }
|
|
|
|
let(:branch) { 'dev' }
|
|
|
|
let(:token) { 'secret' }
|
|
|
|
let(:iid) { rand(1..9999) }
|
|
|
|
|
|
|
|
before(:each) do
|
|
|
|
allow(drone).to receive_messages(
|
|
|
|
project_id: project.id,
|
|
|
|
project: project,
|
|
|
|
active: true,
|
|
|
|
drone_url: drone_url,
|
|
|
|
token: token
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "service page/path methods" do
|
|
|
|
include_context :drone_ci_service
|
|
|
|
|
|
|
|
# URL's
|
|
|
|
let(:commit_page) { "#{drone_url}/gitlab/#{path}/redirect/commits/#{sha}?branch=#{branch}" }
|
|
|
|
let(:merge_request_page) { "#{drone_url}/gitlab/#{path}/redirect/pulls/#{iid}" }
|
|
|
|
let(:commit_status_path) { "#{drone_url}/gitlab/#{path}/commits/#{sha}?branch=#{branch}&access_token=#{token}" }
|
|
|
|
let(:merge_request_status_path) { "#{drone_url}/gitlab/#{path}/pulls/#{iid}?access_token=#{token}" }
|
|
|
|
|
|
|
|
it { expect(drone.build_page(sha, branch)).to eq(commit_page) }
|
|
|
|
it { expect(drone.commit_page(sha, branch)).to eq(commit_page) }
|
|
|
|
it { expect(drone.merge_request_page(iid, sha, branch)).to eq(merge_request_page) }
|
|
|
|
it { expect(drone.commit_status_path(sha, branch)).to eq(commit_status_path) }
|
|
|
|
it { expect(drone.merge_request_status_path(iid, sha, branch)).to eq(merge_request_status_path) }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "execute" do
|
|
|
|
include_context :drone_ci_service
|
|
|
|
|
|
|
|
let(:user) { create(:user, username: 'username') }
|
2016-09-13 17:45:13 +05:30
|
|
|
let(:push_sample_data) do
|
|
|
|
Gitlab::DataBuilder::Push.build_sample(project, user)
|
|
|
|
end
|
2015-09-25 12:07:36 +05:30
|
|
|
|
|
|
|
it do
|
|
|
|
service_hook = double
|
|
|
|
expect(service_hook).to receive(:execute)
|
|
|
|
expect(drone).to receive(:service_hook).and_return(service_hook)
|
|
|
|
|
|
|
|
drone.execute(push_sample_data)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|