Commit 48c9a08e authored by Mike Greiling's avatar Mike Greiling

Merge branch 'eks-group-and-instance-clusters' into 'master'

Initialize EKS clusters form for instance and group level clusters

See merge request gitlab-org/gitlab!18690
parents a00e6006 36b68dd7
document.addEventListener('DOMContentLoaded', () => { import initGkeDropdowns from './gke_cluster';
import initGkeNamespace from './gke_cluster_namespace';
import PersistentUserCallout from '~/persistent_user_callout';
const newClusterViews = [':clusters:new', ':clusters:create_gcp', ':clusters:create_user'];
const isProjectLevelCluster = page => page.startsWith('project:clusters');
export default (document, gon) => {
const { page } = document.body.dataset;
const isNewClusterView = newClusterViews.some(view => page.endsWith(view));
if (!isNewClusterView) {
return;
}
const callout = document.querySelector('.gcp-signup-offer');
PersistentUserCallout.factory(callout);
initGkeDropdowns();
if (gon.features.createEksClusters) { if (gon.features.createEksClusters) {
import(/* webpackChunkName: 'eks_cluster' */ '~/create_cluster/eks_cluster') import(/* webpackChunkName: 'eks_cluster' */ '~/create_cluster/eks_cluster')
.then(({ default: initCreateEKSCluster }) => { .then(({ default: initCreateEKSCluster }) => {
...@@ -10,4 +30,8 @@ document.addEventListener('DOMContentLoaded', () => { ...@@ -10,4 +30,8 @@ document.addEventListener('DOMContentLoaded', () => {
}) })
.catch(() => {}); .catch(() => {});
} }
});
if (isProjectLevelCluster(page)) {
initGkeNamespace();
}
};
import PersistentUserCallout from '~/persistent_user_callout'; import initCreateCluster from '~/create_cluster/init_create_cluster';
import initGkeDropdowns from '~/create_cluster/gke_cluster';
function initGcpSignupCallout() {
const callout = document.querySelector('.gcp-signup-offer');
PersistentUserCallout.factory(callout);
}
document.addEventListener('DOMContentLoaded', () => { document.addEventListener('DOMContentLoaded', () => {
const { page } = document.body.dataset; initCreateCluster(document, gon);
const newClusterViews = [
'admin:clusters:new',
'admin:clusters:create_gcp',
'admin:clusters:create_user',
];
if (newClusterViews.indexOf(page) > -1) {
initGcpSignupCallout();
initGkeDropdowns();
}
}); });
import PersistentUserCallout from '~/persistent_user_callout'; import initCreateCluster from '~/create_cluster/init_create_cluster';
import initGkeDropdowns from '~/create_cluster/gke_cluster';
function initGcpSignupCallout() {
const callout = document.querySelector('.gcp-signup-offer');
PersistentUserCallout.factory(callout);
}
document.addEventListener('DOMContentLoaded', () => { document.addEventListener('DOMContentLoaded', () => {
const { page } = document.body.dataset; initCreateCluster(document, gon);
const newClusterViews = [
'groups:clusters:new',
'groups:clusters:create_gcp',
'groups:clusters:create_user',
];
if (newClusterViews.indexOf(page) > -1) {
initGcpSignupCallout();
initGkeDropdowns();
}
}); });
import ClustersBundle from '~/clusters/clusters_bundle'; import ClustersBundle from '~/clusters/clusters_bundle';
import initGkeNamespace from '~/projects/gke_cluster_namespace'; import initGkeNamespace from '~/create_cluster/gke_cluster_namespace';
document.addEventListener('DOMContentLoaded', () => { document.addEventListener('DOMContentLoaded', () => {
new ClustersBundle(); // eslint-disable-line no-new new ClustersBundle(); // eslint-disable-line no-new
......
import initGkeDropdowns from '~/create_cluster/gke_cluster';
import initGkeNamespace from '~/projects/gke_cluster_namespace';
import PersistentUserCallout from '../../persistent_user_callout';
import Project from './project'; import Project from './project';
import ShortcutsNavigation from '../../behaviors/shortcuts/shortcuts_navigation'; import ShortcutsNavigation from '../../behaviors/shortcuts/shortcuts_navigation';
import initCreateCluster from '~/create_cluster/init_create_cluster';
document.addEventListener('DOMContentLoaded', () => { document.addEventListener('DOMContentLoaded', () => {
const { page } = document.body.dataset; initCreateCluster(document, gon);
const newClusterViews = [
'projects:clusters:new',
'projects:clusters:create_gcp',
'projects:clusters:create_user',
];
if (newClusterViews.indexOf(page) > -1) {
const callout = document.querySelector('.gcp-signup-offer');
PersistentUserCallout.factory(callout);
initGkeDropdowns();
initGkeNamespace();
}
new Project(); // eslint-disable-line no-new new Project(); // eslint-disable-line no-new
new ShortcutsNavigation(); // eslint-disable-line no-new new ShortcutsNavigation(); // eslint-disable-line no-new
......
# frozen_string_literal: true
require 'spec_helper'
describe 'Instance-level AWS EKS Cluster', :js do
let(:user) { create(:admin) }
before do
sign_in(user)
end
context 'when user does not have a cluster and visits group clusters page' do
before do
visit admin_clusters_path
click_link 'Add Kubernetes cluster'
end
context 'when user creates a cluster on AWS EKS' do
before do
click_link 'Amazon EKS'
end
it 'user sees a form to create an EKS cluster' do
expect(page).to have_content('Create new Cluster on EKS')
end
end
end
end
# frozen_string_literal: true
require 'spec_helper'
describe 'Group AWS EKS Cluster', :js do
let(:group) { create(:group) }
let(:user) { create(:user) }
before do
group.add_maintainer(user)
gitlab_sign_in(user)
allow(Groups::ClustersController).to receive(:STATUS_POLLING_INTERVAL) { 100 }
allow_any_instance_of(Clusters::Kubernetes::CreateOrUpdateNamespaceService).to receive(:execute)
allow_any_instance_of(Clusters::Cluster).to receive(:retrieve_connection_status).and_return(:connected)
end
context 'when user does not have a cluster and visits group clusters page' do
before do
visit group_clusters_path(group)
click_link 'Add Kubernetes cluster'
end
context 'when user creates a cluster on AWS EKS' do
before do
click_link 'Amazon EKS'
end
it 'user sees a form to create an EKS cluster' do
expect(page).to have_content('Create new Cluster on EKS')
end
end
end
end
...@@ -27,7 +27,7 @@ describe 'AWS EKS Cluster', :js do ...@@ -27,7 +27,7 @@ describe 'AWS EKS Cluster', :js do
end end
it 'user sees a form to create an EKS cluster' do it 'user sees a form to create an EKS cluster' do
expect(page).to have_selector(:css, '.js-create-eks-cluster') expect(page).to have_content('Create new Cluster on EKS')
end end
end end
end end
......
import initGkeNamespace from '~/projects/gke_cluster_namespace'; import initGkeNamespace from '~/create_cluster/gke_cluster_namespace';
describe('GKE cluster namespace', () => { describe('GKE cluster namespace', () => {
const changeEvent = new Event('change'); const changeEvent = new Event('change');
......
import initCreateCluster from '~/create_cluster/init_create_cluster';
import initGkeDropdowns from '~/create_cluster/gke_cluster';
import initGkeNamespace from '~/create_cluster/gke_cluster_namespace';
import PersistentUserCallout from '~/persistent_user_callout';
jest.mock('~/create_cluster/gke_cluster', () => jest.fn());
jest.mock('~/create_cluster/gke_cluster_namespace', () => jest.fn());
jest.mock('~/persistent_user_callout', () => ({
factory: jest.fn(),
}));
describe('initCreateCluster', () => {
let document;
let gon;
beforeEach(() => {
document = {
body: { dataset: {} },
querySelector: jest.fn(),
};
gon = { features: {} };
});
afterEach(() => {
initGkeDropdowns.mockReset();
initGkeNamespace.mockReset();
PersistentUserCallout.factory.mockReset();
});
describe.each`
pageSuffix | page
${':clusters:new'} | ${'project:clusters:new'}
${':clusters:create_gcp'} | ${'groups:clusters:create_gcp'}
${':clusters:create_user'} | ${'admin:clusters:create_user'}
`('when cluster page ends in $pageSuffix', ({ page }) => {
beforeEach(() => {
document.body.dataset = { page };
initCreateCluster(document, gon);
});
it('initializes create GKE cluster app', () => {
expect(initGkeDropdowns).toHaveBeenCalled();
});
it('initializes gcp signup offer banner', () => {
expect(PersistentUserCallout.factory).toHaveBeenCalled();
});
});
describe('when creating a project level cluster', () => {
it('initializes gke namespace app', () => {
document.body.dataset.page = 'project:clusters:new';
initCreateCluster(document, gon);
expect(initGkeNamespace).toHaveBeenCalled();
});
});
describe.each`
clusterLevel | page
${'group level'} | ${'groups:clusters:new'}
${'instance level'} | ${'admin:clusters:create_gcp'}
`('when creating a $clusterLevel cluster', ({ page }) => {
it('does not initialize gke namespace app', () => {
document.body.dataset = { page };
initCreateCluster(document, gon);
expect(initGkeNamespace).not.toHaveBeenCalled();
});
});
});
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