Commit 6a65e2f5 authored by Shinya Maeda's avatar Shinya Maeda

specs for controller. Improved validation

parent 944149ec
...@@ -27,13 +27,14 @@ class Projects::ClustersController < Projects::ApplicationController ...@@ -27,13 +27,14 @@ class Projects::ClustersController < Projects::ApplicationController
end end
def new def new
@cluster = Clusters::Cluster.new( # @cluster = Clusters::Cluster.new(
platform_type: :kubernetes, # platform_type: :kubernetes,
provider_type: :gcp).tap do |cluster| # provider_type: :gcp).tap do |cluster|
cluster.build_provider_gcp # cluster.build_provider_gcp
cluster.build_platform_kubernetes # cluster.build_platform_kubernetes
cluster.projects << project # cluster.projects << project
end # end
@cluster = Clusters::Cluster.new
end end
def create def create
......
...@@ -10,11 +10,13 @@ module Clusters ...@@ -10,11 +10,13 @@ module Clusters
has_many :projects, through: :cluster_projects, class_name: '::Project' has_many :projects, through: :cluster_projects, class_name: '::Project'
has_one :provider_gcp, class_name: 'Clusters::Providers::Gcp' has_one :provider_gcp, class_name: 'Clusters::Providers::Gcp'
has_one :platform_kubernetes, class_name: 'Clusters::Platforms::Kubernetes' has_one :platform_kubernetes, class_name: 'Clusters::Platforms::Kubernetes', validate: { if: :update }
accepts_nested_attributes_for :provider_gcp accepts_nested_attributes_for :provider_gcp, update_only: true
accepts_nested_attributes_for :platform_kubernetes, update_only: true accepts_nested_attributes_for :platform_kubernetes, update_only: true
validates :provider_type, presence: true
validates :platform_type, presence: true
validates :name, cluster_name: true validates :name, cluster_name: true
validate :restrict_modification, on: :update validate :restrict_modification, on: :update
......
...@@ -30,8 +30,8 @@ module Clusters ...@@ -30,8 +30,8 @@ module Clusters
message: Gitlab::Regex.kubernetes_namespace_regex_message message: Gitlab::Regex.kubernetes_namespace_regex_message
} }
validates :api_url, url: true, presence: true, on: :update validates :api_url, url: true, presence: true
validates :token, presence: true, on: :update validates :token, presence: true
after_save :clear_reactive_cache! after_save :clear_reactive_cache!
......
...@@ -28,10 +28,10 @@ module Clusters ...@@ -28,10 +28,10 @@ module Clusters
def cluster_params def cluster_params
return @cluster_params if defined?(@cluster_params) return @cluster_params if defined?(@cluster_params)
params[:provider_gcp_attributes][:machine_type] ||= params[:provider_gcp_attributes].try do |h|
GoogleApi::CloudPlatform::Client::DEFAULT_MACHINE_TYPE h[:machine_type] ||= GoogleApi::CloudPlatform::Client::DEFAULT_MACHINE_TYPE
h[:access_token] ||= access_token
params[:provider_gcp_attributes][:access_token] ||= access_token end
@cluster_params = params.merge(user: current_user) @cluster_params = params.merge(user: current_user)
end end
......
...@@ -42,7 +42,9 @@ FactoryGirl.define do ...@@ -42,7 +42,9 @@ FactoryGirl.define do
end end
after(:create) do |cluster, evaluator| after(:create) do |cluster, evaluator|
create(:platform_kubernetes, cluster: cluster) build(:platform_kubernetes, cluster: cluster).tap do |platform|
platform.save!(validate: false)
end
end end
end end
end end
......
...@@ -3,19 +3,16 @@ FactoryGirl.define do ...@@ -3,19 +3,16 @@ FactoryGirl.define do
cluster cluster
namespace nil namespace nil
trait :ca_cert do
after(:create) do |platform_kubernetes, evaluator|
pem_file = File.expand_path(Rails.root.join('spec/fixtures/clusters/sample_cert.pem'))
platform_kubernetes.ca_cert = File.read(pem_file)
end
end
trait :configured do trait :configured do
api_url 'https://kubernetes.example.com' api_url 'https://kubernetes.example.com'
ca_cert nil
token 'a' * 40 token 'a' * 40
username 'xxxxxx' username 'xxxxxx'
password 'xxxxxx' password 'xxxxxx'
after(:create) do |platform_kubernetes, evaluator|
pem_file = File.expand_path(Rails.root.join('spec/fixtures/clusters/sample_cert.pem'))
platform_kubernetes.ca_cert = File.read(pem_file)
end
end end
end end
end end
...@@ -10,6 +10,8 @@ describe Clusters::Cluster do ...@@ -10,6 +10,8 @@ describe Clusters::Cluster do
it { is_expected.to delegate_method(:status_name).to(:provider) } it { is_expected.to delegate_method(:status_name).to(:provider) }
it { is_expected.to delegate_method(:on_creation?).to(:provider) } it { is_expected.to delegate_method(:on_creation?).to(:provider) }
it { is_expected.to respond_to :project } it { is_expected.to respond_to :project }
it { is_expected.to validate_presence_of(:provider_type) }
it { is_expected.to validate_presence_of(:platform_type) }
describe '.enabled' do describe '.enabled' do
subject { described_class.enabled } subject { described_class.enabled }
......
...@@ -11,7 +11,7 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching ...@@ -11,7 +11,7 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching
describe 'before_validation' do describe 'before_validation' do
context 'when namespace includes upper case' do context 'when namespace includes upper case' do
let(:kubernetes) { create(:platform_kubernetes, namespace: namespace) } let(:kubernetes) { create(:platform_kubernetes, :configured, namespace: namespace) }
let(:namespace) { 'ABC' } let(:namespace) { 'ABC' }
it 'converts to lower case' do it 'converts to lower case' do
...@@ -24,7 +24,7 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching ...@@ -24,7 +24,7 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching
subject { kubernetes.valid? } subject { kubernetes.valid? }
context 'when validates namespace' do context 'when validates namespace' do
let(:kubernetes) { build(:platform_kubernetes, namespace: namespace) } let(:kubernetes) { build(:platform_kubernetes, :configured, namespace: namespace) }
context 'when namespace is blank' do context 'when namespace is blank' do
let(:namespace) { '' } let(:namespace) { '' }
...@@ -52,74 +52,42 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching ...@@ -52,74 +52,42 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching
end end
context 'when validates api_url' do context 'when validates api_url' do
context 'when updates a record' do let(:kubernetes) { build(:platform_kubernetes, :configured) }
let(:kubernetes) { create(:platform_kubernetes) }
before do before do
kubernetes.api_url = api_url kubernetes.api_url = api_url
end end
context 'when api_url is invalid url' do
let(:api_url) { '!!!!!!' }
it { expect(kubernetes.save).to be_falsey }
end
context 'when api_url is nil' do
let(:api_url) { nil }
it { expect(kubernetes.save).to be_falsey }
end
context 'when api_url is valid url' do context 'when api_url is invalid url' do
let(:api_url) { 'https://111.111.111.111' } let(:api_url) { '!!!!!!' }
it { expect(kubernetes.save).to be_truthy } it { expect(kubernetes.save).to be_falsey }
end
end end
context 'when creates a record' do context 'when api_url is nil' do
let(:kubernetes) { build(:platform_kubernetes) } let(:api_url) { nil }
before do it { expect(kubernetes.save).to be_falsey }
kubernetes.api_url = api_url end
end
context 'when api_url is nil' do context 'when api_url is valid url' do
let(:api_url) { nil } let(:api_url) { 'https://111.111.111.111' }
it { expect(kubernetes.save).to be_truthy } it { expect(kubernetes.save).to be_truthy }
end
end end
end end
context 'when validates token' do context 'when validates token' do
context 'when updates a record' do let(:kubernetes) { build(:platform_kubernetes, :configured) }
let(:kubernetes) { create(:platform_kubernetes) }
before do before do
kubernetes.token = token kubernetes.token = token
end
context 'when token is nil' do
let(:token) { nil }
it { expect(kubernetes.save).to be_falsey }
end
end end
context 'when creates a record' do context 'when token is nil' do
let(:kubernetes) { build(:platform_kubernetes) } let(:token) { nil }
before do it { expect(kubernetes.save).to be_falsey }
kubernetes.token = token
end
context 'when token is nil' do
let(:token) { nil }
it { expect(kubernetes.save).to be_truthy }
end
end end
end end
end end
...@@ -128,7 +96,8 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching ...@@ -128,7 +96,8 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching
subject { kubernetes.actual_namespace } subject { kubernetes.actual_namespace }
let!(:cluster) { create(:cluster, :project, platform_kubernetes: kubernetes) } let!(:cluster) { create(:cluster, :project, platform_kubernetes: kubernetes) }
let(:kubernetes) { create(:platform_kubernetes, namespace: namespace) } let(:project) { cluster.project }
let(:kubernetes) { create(:platform_kubernetes, :configured, namespace: namespace) }
context 'when namespace is present' do context 'when namespace is present' do
let(:namespace) { 'namespace-123' } let(:namespace) { 'namespace-123' }
...@@ -139,7 +108,7 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching ...@@ -139,7 +108,7 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching
context 'when namespace is not present' do context 'when namespace is not present' do
let(:namespace) { nil } let(:namespace) { nil }
it { is_expected.to eq("#{cluster.project.path}-#{cluster.project.id}") } it { is_expected.to eq("#{project.path}-#{project.id}") }
end end
end end
...@@ -154,12 +123,13 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching ...@@ -154,12 +123,13 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching
describe '#default_namespace' do describe '#default_namespace' do
subject { kubernetes.default_namespace } subject { kubernetes.default_namespace }
let(:kubernetes) { create(:platform_kubernetes) } let(:kubernetes) { create(:platform_kubernetes, :configured) }
context 'when cluster belongs to a project' do context 'when cluster belongs to a project' do
let!(:cluster) { create(:cluster, :project, platform_kubernetes: kubernetes) } let!(:cluster) { create(:cluster, :project, platform_kubernetes: kubernetes) }
let(:project) { cluster.project }
it { is_expected.to eq("#{cluster.project.path}-#{cluster.project.id}") } it { is_expected.to eq("#{project.path}-#{project.id}") }
end end
context 'when cluster belongs to nothing' do context 'when cluster belongs to nothing' do
...@@ -229,7 +199,7 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching ...@@ -229,7 +199,7 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching
let!(:cluster) { create(:cluster, :project, platform_kubernetes: service) } let!(:cluster) { create(:cluster, :project, platform_kubernetes: service) }
let(:project) { cluster.project } let(:project) { cluster.project }
let(:service) { create(:platform_kubernetes) } let(:service) { create(:platform_kubernetes, :configured) }
let(:environment) { build(:environment, project: project, name: "env", slug: "env-000000") } let(:environment) { build(:environment, project: project, name: "env", slug: "env-000000") }
context 'with invalid pods' do context 'with invalid pods' do
...@@ -268,7 +238,7 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching ...@@ -268,7 +238,7 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching
subject { service.calculate_reactive_cache } subject { service.calculate_reactive_cache }
let!(:cluster) { create(:cluster, :project, enabled: enabled, platform_kubernetes: service) } let!(:cluster) { create(:cluster, :project, enabled: enabled, platform_kubernetes: service) }
let(:service) { create(:platform_kubernetes, :ca_cert) } let(:service) { create(:platform_kubernetes, :configured) }
let(:enabled) { true } let(:enabled) { true }
context 'when cluster is disabled' do context 'when cluster is disabled' do
......
module GoogleApi module GoogleApi
module CloudPlatformHelpers module CloudPlatformHelpers
def stub_google_api_validate_token
request.session[GoogleApi::CloudPlatform::Client.session_key_for_token] = 'token'
request.session[GoogleApi::CloudPlatform::Client.session_key_for_expires_at] = 1.hour.since.to_i.to_s
end
def stub_google_api_expired_token
request.session[GoogleApi::CloudPlatform::Client.session_key_for_token] = 'token'
request.session[GoogleApi::CloudPlatform::Client.session_key_for_expires_at] = 1.hour.ago.to_i.to_s
end
def stub_cloud_platform_get_zone_cluster(project_id, zone, cluster_id, **options) def stub_cloud_platform_get_zone_cluster(project_id, zone, cluster_id, **options)
WebMock.stub_request(:get, cloud_platform_get_zone_cluster_url(project_id, zone, cluster_id)) WebMock.stub_request(:get, cloud_platform_get_zone_cluster_url(project_id, zone, cluster_id))
.to_return(cloud_platform_response(cloud_platform_cluster_body(options))) .to_return(cloud_platform_response(cloud_platform_cluster_body(options)))
......
...@@ -14,7 +14,7 @@ module KubernetesHelpers ...@@ -14,7 +14,7 @@ module KubernetesHelpers
end end
def stub_kubeclient_pods(response = nil) def stub_kubeclient_pods(response = nil)
stub_kubeclient_discover stub_kubeclient_discover(service.api_url)
pods_url = service.api_url + "/api/v1/namespaces/#{service.actual_namespace}/pods" pods_url = service.api_url + "/api/v1/namespaces/#{service.actual_namespace}/pods"
WebMock.stub_request(:get, pods_url).to_return(response || kube_pods_response) WebMock.stub_request(:get, pods_url).to_return(response || kube_pods_response)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment