Commit 25d1f0ce authored by Petar Prokic's avatar Petar Prokic

Update instance clusters API

- Expose fields managed and enabled where missing
- Update tests to use the new fields
- Update handbook to mention the fields
parent 6cb213a6
...@@ -35,6 +35,8 @@ Example response: ...@@ -35,6 +35,8 @@ Example response:
"id": 9, "id": 9,
"name": "cluster-1", "name": "cluster-1",
"created_at": "2020-07-14T18:36:10.440Z", "created_at": "2020-07-14T18:36:10.440Z",
"managed": true,
"enabled": true,
"domain": null, "domain": null,
"provider_type": "user", "provider_type": "user",
"platform_type": "kubernetes", "platform_type": "kubernetes",
...@@ -99,7 +101,7 @@ Returns a single instance cluster. ...@@ -99,7 +101,7 @@ Returns a single instance cluster.
Parameters: Parameters:
| Attribute | Type | Required | Description | | Attribute | Type | Required | Description |
| --------- | ---- | -------- | ----------- | | ------------ | ------- | -------- | --------------------- |
| `cluster_id` | integer | yes | The ID of the cluster | | `cluster_id` | integer | yes | The ID of the cluster |
```plaintext ```plaintext
...@@ -119,6 +121,8 @@ Example response: ...@@ -119,6 +121,8 @@ Example response:
"id": 9, "id": 9,
"name": "cluster-1", "name": "cluster-1",
"created_at": "2020-07-14T18:36:10.440Z", "created_at": "2020-07-14T18:36:10.440Z",
"managed": true,
"enabled": true,
"domain": null, "domain": null,
"provider_type": "user", "provider_type": "user",
"platform_type": "kubernetes", "platform_type": "kubernetes",
...@@ -154,7 +158,7 @@ POST /admin/clusters/add ...@@ -154,7 +158,7 @@ POST /admin/clusters/add
Parameters: Parameters:
| Attribute | Type | Required | Description | | Attribute | Type | Required | Description |
| --------- | ---- | -------- | ----------- | | ---------------------------------------------------- | ------- | -------- | --------------------------------------------------------------------------------------------------- |
| `name` | string | yes | The name of the cluster | | `name` | string | yes | The name of the cluster |
| `domain` | string | no | The [base domain](../user/project/clusters/index.md#base-domain) of the cluster | | `domain` | string | no | The [base domain](../user/project/clusters/index.md#base-domain) of the cluster |
| `environment_scope` | string | no | The associated environment to the cluster. Defaults to `*` | | `environment_scope` | string | no | The associated environment to the cluster. Defaults to `*` |
...@@ -184,6 +188,8 @@ Example response: ...@@ -184,6 +188,8 @@ Example response:
"id": 11, "id": 11,
"name": "cluster-3", "name": "cluster-3",
"created_at": "2020-07-14T18:42:50.805Z", "created_at": "2020-07-14T18:42:50.805Z",
"managed": true,
"enabled": true,
"domain": null, "domain": null,
"provider_type": "user", "provider_type": "user",
"platform_type": "kubernetes", "platform_type": "kubernetes",
...@@ -219,13 +225,14 @@ PUT /admin/clusters/:cluster_id ...@@ -219,13 +225,14 @@ PUT /admin/clusters/:cluster_id
Parameters: Parameters:
| Attribute | Type | Required | Description | | Attribute | Type | Required | Description |
| --------- | ---- | -------- | ----------- | | ------------------------------------------- | ------- | -------- | --------------------------------------------------------------------------------------------------- |
| `cluster_id` | integer | yes | The ID of the cluster | | `cluster_id` | integer | yes | The ID of the cluster |
| `name` | string | no | The name of the cluster | | `name` | string | no | The name of the cluster |
| `domain` | string | no | The [base domain](../user/project/clusters/index.md#base-domain) of the cluster | | `domain` | string | no | The [base domain](../user/project/clusters/index.md#base-domain) of the cluster |
| `environment_scope` | string | no | The associated environment to the cluster | | `environment_scope` | string | no | The associated environment to the cluster |
| `management_project_id` | integer | no | The ID of the [management project](../user/clusters/management_project.md) for the cluster | | `management_project_id` | integer | no | The ID of the [management project](../user/clusters/management_project.md) for the cluster |
| `enabled` | boolean | no | Determines if cluster is active or not, defaults to true | | `enabled` | boolean | no | Determines if cluster is active or not, defaults to true |
| `managed` | boolean | no | Determines if GitLab will manage namespaces and service accounts for this cluster, defaults to true |
| `platform_kubernetes_attributes[api_url]` | string | no | The URL to access the Kubernetes API | | `platform_kubernetes_attributes[api_url]` | string | no | The URL to access the Kubernetes API |
| `platform_kubernetes_attributes[token]` | string | no | The token to authenticate against Kubernetes | | `platform_kubernetes_attributes[token]` | string | no | The token to authenticate against Kubernetes |
| `platform_kubernetes_attributes[ca_cert]` | string | no | TLS certificate. Required if API is using a self-signed TLS certificate. | | `platform_kubernetes_attributes[ca_cert]` | string | no | TLS certificate. Required if API is using a self-signed TLS certificate. |
...@@ -252,6 +259,8 @@ Example response: ...@@ -252,6 +259,8 @@ Example response:
"id": 9, "id": 9,
"name": "update-cluster-name", "name": "update-cluster-name",
"created_at": "2020-07-14T18:36:10.440Z", "created_at": "2020-07-14T18:36:10.440Z",
"managed": true,
"enabled": true,
"domain": null, "domain": null,
"provider_type": "user", "provider_type": "user",
"platform_type": "kubernetes", "platform_type": "kubernetes",
...@@ -289,7 +298,7 @@ DELETE /admin/clusters/:cluster_id ...@@ -289,7 +298,7 @@ DELETE /admin/clusters/:cluster_id
Parameters: Parameters:
| Attribute | Type | Required | Description | | Attribute | Type | Required | Description |
| --------- | ---- | -------- | ----------- | | ------------ | ------- | -------- | --------------------- |
| `cluster_id` | integer | yes | The ID of the cluster | | `cluster_id` | integer | yes | The ID of the cluster |
Example request: Example request:
......
...@@ -76,6 +76,7 @@ module API ...@@ -76,6 +76,7 @@ module API
optional :namespace_per_environment, default: true, type: Boolean, desc: 'Deploy each environment to a separate Kubernetes namespace' optional :namespace_per_environment, default: true, type: Boolean, desc: 'Deploy each environment to a separate Kubernetes namespace'
optional :domain, type: String, desc: 'Cluster base domain' optional :domain, type: String, desc: 'Cluster base domain'
optional :management_project_id, type: Integer, desc: 'The ID of the management project' optional :management_project_id, type: Integer, desc: 'The ID of the management project'
optional :managed, type: Boolean, default: true, desc: 'Determines if GitLab will manage namespaces and service accounts for this cluster, defaults to true'
optional :platform_kubernetes_attributes, type: Hash, desc: %q(Platform Kubernetes data) do optional :platform_kubernetes_attributes, type: Hash, desc: %q(Platform Kubernetes data) do
optional :api_url, type: String, desc: 'URL to access the Kubernetes API' optional :api_url, type: String, desc: 'URL to access the Kubernetes API'
optional :token, type: String, desc: 'Token to authenticate against Kubernetes' optional :token, type: String, desc: 'Token to authenticate against Kubernetes'
......
...@@ -89,6 +89,8 @@ RSpec.describe ::API::Admin::InstanceClusters do ...@@ -89,6 +89,8 @@ RSpec.describe ::API::Admin::InstanceClusters do
expect(json_response['environment_scope']).to eq('*') expect(json_response['environment_scope']).to eq('*')
expect(json_response['cluster_type']).to eq('instance_type') expect(json_response['cluster_type']).to eq('instance_type')
expect(json_response['domain']).to eq('example.com') expect(json_response['domain']).to eq('example.com')
expect(json_response['enabled']).to be_truthy
expect(json_response['managed']).to be_truthy
end end
it 'returns kubernetes platform information' do it 'returns kubernetes platform information' do
...@@ -162,6 +164,7 @@ RSpec.describe ::API::Admin::InstanceClusters do ...@@ -162,6 +164,7 @@ RSpec.describe ::API::Admin::InstanceClusters do
name: 'test-instance-cluster', name: 'test-instance-cluster',
domain: 'domain.example.com', domain: 'domain.example.com',
managed: false, managed: false,
enabled: false,
namespace_per_environment: false, namespace_per_environment: false,
platform_kubernetes_attributes: platform_kubernetes_attributes, platform_kubernetes_attributes: platform_kubernetes_attributes,
clusterable: clusterable clusterable: clusterable
...@@ -204,9 +207,9 @@ RSpec.describe ::API::Admin::InstanceClusters do ...@@ -204,9 +207,9 @@ RSpec.describe ::API::Admin::InstanceClusters do
expect(cluster_result.name).to eq('test-instance-cluster') expect(cluster_result.name).to eq('test-instance-cluster')
expect(cluster_result.domain).to eq('domain.example.com') expect(cluster_result.domain).to eq('domain.example.com')
expect(cluster_result.environment_scope).to eq('*') expect(cluster_result.environment_scope).to eq('*')
expect(cluster_result.enabled).to eq(true)
expect(platform_kubernetes.authorization_type).to eq('rbac')
expect(cluster_result.managed).to be_falsy expect(cluster_result.managed).to be_falsy
expect(cluster_result.enabled).to be_falsy
expect(platform_kubernetes.authorization_type).to eq('rbac')
expect(cluster_result.namespace_per_environment).to eq(false) expect(cluster_result.namespace_per_environment).to eq(false)
expect(platform_kubernetes.api_url).to eq("https://example.com") expect(platform_kubernetes.api_url).to eq("https://example.com")
expect(platform_kubernetes.token).to eq('sample-token') expect(platform_kubernetes.token).to eq('sample-token')
...@@ -300,6 +303,8 @@ RSpec.describe ::API::Admin::InstanceClusters do ...@@ -300,6 +303,8 @@ RSpec.describe ::API::Admin::InstanceClusters do
let(:update_params) do let(:update_params) do
{ {
domain: domain, domain: domain,
managed: false,
enabled: false,
platform_kubernetes_attributes: platform_kubernetes_attributes platform_kubernetes_attributes: platform_kubernetes_attributes
} }
end end
...@@ -325,6 +330,8 @@ RSpec.describe ::API::Admin::InstanceClusters do ...@@ -325,6 +330,8 @@ RSpec.describe ::API::Admin::InstanceClusters do
it 'updates cluster attributes' do it 'updates cluster attributes' do
expect(cluster.domain).to eq('new-domain.com') expect(cluster.domain).to eq('new-domain.com')
expect(cluster.managed).to be_falsy
expect(cluster.enabled).to be_falsy
end end
end end
...@@ -337,6 +344,8 @@ RSpec.describe ::API::Admin::InstanceClusters do ...@@ -337,6 +344,8 @@ RSpec.describe ::API::Admin::InstanceClusters do
it 'does not update cluster attributes' do it 'does not update cluster attributes' do
expect(cluster.domain).to eq('old-domain.com') expect(cluster.domain).to eq('old-domain.com')
expect(cluster.managed).to be_truthy
expect(cluster.enabled).to be_truthy
end end
it 'returns validation errors' do it 'returns validation errors' 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