Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/models/concerns/deployable_spec.rb')
-rw-r--r--spec/models/concerns/deployable_spec.rb49
1 files changed, 23 insertions, 26 deletions
diff --git a/spec/models/concerns/deployable_spec.rb b/spec/models/concerns/deployable_spec.rb
index 42bed9434f5..f4a1d510f9f 100644
--- a/spec/models/concerns/deployable_spec.rb
+++ b/spec/models/concerns/deployable_spec.rb
@@ -4,51 +4,47 @@ require 'rails_helper'
describe Deployable do
describe '#create_deployment' do
- let(:deployment) { job.deployment }
- let(:environment) { deployment&.environment }
-
- before do
- job.reload
- end
-
context 'when the deployable object will deploy to production' do
- let!(:job) { create(:ci_build, :start_review_app) }
+ let(:job) { create(:ci_build, :start_review_app) }
it 'creates a deployment and environment record' do
- expect(deployment.project).to eq(job.project)
- expect(deployment.ref).to eq(job.ref)
- expect(deployment.tag).to eq(job.tag)
- expect(deployment.sha).to eq(job.sha)
- expect(deployment.user).to eq(job.user)
- expect(deployment.deployable).to eq(job)
- expect(deployment.on_stop).to eq('stop_review_app')
- expect(environment.name).to eq('review/master')
+ job.create_deployment
+
+ expect(job.deployment.project).to eq(job.project)
+ expect(job.deployment.ref).to eq(job.ref)
+ expect(job.deployment.tag).to eq(job.tag)
+ expect(job.deployment.sha).to eq(job.sha)
+ expect(job.deployment.user).to eq(job.user)
+ expect(job.deployment.deployable).to eq(job)
+ expect(job.deployment.on_stop).to eq('stop_review_app')
+ expect(job.deployment.environment.name).to eq('review/master')
end
end
context 'when the deployable object will stop an environment' do
- let!(:job) { create(:ci_build, :stop_review_app) }
+ let(:job) { create(:ci_build, :stop_review_app) }
it 'does not create a deployment record' do
- expect(deployment).to be_nil
+ expect { job.create_deployment }.not_to change { job.reload.deployment }.from(nil)
end
end
context 'when the deployable object has already had a deployment' do
- let!(:job) { create(:ci_build, :start_review_app, deployment: race_deployment) }
- let!(:race_deployment) { create(:deployment, :success) }
+ let(:job) { create(:ci_build, :start_review_app, deployment: race_deployment) }
+ let(:race_deployment) { create(:deployment, :success) }
it 'does not create a new deployment' do
- expect(deployment).to eq(race_deployment)
+ expect { job.create_deployment }.not_to change { job.reload.deployment }.from(race_deployment)
end
end
context 'when the deployable object will not deploy' do
- let!(:job) { create(:ci_build) }
+ let(:job) { create(:ci_build) }
it 'does not create a deployment and environment record' do
- expect(deployment).to be_nil
- expect(environment).to be_nil
+ expect { job.create_deployment }.not_to change { job.reload.deployment }.from(nil)
+
+ expect(job.persisted_environment).to be_nil
end
end
@@ -68,8 +64,9 @@ describe Deployable do
end
it 'does not create a deployment and environment record' do
- expect(deployment).to be_nil
- expect(environment).to be_nil
+ expect { job.create_deployment }.not_to change { job.reload.deployment }.from(nil)
+
+ expect(job.persisted_environment).to be_nil
end
end
end