Commit e4db99f3 authored by Emily Ring's avatar Emily Ring Committed by Enrique Alcántara

Remove default EKS Region Dropdown in cluster form

Replace dropdown with input field for EKS Regions
Update authorize_role_service to authenticate with customer region
parent e45f69f5
<script> <script>
import { createNamespacedHelpers, mapState, mapActions, mapGetters } from 'vuex'; import { createNamespacedHelpers, mapState, mapActions, mapGetters } from 'vuex';
import { GlFormInput, GlFormCheckbox, GlIcon, GlLink, GlSprintf } from '@gitlab/ui'; import { GlFormGroup, GlFormInput, GlFormCheckbox, GlIcon, GlLink, GlSprintf } from '@gitlab/ui';
import { s__ } from '~/locale'; import { s__ } from '~/locale';
import ClusterFormDropdown from '~/create_cluster/components/cluster_form_dropdown.vue'; import ClusterFormDropdown from '~/create_cluster/components/cluster_form_dropdown.vue';
import { KUBERNETES_VERSIONS } from '../constants'; import { KUBERNETES_VERSIONS } from '../constants';
import LoadingButton from '~/vue_shared/components/loading_button.vue'; import LoadingButton from '~/vue_shared/components/loading_button.vue';
const { mapState: mapRolesState, mapActions: mapRolesActions } = createNamespacedHelpers('roles'); const { mapState: mapRolesState, mapActions: mapRolesActions } = createNamespacedHelpers('roles');
const { mapState: mapRegionsState, mapActions: mapRegionsActions } = createNamespacedHelpers(
'regions',
);
const { mapState: mapKeyPairsState, mapActions: mapKeyPairsActions } = createNamespacedHelpers( const { mapState: mapKeyPairsState, mapActions: mapKeyPairsActions } = createNamespacedHelpers(
'keyPairs', 'keyPairs',
); );
...@@ -27,6 +24,7 @@ export default { ...@@ -27,6 +24,7 @@ export default {
components: { components: {
ClusterFormDropdown, ClusterFormDropdown,
GlFormCheckbox, GlFormCheckbox,
GlFormGroup,
GlFormInput, GlFormInput,
GlIcon, GlIcon,
GlLink, GlLink,
...@@ -60,11 +58,10 @@ export default { ...@@ -60,11 +58,10 @@ export default {
), ),
roleDropdownHelpPath: roleDropdownHelpPath:
'https://docs.aws.amazon.com/eks/latest/userguide/service_IAM_role.html#create-service-role', 'https://docs.aws.amazon.com/eks/latest/userguide/service_IAM_role.html#create-service-role',
regionsDropdownHelpText: s__( regionInputLabel: s__('ClusterIntegration|Cluster Region'),
'ClusterIntegration|Learn more about %{linkStart}Regions%{linkEnd}.', regionHelpText: s__(
'ClusterIntegration|The region the new cluster will be created in. You must reauthenticate to change regions.',
), ),
regionsDropdownHelpPath:
'https://aws.amazon.com/about-aws/global-infrastructure/regional-product-services/',
keyPairDropdownHelpText: s__( keyPairDropdownHelpText: s__(
'ClusterIntegration|Select the key pair name that will be used to create EC2 nodes. To use a new key pair name, first create one on %{linkStart}Amazon Web Services%{linkEnd}.', 'ClusterIntegration|Select the key pair name that will be used to create EC2 nodes. To use a new key pair name, first create one on %{linkStart}Amazon Web Services%{linkEnd}.',
), ),
...@@ -117,11 +114,6 @@ export default { ...@@ -117,11 +114,6 @@ export default {
isLoadingRoles: 'isLoadingItems', isLoadingRoles: 'isLoadingItems',
loadingRolesError: 'loadingItemsError', loadingRolesError: 'loadingItemsError',
}), }),
...mapRegionsState({
regions: 'items',
isLoadingRegions: 'isLoadingItems',
loadingRegionsError: 'loadingItemsError',
}),
...mapKeyPairsState({ ...mapKeyPairsState({
keyPairs: 'items', keyPairs: 'items',
isLoadingKeyPairs: 'isLoadingItems', isLoadingKeyPairs: 'isLoadingItems',
...@@ -195,8 +187,8 @@ export default { ...@@ -195,8 +187,8 @@ export default {
}, },
}, },
mounted() { mounted() {
this.fetchRegions();
this.fetchRoles(); this.fetchRoles();
this.setRegionAndFetchVpcsAndKeyPairs();
}, },
methods: { methods: {
...mapActions([ ...mapActions([
...@@ -215,20 +207,18 @@ export default { ...@@ -215,20 +207,18 @@ export default {
'setGitlabManagedCluster', 'setGitlabManagedCluster',
'setNamespacePerEnvironment', 'setNamespacePerEnvironment',
]), ]),
...mapRegionsActions({ fetchRegions: 'fetchItems' }),
...mapVpcActions({ fetchVpcs: 'fetchItems' }), ...mapVpcActions({ fetchVpcs: 'fetchItems' }),
...mapSubnetActions({ fetchSubnets: 'fetchItems' }), ...mapSubnetActions({ fetchSubnets: 'fetchItems' }),
...mapRolesActions({ fetchRoles: 'fetchItems' }), ...mapRolesActions({ fetchRoles: 'fetchItems' }),
...mapKeyPairsActions({ fetchKeyPairs: 'fetchItems' }), ...mapKeyPairsActions({ fetchKeyPairs: 'fetchItems' }),
...mapSecurityGroupsActions({ fetchSecurityGroups: 'fetchItems' }), ...mapSecurityGroupsActions({ fetchSecurityGroups: 'fetchItems' }),
setRegionAndFetchVpcsAndKeyPairs(region) { setRegionAndFetchVpcsAndKeyPairs() {
this.setRegion({ region });
this.setVpc({ vpc: null }); this.setVpc({ vpc: null });
this.setKeyPair({ keyPair: null }); this.setKeyPair({ keyPair: null });
this.setSubnet({ subnet: [] }); this.setSubnet({ subnet: [] });
this.setSecurityGroup({ securityGroup: null }); this.setSecurityGroup({ securityGroup: null });
this.fetchVpcs({ region }); this.fetchVpcs({ region: this.selectedRegion });
this.fetchKeyPairs({ region }); this.fetchKeyPairs({ region: this.selectedRegion });
}, },
setVpcAndFetchSubnets(vpc) { setVpcAndFetchSubnets(vpc) {
this.setVpc({ vpc }); this.setVpc({ vpc });
...@@ -314,33 +304,12 @@ export default { ...@@ -314,33 +304,12 @@ export default {
</gl-sprintf> </gl-sprintf>
</p> </p>
</div> </div>
<div class="form-group"> <gl-form-group
<label class="label-bold" for="eks-role">{{ s__('ClusterIntegration|Region') }}</label> :label="$options.i18n.regionInputLabel"
<cluster-form-dropdown :description="$options.i18n.regionHelpText"
field-id="eks-region" >
field-name="eks-region" <gl-form-input id="eks-region" :value="selectedRegion" type="text" readonly />
:value="selectedRegion" </gl-form-group>
:items="regions"
:loading="isLoadingRegions"
:loading-text="s__('ClusterIntegration|Loading Regions')"
:placeholder="s__('ClusterIntergation|Select a region')"
:search-field-placeholder="s__('ClusterIntegration|Search regions')"
:empty-text="s__('ClusterIntegration|No region found')"
:has-errors="Boolean(loadingRegionsError)"
:error-message="s__('ClusterIntegration|Could not load regions from your AWS account')"
@input="setRegionAndFetchVpcsAndKeyPairs($event)"
/>
<p class="form-text text-muted">
<gl-sprintf :message="$options.i18n.regionsDropdownHelpText">
<template #link="{ content }">
<gl-link :href="$options.i18n.regionsDropdownHelpPath" target="_blank">
{{ content }}
<gl-icon name="external-link" class="gl-vertical-align-middle" />
</gl-link>
</template>
</gl-sprintf>
</p>
</div>
<div class="form-group"> <div class="form-group">
<label class="label-bold" for="eks-key-pair">{{ <label class="label-bold" for="eks-key-pair">{{
s__('ClusterIntegration|Key pair name') s__('ClusterIntegration|Key pair name')
......
<script> <script>
/* eslint-disable vue/no-v-html */ /* eslint-disable vue/no-v-html */
import { GlFormInput, GlButton } from '@gitlab/ui'; import { GlButton, GlFormGroup, GlFormInput, GlIcon, GlLink, GlSprintf } from '@gitlab/ui';
import { escape } from 'lodash'; import { escape } from 'lodash';
import { mapState, mapActions } from 'vuex'; import { mapState, mapActions } from 'vuex';
import { DEFAULT_REGION } from '../constants';
import { sprintf, s__, __ } from '~/locale'; import { sprintf, s__, __ } from '~/locale';
import ClipboardButton from '~/vue_shared/components/clipboard_button.vue'; import ClipboardButton from '~/vue_shared/components/clipboard_button.vue';
export default { export default {
components: { components: {
GlFormInput,
GlButton, GlButton,
GlFormGroup,
GlFormInput,
GlIcon,
GlLink,
GlSprintf,
ClipboardButton, ClipboardButton,
}, },
props: { props: {
...@@ -26,9 +31,18 @@ export default { ...@@ -26,9 +31,18 @@ export default {
required: true, required: true,
}, },
}, },
i18n: {
regionInputLabel: s__('ClusterIntegration|Cluster Region'),
regionHelpPath: 'https://aws.amazon.com/about-aws/global-infrastructure/regions_az/',
regionHelpText: s__(
'ClusterIntegration|Select the region you want to create the new cluster in. Make sure you have access to this region for your role to be able to authenticate. If no region is selected, we will use %{codeStart}DEFAULT_REGION%{codeEnd}. Learn more about %{linkStart}Regions%{linkEnd}.',
),
regionHelpTextDefaultRegion: DEFAULT_REGION,
},
data() { data() {
return { return {
roleArn: this.$store.state.roleArn, roleArn: this.$store.state.roleArn,
selectedRegion: this.$store.state.selectedRegion,
}; };
}, },
computed: { computed: {
...@@ -130,13 +144,33 @@ export default { ...@@ -130,13 +144,33 @@ export default {
<gl-form-input id="eks-provision-role-arn" v-model="roleArn" /> <gl-form-input id="eks-provision-role-arn" v-model="roleArn" />
<p class="form-text text-muted" v-html="provisionRoleArnHelpText"></p> <p class="form-text text-muted" v-html="provisionRoleArnHelpText"></p>
</div> </div>
<gl-form-group :label="$options.i18n.regionInputLabel">
<gl-form-input id="eks-region" v-model="selectedRegion" type="text" />
<template #description>
<gl-sprintf :message="$options.i18n.regionHelpText">
<template #code>
<code>{{ $options.i18n.regionHelpTextDefaultRegion }}</code>
</template>
<template #link="{ content }">
<gl-link :href="$options.i18n.regionHelpPath" target="_blank">
{{ content }}
<gl-icon name="external-link" />
</gl-link>
</template>
</gl-sprintf>
</template>
</gl-form-group>
<gl-button <gl-button
variant="success" variant="success"
category="primary" category="primary"
type="submit" type="submit"
:disabled="submitButtonDisabled" :disabled="submitButtonDisabled"
:loading="isCreatingRole" :loading="isCreatingRole"
@click.prevent="createRole({ roleArn, externalId })" @click.prevent="createRole({ roleArn, selectedRegion, externalId })"
> >
{{ submitButtonLabel }} {{ submitButtonLabel }}
</gl-button> </gl-button>
......
export const DEFAULT_REGION = 'us-east-2';
export const KUBERNETES_VERSIONS = [ export const KUBERNETES_VERSIONS = [
{ name: '1.14', value: '1.14' }, { name: '1.14', value: '1.14' },
{ name: '1.15', value: '1.15' }, { name: '1.15', value: '1.15' },
......
...@@ -8,13 +8,8 @@ const lookupVpcName = ({ Tags: tags, VpcId: id }) => { ...@@ -8,13 +8,8 @@ const lookupVpcName = ({ Tags: tags, VpcId: id }) => {
return nameTag ? nameTag.Value : id; return nameTag ? nameTag.Value : id;
}; };
export const DEFAULT_REGION = 'us-east-2';
export const setAWSConfig = ({ awsCredentials }) => { export const setAWSConfig = ({ awsCredentials }) => {
AWS.config = { AWS.config = awsCredentials;
...awsCredentials,
region: DEFAULT_REGION,
};
}; };
export const fetchRoles = () => { export const fetchRoles = () => {
...@@ -26,20 +21,6 @@ export const fetchRoles = () => { ...@@ -26,20 +21,6 @@ export const fetchRoles = () => {
.then(({ Roles: roles }) => roles.map(({ RoleName: name, Arn: value }) => ({ name, value }))); .then(({ Roles: roles }) => roles.map(({ RoleName: name, Arn: value }) => ({ name, value })));
}; };
export const fetchRegions = () => {
const ec2 = new EC2();
return ec2
.describeRegions()
.promise()
.then(({ Regions: regions }) =>
regions.map(({ RegionName: name }) => ({
name,
value: name,
})),
);
};
export const fetchKeyPairs = ({ region }) => { export const fetchKeyPairs = ({ region }) => {
const ec2 = new EC2({ region }); const ec2 = new EC2({ region });
......
import * as types from './mutation_types'; import * as types from './mutation_types';
import { DEFAULT_REGION } from '../constants';
import { setAWSConfig } from '../services/aws_services_facade'; import { setAWSConfig } from '../services/aws_services_facade';
import axios from '~/lib/utils/axios_utils'; import axios from '~/lib/utils/axios_utils';
import { deprecatedCreateFlash as createFlash } from '~/flash'; import { deprecatedCreateFlash as createFlash } from '~/flash';
...@@ -25,12 +26,22 @@ export const setKubernetesVersion = ({ commit }, payload) => { ...@@ -25,12 +26,22 @@ export const setKubernetesVersion = ({ commit }, payload) => {
export const createRole = ({ dispatch, state: { createRolePath } }, payload) => { export const createRole = ({ dispatch, state: { createRolePath } }, payload) => {
dispatch('requestCreateRole'); dispatch('requestCreateRole');
const region = payload.selectedRegion || DEFAULT_REGION;
return axios return axios
.post(createRolePath, { .post(createRolePath, {
role_arn: payload.roleArn, role_arn: payload.roleArn,
role_external_id: payload.externalId, role_external_id: payload.externalId,
region,
})
.then(({ data }) => {
const awsData = {
...convertObjectPropsToCamelCase(data),
region,
};
dispatch('createRoleSuccess', awsData);
}) })
.then(({ data }) => dispatch('createRoleSuccess', convertObjectPropsToCamelCase(data)))
.catch(error => dispatch('createRoleError', { error })); .catch(error => dispatch('createRoleError', { error }));
}; };
...@@ -38,7 +49,8 @@ export const requestCreateRole = ({ commit }) => { ...@@ -38,7 +49,8 @@ export const requestCreateRole = ({ commit }) => {
commit(types.REQUEST_CREATE_ROLE); commit(types.REQUEST_CREATE_ROLE);
}; };
export const createRoleSuccess = ({ commit }, awsCredentials) => { export const createRoleSuccess = ({ dispatch, commit }, awsCredentials) => {
dispatch('setRegion', { region: awsCredentials.region });
setAWSConfig({ awsCredentials }); setAWSConfig({ awsCredentials });
commit(types.CREATE_ROLE_SUCCESS); commit(types.CREATE_ROLE_SUCCESS);
}; };
......
...@@ -8,7 +8,6 @@ import clusterDropdownStore from '~/create_cluster/store/cluster_dropdown'; ...@@ -8,7 +8,6 @@ import clusterDropdownStore from '~/create_cluster/store/cluster_dropdown';
import { import {
fetchRoles, fetchRoles,
fetchRegions,
fetchKeyPairs, fetchKeyPairs,
fetchVpcs, fetchVpcs,
fetchSubnets, fetchSubnets,
...@@ -26,10 +25,6 @@ const createStore = ({ initialState }) => ...@@ -26,10 +25,6 @@ const createStore = ({ initialState }) =>
namespaced: true, namespaced: true,
...clusterDropdownStore({ fetchFn: fetchRoles }), ...clusterDropdownStore({ fetchFn: fetchRoles }),
}, },
regions: {
namespaced: true,
...clusterDropdownStore({ fetchFn: fetchRegions }),
},
keyPairs: { keyPairs: {
namespaced: true, namespaced: true,
...clusterDropdownStore({ fetchFn: fetchKeyPairs }), ...clusterDropdownStore({ fetchFn: fetchKeyPairs }),
......
...@@ -272,7 +272,7 @@ class Clusters::ClustersController < Clusters::BaseController ...@@ -272,7 +272,7 @@ class Clusters::ClustersController < Clusters::BaseController
end end
def aws_role_params def aws_role_params
params.require(:cluster).permit(:role_arn) params.require(:cluster).permit(:role_arn, :region)
end end
def generate_gcp_authorize_url def generate_gcp_authorize_url
......
...@@ -17,7 +17,8 @@ module Clusters ...@@ -17,7 +17,8 @@ module Clusters
def initialize(user, params:) def initialize(user, params:)
@user = user @user = user
@params = params @role_arn = params[:role_arn]
@region = params[:region]
end end
def execute def execute
...@@ -33,18 +34,18 @@ module Clusters ...@@ -33,18 +34,18 @@ module Clusters
private private
attr_reader :role, :params attr_reader :role, :role_arn, :region
def ensure_role_exists! def ensure_role_exists!
@role = ::Aws::Role.find_by_user_id!(user.id) @role = ::Aws::Role.find_by_user_id!(user.id)
end end
def update_role_arn! def update_role_arn!
role.update!(params) role.update!(role_arn: role_arn)
end end
def credentials def credentials
Clusters::Aws::FetchCredentialsService.new(role).execute Clusters::Aws::FetchCredentialsService.new(role, region: region).execute
end end
end end
end end
......
...@@ -7,9 +7,10 @@ module Clusters ...@@ -7,9 +7,10 @@ module Clusters
MissingRoleError = Class.new(StandardError) MissingRoleError = Class.new(StandardError)
def initialize(provision_role, provider: nil) def initialize(provision_role, provider: nil, region: nil)
@provision_role = provision_role @provision_role = provision_role
@provider = provider @provider = provider
@region = provider&.region || region
end end
def execute def execute
...@@ -26,7 +27,7 @@ module Clusters ...@@ -26,7 +27,7 @@ module Clusters
private private
attr_reader :provider attr_reader :provider, :region
def client def client
::Aws::STS::Client.new(credentials: gitlab_credentials, region: region) ::Aws::STS::Client.new(credentials: gitlab_credentials, region: region)
...@@ -44,10 +45,6 @@ module Clusters ...@@ -44,10 +45,6 @@ module Clusters
Gitlab::CurrentSettings.eks_secret_access_key Gitlab::CurrentSettings.eks_secret_access_key
end end
def region
provider&.region || Clusters::Providers::Aws::DEFAULT_REGION
end
## ##
# If we haven't created a provider record yet, # If we haven't created a provider record yet,
# we restrict ourselves to read only access so # we restrict ourselves to read only access so
......
---
title: Remove default EKS Region dropdown in cluster create form
merge_request: 43017
author:
type: fixed
...@@ -5687,6 +5687,9 @@ msgstr "" ...@@ -5687,6 +5687,9 @@ msgstr ""
msgid "ClusterIntegration|Clear the local cache of namespace and service accounts." msgid "ClusterIntegration|Clear the local cache of namespace and service accounts."
msgstr "" msgstr ""
msgid "ClusterIntegration|Cluster Region"
msgstr ""
msgid "ClusterIntegration|Cluster management project (alpha)" msgid "ClusterIntegration|Cluster management project (alpha)"
msgstr "" msgstr ""
...@@ -5744,9 +5747,6 @@ msgstr "" ...@@ -5744,9 +5747,6 @@ msgstr ""
msgid "ClusterIntegration|Could not load networks" msgid "ClusterIntegration|Could not load networks"
msgstr "" msgstr ""
msgid "ClusterIntegration|Could not load regions from your AWS account"
msgstr ""
msgid "ClusterIntegration|Could not load security groups for the selected VPC" msgid "ClusterIntegration|Could not load security groups for the selected VPC"
msgstr "" msgstr ""
...@@ -6002,9 +6002,6 @@ msgstr "" ...@@ -6002,9 +6002,6 @@ msgstr ""
msgid "ClusterIntegration|Learn more about %{help_link_start}zones%{help_link_end}." msgid "ClusterIntegration|Learn more about %{help_link_start}zones%{help_link_end}."
msgstr "" msgstr ""
msgid "ClusterIntegration|Learn more about %{linkStart}Regions%{linkEnd}."
msgstr ""
msgid "ClusterIntegration|Learn more about Kubernetes" msgid "ClusterIntegration|Learn more about Kubernetes"
msgstr "" msgstr ""
...@@ -6020,9 +6017,6 @@ msgstr "" ...@@ -6020,9 +6017,6 @@ msgstr ""
msgid "ClusterIntegration|Loading Key Pairs" msgid "ClusterIntegration|Loading Key Pairs"
msgstr "" msgstr ""
msgid "ClusterIntegration|Loading Regions"
msgstr ""
msgid "ClusterIntegration|Loading VPCs" msgid "ClusterIntegration|Loading VPCs"
msgstr "" msgstr ""
...@@ -6089,9 +6083,6 @@ msgstr "" ...@@ -6089,9 +6083,6 @@ msgstr ""
msgid "ClusterIntegration|No projects matched your search" msgid "ClusterIntegration|No projects matched your search"
msgstr "" msgstr ""
msgid "ClusterIntegration|No region found"
msgstr ""
msgid "ClusterIntegration|No security group found" msgid "ClusterIntegration|No security group found"
msgstr "" msgstr ""
...@@ -6158,9 +6149,6 @@ msgstr "" ...@@ -6158,9 +6149,6 @@ msgstr ""
msgid "ClusterIntegration|Real-time web application monitoring, logging and access control. %{linkStart}More information%{linkEnd}" msgid "ClusterIntegration|Real-time web application monitoring, logging and access control. %{linkStart}More information%{linkEnd}"
msgstr "" msgstr ""
msgid "ClusterIntegration|Region"
msgstr ""
msgid "ClusterIntegration|Remove Kubernetes cluster integration" msgid "ClusterIntegration|Remove Kubernetes cluster integration"
msgstr "" msgstr ""
...@@ -6227,9 +6215,6 @@ msgstr "" ...@@ -6227,9 +6215,6 @@ msgstr ""
msgid "ClusterIntegration|Search projects" msgid "ClusterIntegration|Search projects"
msgstr "" msgstr ""
msgid "ClusterIntegration|Search regions"
msgstr ""
msgid "ClusterIntegration|Search security groups" msgid "ClusterIntegration|Search security groups"
msgstr "" msgstr ""
...@@ -6290,6 +6275,9 @@ msgstr "" ...@@ -6290,6 +6275,9 @@ msgstr ""
msgid "ClusterIntegration|Select the key pair name that will be used to create EC2 nodes. To use a new key pair name, first create one on %{linkStart}Amazon Web Services%{linkEnd}." msgid "ClusterIntegration|Select the key pair name that will be used to create EC2 nodes. To use a new key pair name, first create one on %{linkStart}Amazon Web Services%{linkEnd}."
msgstr "" msgstr ""
msgid "ClusterIntegration|Select the region you want to create the new cluster in. Make sure you have access to this region for your role to be able to authenticate. If no region is selected, we will use %{codeStart}DEFAULT_REGION%{codeEnd}. Learn more about %{linkStart}Regions%{linkEnd}."
msgstr ""
msgid "ClusterIntegration|Select zone" msgid "ClusterIntegration|Select zone"
msgstr "" msgstr ""
...@@ -6374,6 +6362,9 @@ msgstr "" ...@@ -6374,6 +6362,9 @@ msgstr ""
msgid "ClusterIntegration|The namespace associated with your project. This will be used for deploy boards, logs, and Web terminals." msgid "ClusterIntegration|The namespace associated with your project. This will be used for deploy boards, logs, and Web terminals."
msgstr "" msgstr ""
msgid "ClusterIntegration|The region the new cluster will be created in. You must reauthenticate to change regions."
msgstr ""
msgid "ClusterIntegration|There was a problem authenticating with your cluster. Please ensure your CA Certificate and Token are valid." msgid "ClusterIntegration|There was a problem authenticating with your cluster. Please ensure your CA Certificate and Token are valid."
msgstr "" msgstr ""
...@@ -6515,9 +6506,6 @@ msgstr "" ...@@ -6515,9 +6506,6 @@ msgstr ""
msgid "ClusterIntergation|Select a network" msgid "ClusterIntergation|Select a network"
msgstr "" msgstr ""
msgid "ClusterIntergation|Select a region"
msgstr ""
msgid "ClusterIntergation|Select a security group" msgid "ClusterIntergation|Select a security group"
msgstr "" msgstr ""
......
...@@ -16,7 +16,6 @@ describe('EksClusterConfigurationForm', () => { ...@@ -16,7 +16,6 @@ describe('EksClusterConfigurationForm', () => {
let getters; let getters;
let state; let state;
let rolesState; let rolesState;
let regionsState;
let vpcsState; let vpcsState;
let subnetsState; let subnetsState;
let keyPairsState; let keyPairsState;
...@@ -24,7 +23,6 @@ describe('EksClusterConfigurationForm', () => { ...@@ -24,7 +23,6 @@ describe('EksClusterConfigurationForm', () => {
let instanceTypesState; let instanceTypesState;
let vpcsActions; let vpcsActions;
let rolesActions; let rolesActions;
let regionsActions;
let subnetsActions; let subnetsActions;
let keyPairsActions; let keyPairsActions;
let securityGroupsActions; let securityGroupsActions;
...@@ -46,9 +44,6 @@ describe('EksClusterConfigurationForm', () => { ...@@ -46,9 +44,6 @@ describe('EksClusterConfigurationForm', () => {
setNodeCount: jest.fn(), setNodeCount: jest.fn(),
setGitlabManagedCluster: jest.fn(), setGitlabManagedCluster: jest.fn(),
}; };
regionsActions = {
fetchItems: jest.fn(),
};
keyPairsActions = { keyPairsActions = {
fetchItems: jest.fn(), fetchItems: jest.fn(),
}; };
...@@ -72,10 +67,6 @@ describe('EksClusterConfigurationForm', () => { ...@@ -72,10 +67,6 @@ describe('EksClusterConfigurationForm', () => {
...clusterDropdownStoreState(), ...clusterDropdownStoreState(),
...config.rolesState, ...config.rolesState,
}; };
regionsState = {
...clusterDropdownStoreState(),
...config.regionsState,
};
vpcsState = { vpcsState = {
...clusterDropdownStoreState(), ...clusterDropdownStoreState(),
...config.vpcsState, ...config.vpcsState,
...@@ -109,11 +100,6 @@ describe('EksClusterConfigurationForm', () => { ...@@ -109,11 +100,6 @@ describe('EksClusterConfigurationForm', () => {
state: vpcsState, state: vpcsState,
actions: vpcsActions, actions: vpcsActions,
}, },
regions: {
namespaced: true,
state: regionsState,
actions: regionsActions,
},
subnets: { subnets: {
namespaced: true, namespaced: true,
state: subnetsState, state: subnetsState,
...@@ -189,7 +175,6 @@ describe('EksClusterConfigurationForm', () => { ...@@ -189,7 +175,6 @@ describe('EksClusterConfigurationForm', () => {
const findClusterNameInput = () => vm.find('[id=eks-cluster-name]'); const findClusterNameInput = () => vm.find('[id=eks-cluster-name]');
const findEnvironmentScopeInput = () => vm.find('[id=eks-environment-scope]'); const findEnvironmentScopeInput = () => vm.find('[id=eks-environment-scope]');
const findKubernetesVersionDropdown = () => vm.find('[field-id="eks-kubernetes-version"]'); const findKubernetesVersionDropdown = () => vm.find('[field-id="eks-kubernetes-version"]');
const findRegionDropdown = () => vm.find('[field-id="eks-region"]');
const findKeyPairDropdown = () => vm.find('[field-id="eks-key-pair"]'); const findKeyPairDropdown = () => vm.find('[field-id="eks-key-pair"]');
const findVpcDropdown = () => vm.find('[field-id="eks-vpc"]'); const findVpcDropdown = () => vm.find('[field-id="eks-vpc"]');
const findSubnetDropdown = () => vm.find('[field-id="eks-subnet"]'); const findSubnetDropdown = () => vm.find('[field-id="eks-subnet"]');
...@@ -200,52 +185,63 @@ describe('EksClusterConfigurationForm', () => { ...@@ -200,52 +185,63 @@ describe('EksClusterConfigurationForm', () => {
const findGitlabManagedClusterCheckbox = () => vm.find(GlFormCheckbox); const findGitlabManagedClusterCheckbox = () => vm.find(GlFormCheckbox);
describe('when mounted', () => { describe('when mounted', () => {
it('fetches available regions', () => {
expect(regionsActions.fetchItems).toHaveBeenCalled();
});
it('fetches available roles', () => { it('fetches available roles', () => {
expect(rolesActions.fetchItems).toHaveBeenCalled(); expect(rolesActions.fetchItems).toHaveBeenCalled();
}); });
describe('when fetching vpcs and key pairs', () => {
const region = 'us-west-2';
beforeEach(() => {
createValidStateStore({ selectedRegion: region });
buildWrapper();
}); });
it('sets isLoadingRoles to RoleDropdown loading property', () => { it('fetches available vpcs', () => {
rolesState.isLoadingItems = true; expect(vpcsActions.fetchItems).toHaveBeenCalledWith(expect.anything(), { region });
});
return Vue.nextTick().then(() => { it('fetches available key pairs', () => {
expect(findRoleDropdown().props('loading')).toBe(rolesState.isLoadingItems); expect(keyPairsActions.fetchItems).toHaveBeenCalledWith(expect.anything(), { region });
}); });
it('cleans selected vpc', () => {
expect(actions.setVpc).toHaveBeenCalledWith(expect.anything(), { vpc: null });
}); });
it('sets roles to RoleDropdown items property', () => { it('cleans selected key pair', () => {
expect(findRoleDropdown().props('items')).toBe(rolesState.items); expect(actions.setKeyPair).toHaveBeenCalledWith(expect.anything(), { keyPair: null });
}); });
it('sets RoleDropdown hasErrors to true when loading roles failed', () => { it('cleans selected subnet', () => {
rolesState.loadingItemsError = new Error(); expect(actions.setSubnet).toHaveBeenCalledWith(expect.anything(), { subnet: [] });
});
return Vue.nextTick().then(() => { it('cleans selected security group', () => {
expect(findRoleDropdown().props('hasErrors')).toEqual(true); expect(actions.setSecurityGroup).toHaveBeenCalledWith(expect.anything(), {
securityGroup: null,
});
});
}); });
}); });
it('sets isLoadingRegions to RegionDropdown loading property', () => { it('sets isLoadingRoles to RoleDropdown loading property', () => {
regionsState.isLoadingItems = true; rolesState.isLoadingItems = true;
return Vue.nextTick().then(() => { return Vue.nextTick().then(() => {
expect(findRegionDropdown().props('loading')).toBe(regionsState.isLoadingItems); expect(findRoleDropdown().props('loading')).toBe(rolesState.isLoadingItems);
}); });
}); });
it('sets regions to RegionDropdown regions property', () => { it('sets roles to RoleDropdown items property', () => {
expect(findRegionDropdown().props('items')).toBe(regionsState.items); expect(findRoleDropdown().props('items')).toBe(rolesState.items);
}); });
it('sets loadingRegionsError to RegionDropdown error property', () => { it('sets RoleDropdown hasErrors to true when loading roles failed', () => {
regionsState.loadingItemsError = new Error(); rolesState.loadingItemsError = new Error();
return Vue.nextTick().then(() => { return Vue.nextTick().then(() => {
expect(findRegionDropdown().props('hasErrors')).toEqual(true); expect(findRoleDropdown().props('hasErrors')).toEqual(true);
}); });
}); });
...@@ -394,44 +390,6 @@ describe('EksClusterConfigurationForm', () => { ...@@ -394,44 +390,6 @@ describe('EksClusterConfigurationForm', () => {
}); });
}); });
describe('when region is selected', () => {
const region = { name: 'us-west-2' };
beforeEach(() => {
findRegionDropdown().vm.$emit('input', region);
});
it('dispatches setRegion action', () => {
expect(actions.setRegion).toHaveBeenCalledWith(expect.anything(), { region });
});
it('fetches available vpcs', () => {
expect(vpcsActions.fetchItems).toHaveBeenCalledWith(expect.anything(), { region });
});
it('fetches available key pairs', () => {
expect(keyPairsActions.fetchItems).toHaveBeenCalledWith(expect.anything(), { region });
});
it('cleans selected vpc', () => {
expect(actions.setVpc).toHaveBeenCalledWith(expect.anything(), { vpc: null });
});
it('cleans selected key pair', () => {
expect(actions.setKeyPair).toHaveBeenCalledWith(expect.anything(), { keyPair: null });
});
it('cleans selected subnet', () => {
expect(actions.setSubnet).toHaveBeenCalledWith(expect.anything(), { subnet: [] });
});
it('cleans selected security group', () => {
expect(actions.setSecurityGroup).toHaveBeenCalledWith(expect.anything(), {
securityGroup: null,
});
});
});
it('dispatches setClusterName when cluster name input changes', () => { it('dispatches setClusterName when cluster name input changes', () => {
const clusterName = 'name'; const clusterName = 'name';
......
...@@ -3,12 +3,10 @@ import EC2 from 'aws-sdk/clients/ec2'; ...@@ -3,12 +3,10 @@ import EC2 from 'aws-sdk/clients/ec2';
import { import {
setAWSConfig, setAWSConfig,
fetchRoles, fetchRoles,
fetchRegions,
fetchKeyPairs, fetchKeyPairs,
fetchVpcs, fetchVpcs,
fetchSubnets, fetchSubnets,
fetchSecurityGroups, fetchSecurityGroups,
DEFAULT_REGION,
} from '~/create_cluster/eks_cluster/services/aws_services_facade'; } from '~/create_cluster/eks_cluster/services/aws_services_facade';
const mockListRolesPromise = jest.fn(); const mockListRolesPromise = jest.fn();
...@@ -45,19 +43,17 @@ describe('awsServicesFacade', () => { ...@@ -45,19 +43,17 @@ describe('awsServicesFacade', () => {
vpc = 'vpc-2'; vpc = 'vpc-2';
}); });
it('setAWSConfig configures AWS SDK with provided credentials and default region', () => { it('setAWSConfig configures AWS SDK with provided credentials', () => {
const awsCredentials = { const awsCredentials = {
accessKeyId: 'access-key', accessKeyId: 'access-key',
secretAccessKey: 'secret-key', secretAccessKey: 'secret-key',
sessionToken: 'session-token', sessionToken: 'session-token',
region,
}; };
setAWSConfig({ awsCredentials }); setAWSConfig({ awsCredentials });
expect(AWS.config).toEqual({ expect(AWS.config).toEqual(awsCredentials);
...awsCredentials,
region: DEFAULT_REGION,
});
}); });
describe('when fetchRoles succeeds', () => { describe('when fetchRoles succeeds', () => {
...@@ -79,22 +75,6 @@ describe('awsServicesFacade', () => { ...@@ -79,22 +75,6 @@ describe('awsServicesFacade', () => {
}); });
}); });
describe('when fetchRegions succeeds', () => {
let regions;
let regionsOutput;
beforeEach(() => {
regions = [{ RegionName: 'east-1' }, { RegionName: 'west-2' }];
regionsOutput = regions.map(({ RegionName: name }) => ({ name, value: name }));
mockDescribeRegionsPromise.mockResolvedValueOnce({ Regions: regions });
});
it('return list of roles where each item has a name and value', () => {
return expect(fetchRegions()).resolves.toEqual(regionsOutput);
});
});
describe('when fetchKeyPairs succeeds', () => { describe('when fetchKeyPairs succeeds', () => {
let keyPairs; let keyPairs;
let keyPairsOutput; let keyPairsOutput;
......
...@@ -23,6 +23,7 @@ import { ...@@ -23,6 +23,7 @@ import {
REQUEST_CREATE_CLUSTER, REQUEST_CREATE_CLUSTER,
CREATE_CLUSTER_ERROR, CREATE_CLUSTER_ERROR,
} from '~/create_cluster/eks_cluster/store/mutation_types'; } from '~/create_cluster/eks_cluster/store/mutation_types';
import { DEFAULT_REGION } from '~/create_cluster/eks_cluster/constants';
import axios from '~/lib/utils/axios_utils'; import axios from '~/lib/utils/axios_utils';
import { deprecatedCreateFlash as createFlash } from '~/flash'; import { deprecatedCreateFlash as createFlash } from '~/flash';
...@@ -109,12 +110,13 @@ describe('EKS Cluster Store Actions', () => { ...@@ -109,12 +110,13 @@ describe('EKS Cluster Store Actions', () => {
secretAccessKey: 'secret-key-id', secretAccessKey: 'secret-key-id',
}; };
describe('when request succeeds', () => { describe('when request succeeds with default region', () => {
beforeEach(() => { beforeEach(() => {
mock mock
.onPost(state.createRolePath, { .onPost(state.createRolePath, {
role_arn: payload.roleArn, role_arn: payload.roleArn,
role_external_id: payload.externalId, role_external_id: payload.externalId,
region: DEFAULT_REGION,
}) })
.reply(201, response); .reply(201, response);
}); });
...@@ -125,7 +127,51 @@ describe('EKS Cluster Store Actions', () => { ...@@ -125,7 +127,51 @@ describe('EKS Cluster Store Actions', () => {
payload, payload,
state, state,
[], [],
[{ type: 'requestCreateRole' }, { type: 'createRoleSuccess', payload: response }], [
{ type: 'requestCreateRole' },
{
type: 'createRoleSuccess',
payload: {
region: DEFAULT_REGION,
...response,
},
},
],
));
});
describe('when request succeeds with custom region', () => {
const customRegion = 'custom-region';
beforeEach(() => {
mock
.onPost(state.createRolePath, {
role_arn: payload.roleArn,
role_external_id: payload.externalId,
region: customRegion,
})
.reply(201, response);
});
it('dispatches createRoleSuccess action', () =>
testAction(
actions.createRole,
{
selectedRegion: customRegion,
...payload,
},
state,
[],
[
{ type: 'requestCreateRole' },
{
type: 'createRoleSuccess',
payload: {
region: customRegion,
...response,
},
},
],
)); ));
}); });
...@@ -138,6 +184,7 @@ describe('EKS Cluster Store Actions', () => { ...@@ -138,6 +184,7 @@ describe('EKS Cluster Store Actions', () => {
.onPost(state.createRolePath, { .onPost(state.createRolePath, {
role_arn: payload.roleArn, role_arn: payload.roleArn,
role_external_id: payload.externalId, role_external_id: payload.externalId,
region: DEFAULT_REGION,
}) })
.reply(400, error); .reply(400, error);
}); });
...@@ -160,8 +207,14 @@ describe('EKS Cluster Store Actions', () => { ...@@ -160,8 +207,14 @@ describe('EKS Cluster Store Actions', () => {
}); });
describe('createRoleSuccess', () => { describe('createRoleSuccess', () => {
it('commits createRoleSuccess mutation', () => { it('sets region and commits createRoleSuccess mutation', () => {
testAction(actions.createRoleSuccess, null, state, [{ type: CREATE_ROLE_SUCCESS }]); testAction(
actions.createRoleSuccess,
{ region },
state,
[{ type: CREATE_ROLE_SUCCESS }],
[{ type: 'setRegion', payload: { region } }],
);
}); });
}); });
......
...@@ -11,19 +11,21 @@ RSpec.describe Clusters::Aws::AuthorizeRoleService do ...@@ -11,19 +11,21 @@ RSpec.describe Clusters::Aws::AuthorizeRoleService do
let(:credentials_service) { instance_double(Clusters::Aws::FetchCredentialsService, execute: credentials) } let(:credentials_service) { instance_double(Clusters::Aws::FetchCredentialsService, execute: credentials) }
let(:role_arn) { 'arn:my-role' } let(:role_arn) { 'arn:my-role' }
let(:region) { 'region' }
let(:params) do let(:params) do
params = ActionController::Parameters.new({ params = ActionController::Parameters.new({
cluster: { cluster: {
role_arn: role_arn role_arn: role_arn,
region: region
} }
}) })
params.require(:cluster).permit(:role_arn) params.require(:cluster).permit(:role_arn, :region)
end end
before do before do
allow(Clusters::Aws::FetchCredentialsService).to receive(:new) allow(Clusters::Aws::FetchCredentialsService).to receive(:new)
.with(instance_of(Aws::Role)).and_return(credentials_service) .with(instance_of(Aws::Role), region: region).and_return(credentials_service)
end end
context 'role exists' do context 'role exists' do
......
...@@ -53,10 +53,12 @@ RSpec.describe Clusters::Aws::FetchCredentialsService do ...@@ -53,10 +53,12 @@ RSpec.describe Clusters::Aws::FetchCredentialsService do
context 'provider is not specifed' do context 'provider is not specifed' do
let(:provider) { nil } let(:provider) { nil }
let(:region) { Clusters::Providers::Aws::DEFAULT_REGION } let(:region) { 'custom-region' }
let(:session_name) { "gitlab-eks-autofill-user-#{user.id}" } let(:session_name) { "gitlab-eks-autofill-user-#{user.id}" }
let(:session_policy) { 'policy-document' } let(:session_policy) { 'policy-document' }
subject { described_class.new(provision_role, provider: provider, region: region).execute }
before do before do
allow(File).to receive(:read) allow(File).to receive(:read)
.with(Rails.root.join('vendor', 'aws', 'iam', 'eks_cluster_read_only_policy.json')) .with(Rails.root.join('vendor', 'aws', 'iam', 'eks_cluster_read_only_policy.json'))
......
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