diff options
Diffstat (limited to 'spec/services/deployments/after_create_service_spec.rb')
-rw-r--r-- | spec/services/deployments/after_create_service_spec.rb | 287 |
1 files changed, 0 insertions, 287 deletions
diff --git a/spec/services/deployments/after_create_service_spec.rb b/spec/services/deployments/after_create_service_spec.rb deleted file mode 100644 index 6cdb4c88191..00000000000 --- a/spec/services/deployments/after_create_service_spec.rb +++ /dev/null @@ -1,287 +0,0 @@ -# frozen_string_literal: true - -require 'spec_helper' - -RSpec.describe Deployments::AfterCreateService do - let(:user) { create(:user) } - let(:project) { create(:project, :repository) } - let(:options) { { name: 'production' } } - let(:pipeline) do - create( - :ci_pipeline, - sha: 'b83d6e391c22777fca1ed3012fce84f633d7fed0', - project: project - ) - end - - let(:job) do - create(:ci_build, - :with_deployment, - pipeline: pipeline, - ref: 'master', - tag: false, - environment: 'production', - options: { environment: options }, - project: project) - end - - let(:deployment) { job.deployment } - let(:environment) { deployment.environment } - - subject(:service) { described_class.new(deployment) } - - before do - allow(Deployments::FinishedWorker).to receive(:perform_async) - job.success! # Create/Succeed deployment - end - - describe '#execute' do - let(:store) { Gitlab::EtagCaching::Store.new } - - it 'invalidates the environment etag cache' do - old_value = store.get(environment.etag_cache_key) - - service.execute - - expect(store.get(environment.etag_cache_key)).not_to eq(old_value) - end - - it 'creates ref' do - expect_any_instance_of(Repository) - .to receive(:create_ref) - .with(deployment.sha, "refs/environments/production/deployments/#{deployment.iid}") - - service.execute - end - - it 'updates merge request metrics' do - expect_any_instance_of(Deployment) - .to receive(:update_merge_request_metrics!) - - service.execute - end - - it 'returns the deployment' do - expect(subject.execute).to eq(deployment) - end - - it 'returns the deployment when could not save the environment' do - allow(environment).to receive(:save).and_return(false) - - expect(subject.execute).to eq(deployment) - end - - it 'returns the deployment when environment is stopped' do - allow(environment).to receive(:stopped?).and_return(true) - - expect(subject.execute).to eq(deployment) - end - - context 'when start action is defined' do - let(:options) { { name: 'production', action: 'start' } } - - context 'and environment is stopped' do - before do - environment.stop - end - - it 'makes environment available' do - service.execute - - expect(environment.reload).to be_available - end - end - end - - context 'when variables are used' do - let(:options) do - { name: 'review-apps/$CI_COMMIT_REF_NAME', - url: 'http://$CI_COMMIT_REF_NAME.review-apps.gitlab.com' } - end - - before do - environment.update(name: 'review-apps/master') - job.update(environment: 'review-apps/$CI_COMMIT_REF_NAME') - end - - it 'does not create a new environment' do - expect { subject.execute }.not_to change { Environment.count } - end - - it 'updates external url' do - subject.execute - - expect(subject.environment.name).to eq('review-apps/master') - expect(subject.environment.external_url).to eq('http://master.review-apps.gitlab.com') - end - end - - context 'when auto_stop_in are used' do - let(:options) do - { name: 'production', auto_stop_in: '1 day' } - end - - it 'renews auto stop at' do - freeze_time do - environment.update!(auto_stop_at: nil) - - expect { subject.execute } - .to change { environment.reset.auto_stop_at&.round }.from(nil).to(1.day.since.round) - end - end - end - end - - describe '#expanded_environment_url' do - subject { service.send(:expanded_environment_url) } - - context 'when yaml environment uses $CI_COMMIT_REF_NAME' do - let(:job) do - create(:ci_build, - :with_deployment, - pipeline: pipeline, - ref: 'master', - environment: 'production', - project: project, - options: { environment: { name: 'production', url: 'http://review/$CI_COMMIT_REF_NAME' } }) - end - - it { is_expected.to eq('http://review/master') } - end - - context 'when yaml environment uses $CI_ENVIRONMENT_SLUG' do - let(:job) do - create(:ci_build, - :with_deployment, - pipeline: pipeline, - ref: 'master', - environment: 'prod-slug', - project: project, - options: { environment: { name: 'prod-slug', url: 'http://review/$CI_ENVIRONMENT_SLUG' } }) - end - - it { is_expected.to eq('http://review/prod-slug') } - end - - context 'when yaml environment uses yaml_variables containing symbol keys' do - let(:job) do - create(:ci_build, - :with_deployment, - pipeline: pipeline, - yaml_variables: [{ key: :APP_HOST, value: 'host' }], - environment: 'production', - project: project, - options: { environment: { name: 'production', url: 'http://review/$APP_HOST' } }) - end - - it { is_expected.to eq('http://review/host') } - end - - context 'when job variables are generated during runtime' do - let(:job) do - create(:ci_build, - :with_deployment, - pipeline: pipeline, - environment: 'review/$CI_COMMIT_REF_NAME', - project: project, - job_variables: [job_variable], - options: { environment: { name: 'review/$CI_COMMIT_REF_NAME', url: 'http://$DYNAMIC_ENV_URL' } }) - end - - let(:job_variable) do - build(:ci_job_variable, :dotenv_source, key: 'DYNAMIC_ENV_URL', value: 'abc.test.com') - end - - it 'expands the environment URL from the dynamic variable' do - is_expected.to eq('http://abc.test.com') - end - end - - context 'when yaml environment does not have url' do - let(:job) { create(:ci_build, :with_deployment, pipeline: pipeline, environment: 'staging', project: project) } - - it 'returns the external_url from persisted environment' do - is_expected.to be_nil - end - end - end - - describe "merge request metrics" do - let(:merge_request) { create(:merge_request, target_branch: 'master', source_branch: 'feature', source_project: project) } - - context "while updating the 'first_deployed_to_production_at' time" do - before do - merge_request.metrics.update!(merged_at: 1.hour.ago) - end - - context "for merge requests merged before the current deploy" do - it "sets the time if the deploy's environment is 'production'" do - service.execute - - expect(merge_request.reload.metrics.first_deployed_to_production_at).to be_like_time(deployment.finished_at) - end - - context 'when job deploys to staging' do - let(:job) do - create(:ci_build, - :with_deployment, - pipeline: pipeline, - ref: 'master', - tag: false, - environment: 'staging', - options: { environment: { name: 'staging' } }, - project: project) - end - - it "doesn't set the time if the deploy's environment is not 'production'" do - service.execute - - expect(merge_request.reload.metrics.first_deployed_to_production_at).to be_nil - end - end - - it 'does not raise errors if the merge request does not have a metrics record' do - merge_request.metrics.destroy - - expect(merge_request.reload.metrics).to be_nil - expect { service.execute }.not_to raise_error - end - end - - context "for merge requests merged before the previous deploy" do - context "if the 'first_deployed_to_production_at' time is already set" do - it "does not overwrite the older 'first_deployed_to_production_at' time" do - # Previous deploy - service.execute - - expect(merge_request.reload.metrics.first_deployed_to_production_at).to be_like_time(deployment.finished_at) - - # Current deploy - Timecop.travel(12.hours.from_now) do - service.execute - - expect(merge_request.reload.metrics.first_deployed_to_production_at).to be_like_time(deployment.finished_at) - end - end - end - - context "if the 'first_deployed_to_production_at' time is not already set" do - it "does not overwrite the older 'first_deployed_to_production_at' time" do - # Previous deploy - time = 5.minutes.from_now - Timecop.freeze(time) { service.execute } - - expect(merge_request.reload.metrics.merged_at).to be < merge_request.reload.metrics.first_deployed_to_production_at - - previous_time = merge_request.reload.metrics.first_deployed_to_production_at - - # Current deploy - Timecop.freeze(time + 12.hours) { service.execute } - - expect(merge_request.reload.metrics.first_deployed_to_production_at).to eq(previous_time) - end - end - end - end - end -end |