2016-06-14 07:51:12 -04:00
|
|
|
require 'spec_helper'
|
|
|
|
|
2017-07-10 10:24:02 -04:00
|
|
|
describe Deployment do
|
2016-06-14 07:51:12 -04:00
|
|
|
subject { build(:deployment) }
|
|
|
|
|
|
|
|
it { is_expected.to belong_to(:project) }
|
|
|
|
it { is_expected.to belong_to(:environment) }
|
|
|
|
it { is_expected.to belong_to(:user) }
|
|
|
|
it { is_expected.to belong_to(:deployable) }
|
|
|
|
|
|
|
|
it { is_expected.to delegate_method(:name).to(:environment).with_prefix }
|
|
|
|
it { is_expected.to delegate_method(:commit).to(:project) }
|
|
|
|
it { is_expected.to delegate_method(:commit_title).to(:commit).as(:try) }
|
2016-07-16 19:48:51 -04:00
|
|
|
it { is_expected.to delegate_method(:manual_actions).to(:deployable).as(:try) }
|
2016-06-14 07:51:12 -04:00
|
|
|
|
|
|
|
it { is_expected.to validate_presence_of(:ref) }
|
|
|
|
it { is_expected.to validate_presence_of(:sha) }
|
2016-08-03 07:37:39 -04:00
|
|
|
|
2017-05-23 04:43:55 -04:00
|
|
|
describe 'after_create callbacks' do
|
2017-06-01 10:59:18 -04:00
|
|
|
let(:environment) { create(:environment) }
|
|
|
|
let(:store) { Gitlab::EtagCaching::Store.new }
|
2017-05-23 04:43:55 -04:00
|
|
|
|
2017-06-01 10:59:18 -04:00
|
|
|
it 'invalidates the environment etag cache' do
|
|
|
|
old_value = store.get(environment.etag_cache_key)
|
|
|
|
|
|
|
|
create(:deployment, environment: environment)
|
|
|
|
|
|
|
|
expect(store.get(environment.etag_cache_key)).not_to eq(old_value)
|
2017-05-23 04:43:55 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-08-09 09:11:14 -04:00
|
|
|
describe '#includes_commit?' do
|
2017-06-16 14:48:34 -04:00
|
|
|
let(:project) { create(:project, :repository) }
|
2016-08-03 07:37:39 -04:00
|
|
|
let(:environment) { create(:environment, project: project) }
|
|
|
|
let(:deployment) do
|
2016-08-09 09:11:14 -04:00
|
|
|
create(:deployment, environment: environment, sha: project.commit.id)
|
2016-08-03 07:37:39 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there is no project commit' do
|
|
|
|
it 'returns false' do
|
2016-08-09 09:11:14 -04:00
|
|
|
commit = project.commit('feature')
|
|
|
|
|
|
|
|
expect(deployment.includes_commit?(commit)).to be false
|
2016-08-03 07:37:39 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when they share the same tree branch' do
|
|
|
|
it 'returns true' do
|
2016-08-09 09:11:14 -04:00
|
|
|
commit = project.commit
|
|
|
|
|
|
|
|
expect(deployment.includes_commit?(commit)).to be true
|
2016-08-03 07:37:39 -04:00
|
|
|
end
|
|
|
|
end
|
2016-10-13 09:19:52 -04:00
|
|
|
|
|
|
|
context 'when the SHA for the deployment does not exist in the repo' do
|
|
|
|
it 'returns false' do
|
|
|
|
deployment.update(sha: Gitlab::Git::BLANK_SHA)
|
|
|
|
commit = project.commit
|
|
|
|
|
|
|
|
expect(deployment.includes_commit?(commit)).to be false
|
|
|
|
end
|
|
|
|
end
|
2016-08-03 07:37:39 -04:00
|
|
|
end
|
2016-10-17 11:10:26 -04:00
|
|
|
|
2017-05-09 00:15:34 -04:00
|
|
|
describe '#metrics' do
|
|
|
|
let(:deployment) { create(:deployment) }
|
|
|
|
|
2017-05-09 16:24:24 -04:00
|
|
|
subject { deployment.metrics }
|
2017-05-09 00:15:34 -04:00
|
|
|
|
|
|
|
context 'metrics are disabled' do
|
|
|
|
it { is_expected.to eq({}) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'metrics are enabled' do
|
|
|
|
let(:simple_metrics) do
|
|
|
|
{
|
|
|
|
success: true,
|
|
|
|
metrics: {},
|
2017-05-09 16:24:24 -04:00
|
|
|
last_update: 42,
|
|
|
|
deployment_time: 1494408956
|
2017-05-09 00:15:34 -04:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
2017-05-09 16:24:24 -04:00
|
|
|
allow(deployment.project).to receive_message_chain(:monitoring_service, :deployment_metrics)
|
2017-05-09 00:15:34 -04:00
|
|
|
.with(any_args).and_return(simple_metrics)
|
|
|
|
end
|
|
|
|
|
2017-05-09 16:24:24 -04:00
|
|
|
it { is_expected.to eq(simple_metrics) }
|
2017-05-09 00:15:34 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-06-06 20:36:59 -04:00
|
|
|
describe '#additional_metrics' do
|
2017-08-01 14:51:52 -04:00
|
|
|
let(:project) { create(:project, :repository) }
|
2017-06-16 14:48:34 -04:00
|
|
|
let(:deployment) { create(:deployment, project: project) }
|
2017-06-06 20:36:59 -04:00
|
|
|
|
|
|
|
subject { deployment.additional_metrics }
|
|
|
|
|
|
|
|
context 'metrics are disabled' do
|
|
|
|
it { is_expected.to eq({}) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'metrics are enabled' do
|
|
|
|
let(:simple_metrics) do
|
|
|
|
{
|
|
|
|
success: true,
|
|
|
|
metrics: {},
|
|
|
|
last_update: 42
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
let(:prometheus_service) { double('prometheus_service') }
|
|
|
|
|
|
|
|
before do
|
2017-06-16 14:48:34 -04:00
|
|
|
allow(project).to receive(:prometheus_service).and_return(prometheus_service)
|
2017-06-06 20:36:59 -04:00
|
|
|
allow(prometheus_service).to receive(:additional_deployment_metrics).and_return(simple_metrics)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq(simple_metrics.merge({ deployment_time: deployment.created_at.to_i })) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-10-17 11:10:26 -04:00
|
|
|
describe '#stop_action' do
|
|
|
|
let(:build) { create(:ci_build) }
|
|
|
|
|
|
|
|
subject { deployment.stop_action }
|
|
|
|
|
|
|
|
context 'when no other actions' do
|
|
|
|
let(:deployment) { FactoryGirl.build(:deployment, deployable: build) }
|
|
|
|
|
|
|
|
it { is_expected.to be_nil }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with other actions' do
|
2017-06-13 04:17:11 -04:00
|
|
|
let!(:close_action) { create(:ci_build, :manual, pipeline: build.pipeline, name: 'close_app') }
|
2016-10-17 11:10:26 -04:00
|
|
|
|
|
|
|
context 'when matching action is defined' do
|
|
|
|
let(:deployment) { FactoryGirl.build(:deployment, deployable: build, on_stop: 'close_other_app') }
|
|
|
|
|
|
|
|
it { is_expected.to be_nil }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when no matching action is defined' do
|
|
|
|
let(:deployment) { FactoryGirl.build(:deployment, deployable: build, on_stop: 'close_app') }
|
|
|
|
|
|
|
|
it { is_expected.to eq(close_action) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-02-07 07:30:33 -05:00
|
|
|
describe '#stop_action?' do
|
|
|
|
subject { deployment.stop_action? }
|
2016-10-17 11:10:26 -04:00
|
|
|
|
|
|
|
context 'when no other actions' do
|
|
|
|
let(:deployment) { build(:deployment) }
|
|
|
|
|
|
|
|
it { is_expected.to be_falsey }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when matching action is defined' do
|
|
|
|
let(:build) { create(:ci_build) }
|
|
|
|
let(:deployment) { FactoryGirl.build(:deployment, deployable: build, on_stop: 'close_app') }
|
2017-06-13 04:17:11 -04:00
|
|
|
let!(:close_action) { create(:ci_build, :manual, pipeline: build.pipeline, name: 'close_app') }
|
2016-10-17 11:10:26 -04:00
|
|
|
|
|
|
|
it { is_expected.to be_truthy }
|
|
|
|
end
|
|
|
|
end
|
2016-06-14 07:51:12 -04:00
|
|
|
end
|