diff options
author | Thong Kuah <tkuah@gitlab.com> | 2018-10-22 20:12:26 +0000 |
---|---|---|
committer | Thong Kuah <tkuah@gitlab.com> | 2018-10-22 20:12:26 +0000 |
commit | 305ab0405aca2270e6db24f9b53a0aa1ec9aa92e (patch) | |
tree | 5366e3b09c8dee410496757319340c658064248f /spec/support | |
parent | b887d106cc3aaf00ac2e7af5b838009d1c9d6df3 (diff) | |
download | gitlab-ce-305ab0405aca2270e6db24f9b53a0aa1ec9aa92e.tar.gz |
Revert "Merge branch 'refactor-cluster-create-service-spec' into 'master'"
This reverts merge request !22407
Diffstat (limited to 'spec/support')
-rw-r--r-- | spec/support/services/clusters/create_service_shared.rb | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/spec/support/services/clusters/create_service_shared.rb b/spec/support/services/clusters/create_service_shared.rb new file mode 100644 index 00000000000..b0bf942aa09 --- /dev/null +++ b/spec/support/services/clusters/create_service_shared.rb @@ -0,0 +1,59 @@ +shared_context 'valid cluster create params' do + let(:params) do + { + name: 'test-cluster', + provider_type: :gcp, + provider_gcp_attributes: { + gcp_project_id: 'gcp-project', + zone: 'us-central1-a', + num_nodes: 1, + machine_type: 'machine_type-a', + legacy_abac: 'true' + } + } + end +end + +shared_context 'invalid cluster create params' do + let(:params) do + { + name: 'test-cluster', + provider_type: :gcp, + provider_gcp_attributes: { + gcp_project_id: '!!!!!!!', + zone: 'us-central1-a', + num_nodes: 1, + machine_type: 'machine_type-a' + } + } + end +end + +shared_examples 'create cluster service success' do + it 'creates a cluster object and performs a worker' do + expect(ClusterProvisionWorker).to receive(:perform_async) + + expect { subject } + .to change { Clusters::Cluster.count }.by(1) + .and change { Clusters::Providers::Gcp.count }.by(1) + + expect(subject.name).to eq('test-cluster') + expect(subject.user).to eq(user) + expect(subject.project).to eq(project) + expect(subject.provider.gcp_project_id).to eq('gcp-project') + expect(subject.provider.zone).to eq('us-central1-a') + expect(subject.provider.num_nodes).to eq(1) + expect(subject.provider.machine_type).to eq('machine_type-a') + expect(subject.provider.access_token).to eq(access_token) + expect(subject.provider).to be_legacy_abac + expect(subject.platform).to be_nil + end +end + +shared_examples 'create cluster service error' do + it 'returns an error' do + expect(ClusterProvisionWorker).not_to receive(:perform_async) + expect { subject }.to change { Clusters::Cluster.count }.by(0) + expect(subject.errors[:"provider_gcp.gcp_project_id"]).to be_present + end +end |