Commit 18b4c66d authored by Robert Speicher's avatar Robert Speicher

Merge branch 'group_level_jupyterhub' into 'master'

Group level JupyterHub

See merge request gitlab-org/gitlab-ce!32512
parents 1efb4ea8 bc04a1dc
...@@ -397,7 +397,6 @@ export default { ...@@ -397,7 +397,6 @@ export default {
</div> </div>
</application-row> </application-row>
<application-row <application-row
v-if="isProjectCluster"
id="jupyter" id="jupyter"
:logo-url="jupyterhubLogo" :logo-url="jupyterhubLogo"
:title="applications.jupyter.title" :title="applications.jupyter.title"
......
...@@ -85,7 +85,8 @@ module Clusters ...@@ -85,7 +85,8 @@ module Clusters
"clientId" => oauth_application.uid, "clientId" => oauth_application.uid,
"clientSecret" => oauth_application.secret, "clientSecret" => oauth_application.secret,
"callbackUrl" => callback_url, "callbackUrl" => callback_url,
"gitlabProjectIdWhitelist" => [project_id] "gitlabProjectIdWhitelist" => cluster.projects.ids,
"gitlabGroupWhitelist" => cluster.groups.map(&:to_param)
} }
}, },
"singleuser" => { "singleuser" => {
...@@ -101,10 +102,6 @@ module Clusters ...@@ -101,10 +102,6 @@ module Clusters
@crypto_key ||= SecureRandom.hex(32) @crypto_key ||= SecureRandom.hex(32)
end end
def project_id
cluster&.project&.id
end
def gitlab_url def gitlab_url
Gitlab.config.gitlab.url Gitlab.config.gitlab.url
end end
......
...@@ -10,15 +10,15 @@ module Clusters ...@@ -10,15 +10,15 @@ module Clusters
self.table_name = 'clusters' self.table_name = 'clusters'
PROJECT_ONLY_APPLICATIONS = { PROJECT_ONLY_APPLICATIONS = {
Applications::Jupyter.application_name => Applications::Jupyter,
Applications::Knative.application_name => Applications::Knative Applications::Knative.application_name => Applications::Knative
}.freeze }.freeze
APPLICATIONS = { APPLICATIONS = {
Applications::Helm.application_name => Applications::Helm, Applications::Helm.application_name => Applications::Helm,
Applications::Ingress.application_name => Applications::Ingress, Applications::Ingress.application_name => Applications::Ingress,
Applications::CertManager.application_name => Applications::CertManager, Applications::CertManager.application_name => Applications::CertManager,
Applications::Prometheus.application_name => Applications::Prometheus,
Applications::Runner.application_name => Applications::Runner, Applications::Runner.application_name => Applications::Runner,
Applications::Prometheus.application_name => Applications::Prometheus Applications::Jupyter.application_name => Applications::Jupyter
}.merge(PROJECT_ONLY_APPLICATIONS).freeze }.merge(PROJECT_ONLY_APPLICATIONS).freeze
DEFAULT_ENVIRONMENT = '*' DEFAULT_ENVIRONMENT = '*'
KUBE_INGRESS_BASE_DOMAIN = 'KUBE_INGRESS_BASE_DOMAIN' KUBE_INGRESS_BASE_DOMAIN = 'KUBE_INGRESS_BASE_DOMAIN'
......
---
title: Group level JupyterHub
merge_request: 32512
author:
type: added
...@@ -85,7 +85,44 @@ describe('Applications', () => { ...@@ -85,7 +85,44 @@ describe('Applications', () => {
}); });
it('renders a row for Jupyter', () => { it('renders a row for Jupyter', () => {
expect(vm.$el.querySelector('.js-cluster-application-row-jupyter')).toBeNull(); expect(vm.$el.querySelector('.js-cluster-application-row-jupyter')).not.toBeNull();
});
it('renders a row for Knative', () => {
expect(vm.$el.querySelector('.js-cluster-application-row-knative')).toBeNull();
});
});
describe('Instance cluster applications', () => {
beforeEach(() => {
vm = mountComponent(Applications, {
type: CLUSTER_TYPE.INSTANCE,
applications: APPLICATIONS_MOCK_STATE,
});
});
it('renders a row for Helm Tiller', () => {
expect(vm.$el.querySelector('.js-cluster-application-row-helm')).not.toBeNull();
});
it('renders a row for Ingress', () => {
expect(vm.$el.querySelector('.js-cluster-application-row-ingress')).not.toBeNull();
});
it('renders a row for Cert-Manager', () => {
expect(vm.$el.querySelector('.js-cluster-application-row-cert_manager')).not.toBeNull();
});
it('renders a row for Prometheus', () => {
expect(vm.$el.querySelector('.js-cluster-application-row-prometheus')).not.toBeNull();
});
it('renders a row for GitLab Runner', () => {
expect(vm.$el.querySelector('.js-cluster-application-row-runner')).not.toBeNull();
});
it('renders a row for Jupyter', () => {
expect(vm.$el.querySelector('.js-cluster-application-row-jupyter')).not.toBeNull();
}); });
it('renders a row for Knative', () => { it('renders a row for Knative', () => {
......
...@@ -81,11 +81,13 @@ describe Clusters::Applications::Jupyter do ...@@ -81,11 +81,13 @@ describe Clusters::Applications::Jupyter do
end end
describe '#files' do describe '#files' do
let(:application) { create(:clusters_applications_jupyter) } let(:cluster) { create(:cluster, :with_installed_helm, :provided_by_gcp, :project) }
let(:application) { create(:clusters_applications_jupyter, cluster: cluster) }
let(:values) { subject[:'values.yaml'] } let(:values) { subject[:'values.yaml'] }
subject { application.files } subject { application.files }
context 'when cluster belongs to a project' do
it 'includes valid values' do it 'includes valid values' do
expect(values).to include('ingress') expect(values).to include('ingress')
expect(values).to include('hub') expect(values).to include('hub')
...@@ -98,10 +100,26 @@ describe Clusters::Applications::Jupyter do ...@@ -98,10 +100,26 @@ describe Clusters::Applications::Jupyter do
expect(values).to include("gitlabProjectIdWhitelist:\n - #{application.cluster.project.id}") expect(values).to include("gitlabProjectIdWhitelist:\n - #{application.cluster.project.id}")
expect(values).to include("c.GitLabOAuthenticator.scope = ['api read_repository write_repository']") expect(values).to include("c.GitLabOAuthenticator.scope = ['api read_repository write_repository']")
expect(values).to match(/GITLAB_HOST: '?#{Gitlab.config.gitlab.host}/) expect(values).to match(/GITLAB_HOST: '?#{Gitlab.config.gitlab.host}/)
expect(values).to match(/GITLAB_CLUSTER_ID: '?#{application.cluster.id}/)
end
end end
context 'when cluster belongs to a project' do context 'when cluster belongs to a group' do
it 'sets GitLab project id' do let(:group) { create(:group) }
let(:cluster) { create(:cluster, :with_installed_helm, :provided_by_gcp, :group, groups: [group]) }
it 'includes valid values' do
expect(values).to include('ingress')
expect(values).to include('hub')
expect(values).to include('rbac')
expect(values).to include('proxy')
expect(values).to include('auth')
expect(values).to include('singleuser')
expect(values).to match(/clientId: '?#{application.oauth_application.uid}/)
expect(values).to match(/callbackUrl: '?#{application.callback_url}/)
expect(values).to include("gitlabGroupWhitelist:\n - #{group.to_param}")
expect(values).to include("c.GitLabOAuthenticator.scope = ['api read_repository write_repository']")
expect(values).to match(/GITLAB_HOST: '?#{Gitlab.config.gitlab.host}/)
expect(values).to match(/GITLAB_CLUSTER_ID: '?#{application.cluster.id}/) expect(values).to match(/GITLAB_CLUSTER_ID: '?#{application.cluster.id}/)
end end
end end
......
...@@ -147,12 +147,12 @@ describe Clusters::Applications::CreateService do ...@@ -147,12 +147,12 @@ describe Clusters::Applications::CreateService do
using RSpec::Parameterized::TableSyntax using RSpec::Parameterized::TableSyntax
where(:application, :association, :allowed, :pre_create_helm) do where(:application, :association, :allowed, :pre_create_helm, :pre_create_ingress) do
'helm' | :application_helm | true | false 'helm' | :application_helm | true | false | false
'ingress' | :application_ingress | true | true 'ingress' | :application_ingress | true | true | false
'runner' | :application_runner | true | true 'runner' | :application_runner | true | true | false
'prometheus' | :application_prometheus | true | true 'prometheus' | :application_prometheus | true | true | false
'jupyter' | :application_jupyter | false | true 'jupyter' | :application_jupyter | true | true | true
end end
with_them do with_them do
...@@ -160,6 +160,7 @@ describe Clusters::Applications::CreateService do ...@@ -160,6 +160,7 @@ describe Clusters::Applications::CreateService do
klass = "Clusters::Applications::#{application.titleize}" klass = "Clusters::Applications::#{application.titleize}"
allow_any_instance_of(klass.constantize).to receive(:make_scheduled!).and_call_original allow_any_instance_of(klass.constantize).to receive(:make_scheduled!).and_call_original
create(:clusters_applications_helm, :installed, cluster: cluster) if pre_create_helm create(:clusters_applications_helm, :installed, cluster: cluster) if pre_create_helm
create(:clusters_applications_ingress, :installed, cluster: cluster, external_hostname: 'example.com') if pre_create_ingress
end end
let(:params) { { application: application } } let(:params) { { application: application } }
......
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