2018-03-17 18:26:18 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe Clusters::CreateService do
|
|
|
|
let(:access_token) { 'xxx' }
|
|
|
|
let(:project) { create(:project) }
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
|
2018-12-13 13:39:08 +05:30
|
|
|
subject { described_class.new(user, params).execute(access_token: access_token) }
|
2018-03-17 18:26:18 +05:30
|
|
|
|
|
|
|
context 'when provider is gcp' do
|
|
|
|
context 'when project has no clusters' do
|
|
|
|
context 'when correct params' do
|
2018-12-13 13:39:08 +05:30
|
|
|
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'
|
|
|
|
},
|
|
|
|
clusterable: project
|
|
|
|
}
|
|
|
|
end
|
2018-03-17 18:26:18 +05:30
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
include_examples 'create cluster service success'
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
context 'when invalid params' do
|
2018-12-13 13:39:08 +05:30
|
|
|
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'
|
|
|
|
},
|
|
|
|
clusterable: project
|
|
|
|
}
|
|
|
|
end
|
2018-03-17 18:26:18 +05:30
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
include_examples 'create cluster service error'
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when project has a cluster' do
|
2018-11-08 19:23:39 +05:30
|
|
|
include_context 'valid cluster create params'
|
2018-05-01 15:08:00 +05:30
|
|
|
let!(:cluster) { create(:cluster, :provided_by_gcp, :production_environment, projects: [project]) }
|
2018-03-17 18:26:18 +05:30
|
|
|
|
|
|
|
it 'does not create a cluster' do
|
|
|
|
expect(ClusterProvisionWorker).not_to receive(:perform_async)
|
|
|
|
expect { subject }.to raise_error(ArgumentError).and change { Clusters::Cluster.count }.by(0)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|