Commit ef34cb6b authored by Tiger's avatar Tiger

Remove some duplication from new cluster form

Also rename 'eks' to 'aws' to keep consistency with
the backend.
parent 629fd9a3
...@@ -43,14 +43,11 @@ class Clusters::ClustersController < Clusters::BaseController ...@@ -43,14 +43,11 @@ class Clusters::ClustersController < Clusters::BaseController
def new def new
return unless Feature.enabled?(:create_eks_clusters) return unless Feature.enabled?(:create_eks_clusters)
if params[:provider] == 'eks' if params[:provider] == 'aws'
@eks_selected = true
@aws_role = current_user.aws_role || Aws::Role.new @aws_role = current_user.aws_role || Aws::Role.new
@aws_role.ensure_role_external_id! @aws_role.ensure_role_external_id!
elsif params[:provider] == 'gke' elsif params[:provider] == 'gcp'
@gke_selected = true
redirect_to @authorize_url if @authorize_url && !@valid_gcp_token redirect_to @authorize_url if @authorize_url && !@valid_gcp_token
end end
end end
......
...@@ -6,6 +6,28 @@ module ClustersHelper ...@@ -6,6 +6,28 @@ module ClustersHelper
false false
end end
def create_new_cluster_label(provider: nil)
case provider
when 'aws'
s_('ClusterIntegration|Create new Cluster on EKS')
when 'gcp'
s_('ClusterIntegration|Create new Cluster on GKE')
else
s_('ClusterIntegration|Create new Cluster')
end
end
def new_cluster_partial(provider: nil)
case provider
when 'aws'
'clusters/clusters/aws/new'
when 'gcp'
'clusters/clusters/gcp/new'
else
'clusters/clusters/cloud_providers/cloud_provider_selector'
end
end
def render_gcp_signup_offer def render_gcp_signup_offer
return if Gitlab::CurrentSettings.current_application_settings.hide_third_party_offers? return if Gitlab::CurrentSettings.current_application_settings.hide_third_party_offers?
return unless show_gcp_signup_offer? return unless show_gcp_signup_offer?
......
...@@ -280,15 +280,15 @@ class ApplicationSetting < ApplicationRecord ...@@ -280,15 +280,15 @@ class ApplicationSetting < ApplicationRecord
validates :eks_account_id, validates :eks_account_id,
format: { with: Gitlab::Regex.aws_account_id_regex, format: { with: Gitlab::Regex.aws_account_id_regex,
message: Gitlab::Regex.aws_account_id_message }, message: Gitlab::Regex.aws_account_id_message },
if: -> (setting) { setting.eks_integration_enabled? } if: :eks_integration_enabled?
validates :eks_access_key_id, validates :eks_access_key_id,
length: { in: 16..128 }, length: { in: 16..128 },
if: -> (setting) { setting.eks_integration_enabled? } if: :eks_integration_enabled?
validates :eks_secret_access_key, validates :eks_secret_access_key,
presence: true, presence: true,
if: -> (setting) { setting.eks_integration_enabled? } if: :eks_integration_enabled?
validates_with X509CertificateCredentialsValidator, validates_with X509CertificateCredentialsValidator,
certificate: :external_auth_client_cert, certificate: :external_auth_client_cert,
......
...@@ -14,7 +14,7 @@ module Aws ...@@ -14,7 +14,7 @@ module Aws
message: Gitlab::Regex.aws_arn_regex_message message: Gitlab::Regex.aws_arn_regex_message
} }
before_validation :ensure_role_external_id!, if: :new_record? before_validation :ensure_role_external_id!, on: :create
def ensure_role_external_id! def ensure_role_external_id!
self.role_external_id ||= SecureRandom.hex(20) self.role_external_id ||= SecureRandom.hex(20)
......
...@@ -6,6 +6,6 @@ ...@@ -6,6 +6,6 @@
= create_cluster_label = create_cluster_label
.d-flex .d-flex
= render partial: 'clusters/clusters/cloud_providers/cloud_provider_button', = render partial: 'clusters/clusters/cloud_providers/cloud_provider_button',
locals: { provider: 'eks', label: eks_label, logo_path: 'illustrations/logos/amazon_eks.svg' } locals: { provider: 'aws', label: eks_label, logo_path: 'illustrations/logos/amazon_eks.svg' }
= render partial: 'clusters/clusters/cloud_providers/cloud_provider_button', = render partial: 'clusters/clusters/cloud_providers/cloud_provider_button',
locals: { provider: 'gke', label: gke_label, logo_path: 'illustrations/logos/google_gke.svg', last: true } locals: { provider: 'gcp', label: gke_label, logo_path: 'illustrations/logos/google_gke.svg', last: true }
= render 'clusters/clusters/gcp/header'
- if @valid_gcp_token
= render 'clusters/clusters/gcp/form'
- elsif @authorize_url
= render 'clusters/clusters/gcp/signin_with_google_button'
- else
= render 'clusters/clusters/gcp/gcp_not_configured'
...@@ -2,9 +2,6 @@ ...@@ -2,9 +2,6 @@
- page_title _('Kubernetes Cluster') - page_title _('Kubernetes Cluster')
- create_eks_enabled = Feature.enabled?(:create_eks_clusters) - create_eks_enabled = Feature.enabled?(:create_eks_clusters)
- active_tab = local_assigns.fetch(:active_tab, 'create') - active_tab = local_assigns.fetch(:active_tab, 'create')
- create_on_gke_tab_label = s_('ClusterIntegration|Create new Cluster on GKE')
- create_on_eks_tab_label = s_('ClusterIntegration|Create new Cluster on EKS')
- create_new_cluster_label = s_('ClusterIntegration|Create new Cluster')
= javascript_include_tag 'https://apis.google.com/js/api.js' = javascript_include_tag 'https://apis.google.com/js/api.js'
= render_gcp_signup_offer = render_gcp_signup_offer
...@@ -18,14 +15,9 @@ ...@@ -18,14 +15,9 @@
%a.nav-link{ href: '#create-cluster-pane', id: 'create-cluster-tab', class: active_when(active_tab == 'create'), data: { toggle: 'tab' }, role: 'tab' } %a.nav-link{ href: '#create-cluster-pane', id: 'create-cluster-tab', class: active_when(active_tab == 'create'), data: { toggle: 'tab' }, role: 'tab' }
%span %span
- if create_eks_enabled - if create_eks_enabled
- if @gke_selected = create_new_cluster_label(provider: params[:provider])
= create_on_gke_tab_label
- elsif @eks_selected
= create_on_eks_tab_label
- else
= create_new_cluster_label
- else - else
= create_on_gke_tab_label = create_new_cluster_label(provider: 'gcp')
%li.nav-item{ role: 'presentation' } %li.nav-item{ role: 'presentation' }
%a.nav-link{ href: '#add-cluster-pane', id: 'add-cluster-tab', class: active_when(active_tab == 'add'), data: { toggle: 'tab' }, role: 'tab' } %a.nav-link{ href: '#add-cluster-pane', id: 'add-cluster-tab', class: active_when(active_tab == 'add'), data: { toggle: 'tab' }, role: 'tab' }
%span Add existing cluster %span Add existing cluster
...@@ -33,27 +25,10 @@ ...@@ -33,27 +25,10 @@
.tab-content.gitlab-tab-content .tab-content.gitlab-tab-content
- if create_eks_enabled - if create_eks_enabled
.tab-pane{ id: 'create-cluster-pane', class: active_when(active_tab == 'create'), role: 'tabpanel' } .tab-pane{ id: 'create-cluster-pane', class: active_when(active_tab == 'create'), role: 'tabpanel' }
- if @gke_selected = render new_cluster_partial(provider: params[:provider])
= render 'clusters/clusters/gcp/header'
- if @valid_gcp_token
= render 'clusters/clusters/gcp/form'
- elsif @authorize_url
= render 'clusters/clusters/gcp/signin_with_google_button'
- else
= render 'clusters/clusters/gcp/gcp_not_configured'
- elsif @eks_selected
= render 'clusters/clusters/eks/index'
- else
= render 'clusters/clusters/cloud_providers/cloud_provider_selector'
- else - else
.tab-pane{ id: 'create-cluster-pane', class: active_when(active_tab == 'create'), role: 'tabpanel' } .tab-pane{ id: 'create-cluster-pane', class: active_when(active_tab == 'create'), role: 'tabpanel' }
= render 'clusters/clusters/gcp/header' = render new_cluster_partial(provider: 'gcp')
- if @valid_gcp_token
= render 'clusters/clusters/gcp/form'
- elsif @authorize_url
= render 'clusters/clusters/gcp/signin_with_google_button'
- else
= render 'clusters/clusters/gcp/gcp_not_configured'
.tab-pane{ id: 'add-cluster-pane', class: active_when(active_tab == 'add'), role: 'tabpanel' } .tab-pane{ id: 'add-cluster-pane', class: active_when(active_tab == 'add'), role: 'tabpanel' }
= render 'clusters/clusters/user/header' = render 'clusters/clusters/user/header'
......
...@@ -73,7 +73,7 @@ describe Admin::ClustersController do ...@@ -73,7 +73,7 @@ describe Admin::ClustersController do
end end
describe 'GET #new' do describe 'GET #new' do
def get_new(provider: 'gke') def get_new(provider: 'gcp')
get :new, params: { provider: provider } get :new, params: { provider: provider }
end end
......
...@@ -85,7 +85,7 @@ describe Groups::ClustersController do ...@@ -85,7 +85,7 @@ describe Groups::ClustersController do
end end
describe 'GET new' do describe 'GET new' do
def go(provider: 'gke') def go(provider: 'gcp')
get :new, params: { group_id: group, provider: provider } get :new, params: { group_id: group, provider: provider }
end end
......
...@@ -79,7 +79,7 @@ describe Projects::ClustersController do ...@@ -79,7 +79,7 @@ describe Projects::ClustersController do
end end
describe 'GET new' do describe 'GET new' do
def go(provider: 'gke') def go(provider: 'gcp')
get :new, params: { get :new, params: {
namespace_id: project.namespace, namespace_id: project.namespace,
project_id: project, project_id: project,
......
...@@ -30,4 +30,60 @@ describe ClustersHelper do ...@@ -30,4 +30,60 @@ describe ClustersHelper do
end end
end end
end end
describe '#create_new_cluster_label' do
subject { helper.create_new_cluster_label(provider: provider) }
context 'GCP provider' do
let(:provider) { 'gcp' }
it { is_expected.to eq('Create new Cluster on GKE') }
end
context 'AWS provider' do
let(:provider) { 'aws' }
it { is_expected.to eq('Create new Cluster on EKS') }
end
context 'other provider' do
let(:provider) { 'other' }
it { is_expected.to eq('Create new Cluster') }
end
context 'no provider' do
let(:provider) { nil }
it { is_expected.to eq('Create new Cluster') }
end
end
describe '#render_new_provider_form' do
subject { helper.new_cluster_partial(provider: provider) }
context 'GCP provider' do
let(:provider) { 'gcp' }
it { is_expected.to eq('clusters/clusters/gcp/new') }
end
context 'AWS provider' do
let(:provider) { 'aws' }
it { is_expected.to eq('clusters/clusters/aws/new') }
end
context 'other provider' do
let(:provider) { 'other' }
it { is_expected.to eq('clusters/clusters/cloud_providers/cloud_provider_selector') }
end
context 'no provider' do
let(:provider) { nil }
it { is_expected.to eq('clusters/clusters/cloud_providers/cloud_provider_selector') }
end
end
end end
...@@ -33,7 +33,7 @@ describe Aws::Role do ...@@ -33,7 +33,7 @@ describe Aws::Role do
end end
describe 'callbacks' do describe 'callbacks' do
describe '#ensure_role_external_id' do describe '#ensure_role_external_id!' do
subject { role.validate } subject { role.validate }
context 'for a new record' do context 'for a new record' do
......
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