debian-mirror-gitlab/spec/services/deployments/create_service_spec.rb

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

101 lines
2.7 KiB
Ruby
Raw Normal View History

2019-12-21 20:55:43 +05:30
# frozen_string_literal: true
require 'spec_helper'
2023-05-27 22:25:52 +05:30
RSpec.describe Deployments::CreateService, feature_category: :continuous_delivery do
2020-01-01 13:55:28 +05:30
let(:user) { create(:user) }
2019-12-21 20:55:43 +05:30
describe '#execute' do
2020-01-01 13:55:28 +05:30
let(:project) { create(:project, :repository) }
let(:environment) { create(:environment, project: project) }
2019-12-21 20:55:43 +05:30
2020-01-01 13:55:28 +05:30
it 'creates a deployment' do
service = described_class.new(
environment,
user,
sha: 'b83d6e391c22777fca1ed3012fce84f633d7fed0',
ref: 'master',
tag: false,
status: 'success'
)
2019-12-21 20:55:43 +05:30
2021-01-03 14:25:43 +05:30
expect(Deployments::UpdateEnvironmentWorker).to receive(:perform_async)
expect(Deployments::LinkMergeRequestWorker).to receive(:perform_async)
2022-08-13 15:12:31 +05:30
expect(Deployments::HooksWorker).to receive(:perform_async)
2019-12-21 20:55:43 +05:30
2020-01-01 13:55:28 +05:30
expect(service.execute).to be_persisted
2019-12-21 20:55:43 +05:30
end
2020-01-01 13:55:28 +05:30
it 'does not change the status if no status is given' do
service = described_class.new(
environment,
user,
sha: 'b83d6e391c22777fca1ed3012fce84f633d7fed0',
ref: 'master',
tag: false
)
2019-12-21 20:55:43 +05:30
2021-01-03 14:25:43 +05:30
expect(Deployments::UpdateEnvironmentWorker).not_to receive(:perform_async)
expect(Deployments::LinkMergeRequestWorker).not_to receive(:perform_async)
2022-08-13 15:12:31 +05:30
expect(Deployments::HooksWorker).not_to receive(:perform_async)
2019-12-21 20:55:43 +05:30
2020-01-01 13:55:28 +05:30
expect(service.execute).to be_persisted
2019-12-21 20:55:43 +05:30
end
2021-03-11 19:13:27 +05:30
context 'when the last deployment has the same parameters' do
let(:params) do
{
sha: 'b83d6e391c22777fca1ed3012fce84f633d7fed0',
ref: 'master',
tag: false,
status: 'success'
}
end
it 'does not create a new deployment' do
described_class.new(environment, user, params).execute
2022-08-13 15:12:31 +05:30
expect(Deployments::UpdateEnvironmentWorker).not_to receive(:perform_async)
expect(Deployments::LinkMergeRequestWorker).not_to receive(:perform_async)
expect(Deployments::HooksWorker).not_to receive(:perform_async)
described_class.new(environment.reload, user, params).execute
2021-03-11 19:13:27 +05:30
end
end
2019-12-21 20:55:43 +05:30
end
2020-01-01 13:55:28 +05:30
describe '#deployment_attributes' do
let(:environment) do
double(
:environment,
deployment_platform: double(:platform, cluster_id: 1),
project_id: 2,
id: 3
)
2019-12-21 20:55:43 +05:30
end
it 'only includes attributes that we want to persist' do
service = described_class.new(
environment,
user,
ref: 'master',
tag: true,
sha: '123',
foo: 'bar',
2020-01-01 13:55:28 +05:30
on_stop: 'stop'
2019-12-21 20:55:43 +05:30
)
expect(service.deployment_attributes).to eq(
cluster_id: 1,
project_id: 2,
environment_id: 3,
ref: 'master',
tag: true,
sha: '123',
user: user,
2020-01-01 13:55:28 +05:30
on_stop: 'stop'
2019-12-21 20:55:43 +05:30
)
end
end
end