summaryrefslogtreecommitdiff
path: root/spec/lib/gitlab/ci/config/node/environment_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/lib/gitlab/ci/config/node/environment_spec.rb')
-rw-r--r--spec/lib/gitlab/ci/config/node/environment_spec.rb217
1 files changed, 0 insertions, 217 deletions
diff --git a/spec/lib/gitlab/ci/config/node/environment_spec.rb b/spec/lib/gitlab/ci/config/node/environment_spec.rb
deleted file mode 100644
index df925ff1afd..00000000000
--- a/spec/lib/gitlab/ci/config/node/environment_spec.rb
+++ /dev/null
@@ -1,217 +0,0 @@
-require 'spec_helper'
-
-describe Gitlab::Ci::Config::Node::Environment do
- let(:entry) { described_class.new(config) }
-
- before { entry.compose! }
-
- context 'when configuration is a string' do
- let(:config) { 'production' }
-
- describe '#string?' do
- it 'is string configuration' do
- expect(entry).to be_string
- end
- end
-
- describe '#hash?' do
- it 'is not hash configuration' do
- expect(entry).not_to be_hash
- end
- end
-
- describe '#valid?' do
- it 'is valid' do
- expect(entry).to be_valid
- end
- end
-
- describe '#value' do
- it 'returns valid hash' do
- expect(entry.value).to include(name: 'production')
- end
- end
-
- describe '#name' do
- it 'returns environment name' do
- expect(entry.name).to eq 'production'
- end
- end
-
- describe '#url' do
- it 'returns environment url' do
- expect(entry.url).to be_nil
- end
- end
- end
-
- context 'when configuration is a hash' do
- let(:config) do
- { name: 'development', url: 'https://example.gitlab.com' }
- end
-
- describe '#string?' do
- it 'is not string configuration' do
- expect(entry).not_to be_string
- end
- end
-
- describe '#hash?' do
- it 'is hash configuration' do
- expect(entry).to be_hash
- end
- end
-
- describe '#valid?' do
- it 'is valid' do
- expect(entry).to be_valid
- end
- end
-
- describe '#value' do
- it 'returns valid hash' do
- expect(entry.value).to eq config
- end
- end
-
- describe '#name' do
- it 'returns environment name' do
- expect(entry.name).to eq 'development'
- end
- end
-
- describe '#url' do
- it 'returns environment url' do
- expect(entry.url).to eq 'https://example.gitlab.com'
- end
- end
- end
-
- context 'when valid action is used' do
- let(:config) do
- { name: 'production',
- action: 'start' }
- end
-
- it 'is valid' do
- expect(entry).to be_valid
- end
- end
-
- context 'when invalid action is used' do
- let(:config) do
- { name: 'production',
- action: 'invalid' }
- end
-
- describe '#valid?' do
- it 'is not valid' do
- expect(entry).not_to be_valid
- end
- end
-
- describe '#errors' do
- it 'contains error about invalid action' do
- expect(entry.errors)
- .to include 'environment action should be start or stop'
- end
- end
- end
-
- context 'when on_stop is used' do
- let(:config) do
- { name: 'production',
- on_stop: 'close_app' }
- end
-
- it 'is valid' do
- expect(entry).to be_valid
- end
- end
-
- context 'when invalid on_stop is used' do
- let(:config) do
- { name: 'production',
- on_stop: false }
- end
-
- describe '#valid?' do
- it 'is not valid' do
- expect(entry).not_to be_valid
- end
- end
-
- describe '#errors' do
- it 'contains error about invalid action' do
- expect(entry.errors)
- .to include 'environment on stop should be a string'
- end
- end
- end
-
- context 'when variables are used for environment' do
- let(:config) do
- { name: 'review/$CI_BUILD_REF_NAME',
- url: 'https://$CI_BUILD_REF_NAME.review.gitlab.com' }
- end
-
- describe '#valid?' do
- it 'is valid' do
- expect(entry).to be_valid
- end
- end
- end
-
- context 'when configuration is invalid' do
- context 'when configuration is an array' do
- let(:config) { ['env'] }
-
- describe '#valid?' do
- it 'is not valid' do
- expect(entry).not_to be_valid
- end
- end
-
- describe '#errors' do
- it 'contains error about invalid type' do
- expect(entry.errors)
- .to include 'environment config should be a hash or a string'
- end
- end
- end
-
- context 'when environment name is not present' do
- let(:config) { { url: 'https://example.gitlab.com' } }
-
- describe '#valid?' do
- it 'is not valid' do
- expect(entry).not_to be_valid
- end
- end
-
- describe '#errors?' do
- it 'contains error about missing environment name' do
- expect(entry.errors)
- .to include "environment name can't be blank"
- end
- end
- end
-
- context 'when invalid URL is used' do
- let(:config) { { name: 'test', url: 'invalid-example.gitlab.com' } }
-
- describe '#valid?' do
- it 'is not valid' do
- expect(entry).not_to be_valid
- end
- end
-
- describe '#errors?' do
- it 'contains error about invalid URL' do
- expect(entry.errors)
- .to include "environment url must be a valid url"
- end
- end
- end
- end
-end