From 645d52d08ac283d64468931f2ee50fa3a6fcc8ae Mon Sep 17 00:00:00 2001 From: Francesco Pantano Date: Fri, 13 Oct 2023 13:20:39 +0200 Subject: [PATCH] Add new glanceAPI struct This change is the first of a series where the purpose is to move away from the harcoded internal/external glanceAPI instance in favor of an arbitrary number of GlanceAPI instances. The current change doesn't introduce the ability to deploy >1 GlanceAPI instance, but introduces the intermediate struct that will serve this purpose. The split behavior is still preserved, but it happens behind the scenes in Glance. Depends-On: openstack-k8s-operators/glance-operator/pull/329 Depends-On: openstack-k8s-operators/openstack-operator/pull/518 Note: Still WIP and under review. Signed-off-by: Francesco Pantano --- ....openstack.org_openstackcontrolplanes.yaml | 208 ++++-------------- apis/go.mod | 2 + apis/go.sum | 4 +- ....openstack.org_openstackcontrolplanes.yaml | 208 ++++-------------- .../core_v1beta1_openstackcontrolplane.yaml | 3 + ..._openstackcontrolplane_collapsed_cell.yaml | 3 + ..._v1beta1_openstackcontrolplane_galera.yaml | 3 + ...penstackcontrolplane_galera_3replicas.yaml | 3 + ...controlplane_galera_network_isolation.yaml | 7 +- ...ne_galera_network_isolation_3replicas.yaml | 7 +- ...enstackcontrolplane_network_isolation.yaml | 7 +- ...ckcontrolplane_network_isolation_ceph.yaml | 7 +- go.mod | 2 + go.sum | 4 +- hack/pin-bundle-images.sh | 3 + kuttl-test.yaml | 2 +- pkg/openstack/glance.go | 26 +-- .../common/assert-sample-deployment.yaml | 3 + .../collapsed/01-assert-collapsed-cell.yaml | 2 + .../01-assert-galera-3replicas.yaml | 2 + .../tests/galera-basic/01-assert-galera.yaml | 2 + 21 files changed, 154 insertions(+), 354 deletions(-) diff --git a/apis/bases/core.openstack.org_openstackcontrolplanes.yaml b/apis/bases/core.openstack.org_openstackcontrolplanes.yaml index 8ff1198af..e0ff3dc08 100644 --- a/apis/bases/core.openstack.org_openstackcontrolplanes.yaml +++ b/apis/bases/core.openstack.org_openstackcontrolplanes.yaml @@ -3135,7 +3135,7 @@ spec: - extraVol type: object type: array - glanceAPIExternal: + glanceAPI: properties: containerImage: type: string @@ -3166,169 +3166,52 @@ spec: override: properties: service: - properties: - endpointURL: - type: string - metadata: - properties: - annotations: - additionalProperties: + additionalProperties: + properties: + endpointURL: + type: string + metadata: + properties: + annotations: + additionalProperties: + type: string + type: object + labels: + additionalProperties: + type: string + type: object + type: object + spec: + properties: + externalName: type: string - type: object - labels: - additionalProperties: + externalTrafficPolicy: type: string - type: object - type: object - spec: - properties: - externalName: - type: string - externalTrafficPolicy: - type: string - internalTrafficPolicy: - type: string - ipFamilyPolicy: - type: string - loadBalancerClass: - type: string - loadBalancerSourceRanges: - items: + internalTrafficPolicy: type: string - type: array - sessionAffinity: - type: string - sessionAffinityConfig: - properties: - clientIP: - properties: - timeoutSeconds: - format: int32 - type: integer - type: object - type: object - type: - type: string - type: object - type: object - type: object - pvc: - type: string - replicas: - default: 1 - format: int32 - maximum: 32 - minimum: 0 - type: integer - resources: - properties: - claims: - items: - properties: - name: - type: string - required: - - name - type: object - type: array - x-kubernetes-list-map-keys: - - name - x-kubernetes-list-type: map - limits: - additionalProperties: - anyOf: - - type: integer - - type: string - pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ - x-kubernetes-int-or-string: true - type: object - requests: - additionalProperties: - anyOf: - - type: integer - - type: string - pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ - x-kubernetes-int-or-string: true - type: object - type: object - required: - - containerImage - type: object - glanceAPIInternal: - properties: - containerImage: - type: string - customServiceConfig: - type: string - customServiceConfigSecrets: - items: - type: string - type: array - debug: - properties: - service: - default: false - type: boolean - type: object - defaultConfigOverwrite: - additionalProperties: - type: string - type: object - networkAttachments: - items: - type: string - type: array - nodeSelector: - additionalProperties: - type: string - type: object - override: - properties: - service: - properties: - endpointURL: - type: string - metadata: - properties: - annotations: - additionalProperties: + ipFamilyPolicy: type: string - type: object - labels: - additionalProperties: + loadBalancerClass: type: string - type: object - type: object - spec: - properties: - externalName: - type: string - externalTrafficPolicy: - type: string - internalTrafficPolicy: - type: string - ipFamilyPolicy: - type: string - loadBalancerClass: - type: string - loadBalancerSourceRanges: - items: + loadBalancerSourceRanges: + items: + type: string + type: array + sessionAffinity: type: string - type: array - sessionAffinity: - type: string - sessionAffinityConfig: - properties: - clientIP: - properties: - timeoutSeconds: - format: int32 - type: integer - type: object - type: object - type: - type: string - type: object + sessionAffinityConfig: + properties: + clientIP: + properties: + timeoutSeconds: + format: int32 + type: integer + type: object + type: object + type: + type: string + type: object + type: object type: object type: object pvc: @@ -3370,6 +3253,12 @@ spec: x-kubernetes-int-or-string: true type: object type: object + type: + default: split + enum: + - split + - single + type: string required: - containerImage type: object @@ -3427,8 +3316,7 @@ spec: required: - containerImage - databaseInstance - - glanceAPIExternal - - glanceAPIInternal + - glanceAPI - imageCacheSize - secret - storageRequest diff --git a/apis/go.mod b/apis/go.mod index b5b3d08d8..2796cd194 100644 --- a/apis/go.mod +++ b/apis/go.mod @@ -109,3 +109,5 @@ replace ( // mschuppert: map to latest commit from release-4.13 tag // must consistent within modules and service operators replace github.com/openshift/api => github.com/openshift/api v0.0.0-20230414143018-3367bc7e6ac7 //allow-merging + +replace github.com/openstack-k8s-operators/glance-operator/api => github.com/fmount/glance-operator/api v0.0.0-20231018072238-09a5287701da diff --git a/apis/go.sum b/apis/go.sum index e0a7e0e83..82b173e1d 100644 --- a/apis/go.sum +++ b/apis/go.sum @@ -33,6 +33,8 @@ github.com/evanphx/json-patch v5.6.0+incompatible h1:jBYDEEiFBPxA0v50tFdvOzQQTCv github.com/evanphx/json-patch/v5 v5.6.0 h1:b91NhWfaz02IuVxO9faSllyAtNXHMPkC5J8sJCLunww= github.com/evanphx/json-patch/v5 v5.6.0/go.mod h1:G79N1coSVB93tBe7j6PhzjmR3/2VvlbKOFpnXhI9Bw4= github.com/flowstack/go-jsonschema v0.1.1/go.mod h1:yL7fNggx1o8rm9RlgXv7hTBWxdBM0rVwpMwimd3F3N0= +github.com/fmount/glance-operator/api v0.0.0-20231018072238-09a5287701da h1:pfnTn5DC0yOgo6WeTh98qPx+0dsWCujrD3/RSgo/Vj8= +github.com/fmount/glance-operator/api v0.0.0-20231018072238-09a5287701da/go.mod h1:D+c4nLxVzSZDeYqAGrfD5po2+udzVkF5M5SCF9QeMMY= github.com/fsnotify/fsnotify v1.6.0 h1:n+5WquG0fcWoWp6xPWfHdbskMCQaFnG6PfBrh1Ky4HY= github.com/fsnotify/fsnotify v1.6.0/go.mod h1:sl3t1tCWJFWoRz9R8WJCbQihKKwmorjAbSClcnxKAGw= github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04= @@ -130,8 +132,6 @@ github.com/openshift/api v0.0.0-20230414143018-3367bc7e6ac7 h1:rncLxJBpFGqBztyxC github.com/openshift/api v0.0.0-20230414143018-3367bc7e6ac7/go.mod h1:ctXNyWanKEjGj8sss1KjjHQ3ENKFm33FFnS5BKaIPh4= github.com/openstack-k8s-operators/cinder-operator/api v0.3.1-0.20231006133827-ce89e0fd01f2 h1:sPQWPiTBSyNf1vdImemK4vAjavwmf/cKXkIrIMOVWTs= github.com/openstack-k8s-operators/cinder-operator/api v0.3.1-0.20231006133827-ce89e0fd01f2/go.mod h1:8NFIyjXZeC+T2UBcmTDTfSatRdhi2eaZlaAuzcT2rNk= -github.com/openstack-k8s-operators/glance-operator/api v0.3.1-0.20231013112543-a07d8273b82d h1:WEG0KPgsujhwVh7W/IbJ8I8JTDUuJj6V5rWD6L+KzbI= -github.com/openstack-k8s-operators/glance-operator/api v0.3.1-0.20231013112543-a07d8273b82d/go.mod h1:D+c4nLxVzSZDeYqAGrfD5po2+udzVkF5M5SCF9QeMMY= github.com/openstack-k8s-operators/heat-operator/api v0.3.1-0.20231015090350-5fdcca35e29e h1:XBXHAOx6UbYT5IKiSX4GcFLrvc6ccdcHi39As7+1NvM= github.com/openstack-k8s-operators/heat-operator/api v0.3.1-0.20231015090350-5fdcca35e29e/go.mod h1:w4AkvOs7PCint2ZJSk2/ownZE3qQnVryNuqZsw0ZKM4= github.com/openstack-k8s-operators/horizon-operator/api v0.3.1-0.20231015112558-692aca16f97d h1:WID1OPHjN8saP8SK5SZfE9m31e5HYrTltIugrIHgt3w= diff --git a/config/crd/bases/core.openstack.org_openstackcontrolplanes.yaml b/config/crd/bases/core.openstack.org_openstackcontrolplanes.yaml index 8ff1198af..e0ff3dc08 100644 --- a/config/crd/bases/core.openstack.org_openstackcontrolplanes.yaml +++ b/config/crd/bases/core.openstack.org_openstackcontrolplanes.yaml @@ -3135,7 +3135,7 @@ spec: - extraVol type: object type: array - glanceAPIExternal: + glanceAPI: properties: containerImage: type: string @@ -3166,169 +3166,52 @@ spec: override: properties: service: - properties: - endpointURL: - type: string - metadata: - properties: - annotations: - additionalProperties: + additionalProperties: + properties: + endpointURL: + type: string + metadata: + properties: + annotations: + additionalProperties: + type: string + type: object + labels: + additionalProperties: + type: string + type: object + type: object + spec: + properties: + externalName: type: string - type: object - labels: - additionalProperties: + externalTrafficPolicy: type: string - type: object - type: object - spec: - properties: - externalName: - type: string - externalTrafficPolicy: - type: string - internalTrafficPolicy: - type: string - ipFamilyPolicy: - type: string - loadBalancerClass: - type: string - loadBalancerSourceRanges: - items: + internalTrafficPolicy: type: string - type: array - sessionAffinity: - type: string - sessionAffinityConfig: - properties: - clientIP: - properties: - timeoutSeconds: - format: int32 - type: integer - type: object - type: object - type: - type: string - type: object - type: object - type: object - pvc: - type: string - replicas: - default: 1 - format: int32 - maximum: 32 - minimum: 0 - type: integer - resources: - properties: - claims: - items: - properties: - name: - type: string - required: - - name - type: object - type: array - x-kubernetes-list-map-keys: - - name - x-kubernetes-list-type: map - limits: - additionalProperties: - anyOf: - - type: integer - - type: string - pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ - x-kubernetes-int-or-string: true - type: object - requests: - additionalProperties: - anyOf: - - type: integer - - type: string - pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ - x-kubernetes-int-or-string: true - type: object - type: object - required: - - containerImage - type: object - glanceAPIInternal: - properties: - containerImage: - type: string - customServiceConfig: - type: string - customServiceConfigSecrets: - items: - type: string - type: array - debug: - properties: - service: - default: false - type: boolean - type: object - defaultConfigOverwrite: - additionalProperties: - type: string - type: object - networkAttachments: - items: - type: string - type: array - nodeSelector: - additionalProperties: - type: string - type: object - override: - properties: - service: - properties: - endpointURL: - type: string - metadata: - properties: - annotations: - additionalProperties: + ipFamilyPolicy: type: string - type: object - labels: - additionalProperties: + loadBalancerClass: type: string - type: object - type: object - spec: - properties: - externalName: - type: string - externalTrafficPolicy: - type: string - internalTrafficPolicy: - type: string - ipFamilyPolicy: - type: string - loadBalancerClass: - type: string - loadBalancerSourceRanges: - items: + loadBalancerSourceRanges: + items: + type: string + type: array + sessionAffinity: type: string - type: array - sessionAffinity: - type: string - sessionAffinityConfig: - properties: - clientIP: - properties: - timeoutSeconds: - format: int32 - type: integer - type: object - type: object - type: - type: string - type: object + sessionAffinityConfig: + properties: + clientIP: + properties: + timeoutSeconds: + format: int32 + type: integer + type: object + type: object + type: + type: string + type: object + type: object type: object type: object pvc: @@ -3370,6 +3253,12 @@ spec: x-kubernetes-int-or-string: true type: object type: object + type: + default: split + enum: + - split + - single + type: string required: - containerImage type: object @@ -3427,8 +3316,7 @@ spec: required: - containerImage - databaseInstance - - glanceAPIExternal - - glanceAPIInternal + - glanceAPI - imageCacheSize - secret - storageRequest diff --git a/config/samples/core_v1beta1_openstackcontrolplane.yaml b/config/samples/core_v1beta1_openstackcontrolplane.yaml index 8ad4d51cd..5eed0d74d 100644 --- a/config/samples/core_v1beta1_openstackcontrolplane.yaml +++ b/config/samples/core_v1beta1_openstackcontrolplane.yaml @@ -51,9 +51,12 @@ spec: secret: osp-secret glance: template: + secret: osp-secret databaseInstance: openstack storageClass: "" storageRequest: 10G + glanceAPI: + replicas: 1 cinder: template: databaseInstance: openstack diff --git a/config/samples/core_v1beta1_openstackcontrolplane_collapsed_cell.yaml b/config/samples/core_v1beta1_openstackcontrolplane_collapsed_cell.yaml index 0562fd2f2..f80db1dcb 100644 --- a/config/samples/core_v1beta1_openstackcontrolplane_collapsed_cell.yaml +++ b/config/samples/core_v1beta1_openstackcontrolplane_collapsed_cell.yaml @@ -34,9 +34,12 @@ spec: secret: osp-secret glance: template: + secret: osp-secret databaseInstance: openstack storageClass: "" storageRequest: 10G + glanceAPI: + replicas: 1 cinder: template: databaseInstance: openstack diff --git a/config/samples/core_v1beta1_openstackcontrolplane_galera.yaml b/config/samples/core_v1beta1_openstackcontrolplane_galera.yaml index 851a562e4..581b6ed71 100644 --- a/config/samples/core_v1beta1_openstackcontrolplane_galera.yaml +++ b/config/samples/core_v1beta1_openstackcontrolplane_galera.yaml @@ -50,9 +50,12 @@ spec: secret: osp-secret glance: template: + secret: osp-secret databaseInstance: openstack storageClass: "" storageRequest: 10G + glanceAPI: + replicas: 1 cinder: template: databaseInstance: openstack diff --git a/config/samples/core_v1beta1_openstackcontrolplane_galera_3replicas.yaml b/config/samples/core_v1beta1_openstackcontrolplane_galera_3replicas.yaml index b023168de..5077ac770 100644 --- a/config/samples/core_v1beta1_openstackcontrolplane_galera_3replicas.yaml +++ b/config/samples/core_v1beta1_openstackcontrolplane_galera_3replicas.yaml @@ -53,6 +53,9 @@ spec: databaseInstance: openstack storageClass: "" storageRequest: 10G + secret: osp-secret + glanceAPI: + replicas: 1 cinder: template: databaseInstance: openstack diff --git a/config/samples/core_v1beta1_openstackcontrolplane_galera_network_isolation.yaml b/config/samples/core_v1beta1_openstackcontrolplane_galera_network_isolation.yaml index 4e1901f91..43c797c02 100644 --- a/config/samples/core_v1beta1_openstackcontrolplane_galera_network_isolation.yaml +++ b/config/samples/core_v1beta1_openstackcontrolplane_galera_network_isolation.yaml @@ -56,7 +56,9 @@ spec: databaseInstance: openstack storageClass: "" storageRequest: 10G - glanceAPIInternal: + secret: osp-secret + glanceAPI: + replicas: 1 override: service: metadata: @@ -68,9 +70,6 @@ spec: type: LoadBalancer networkAttachments: - storage - glanceAPIExternal: - networkAttachments: - - storage keystone: apiOverride: route: {} diff --git a/config/samples/core_v1beta1_openstackcontrolplane_galera_network_isolation_3replicas.yaml b/config/samples/core_v1beta1_openstackcontrolplane_galera_network_isolation_3replicas.yaml index d71d83006..40a2b8975 100644 --- a/config/samples/core_v1beta1_openstackcontrolplane_galera_network_isolation_3replicas.yaml +++ b/config/samples/core_v1beta1_openstackcontrolplane_galera_network_isolation_3replicas.yaml @@ -56,7 +56,9 @@ spec: databaseInstance: openstack storageClass: "" storageRequest: 10G - glanceAPIInternal: + secret: osp-secret + glanceAPI: + replicas: 1 override: service: metadata: @@ -68,9 +70,6 @@ spec: type: LoadBalancer networkAttachments: - storage - glanceAPIExternal: - networkAttachments: - - storage keystone: apiOverride: route: {} diff --git a/config/samples/core_v1beta1_openstackcontrolplane_network_isolation.yaml b/config/samples/core_v1beta1_openstackcontrolplane_network_isolation.yaml index 0619f35d2..e286c9cde 100644 --- a/config/samples/core_v1beta1_openstackcontrolplane_network_isolation.yaml +++ b/config/samples/core_v1beta1_openstackcontrolplane_network_isolation.yaml @@ -56,7 +56,9 @@ spec: databaseInstance: openstack storageClass: "" storageRequest: 10G - glanceAPIInternal: + secret: osp-secret + glanceAPI: + replicas: 1 override: service: metadata: @@ -68,9 +70,6 @@ spec: type: LoadBalancer networkAttachments: - storage - glanceAPIExternal: - networkAttachments: - - storage keystone: apiOverride: route: {} diff --git a/config/samples/core_v1beta1_openstackcontrolplane_network_isolation_ceph.yaml b/config/samples/core_v1beta1_openstackcontrolplane_network_isolation_ceph.yaml index 62a1164b6..869aedaa4 100644 --- a/config/samples/core_v1beta1_openstackcontrolplane_network_isolation_ceph.yaml +++ b/config/samples/core_v1beta1_openstackcontrolplane_network_isolation_ceph.yaml @@ -101,7 +101,9 @@ spec: rbd_store_user = openstack storageClass: "" storageRequest: 10G - glanceAPIInternal: + secret: osp-secret + glanceAPI: + replicas: 1 override: service: metadata: @@ -113,9 +115,6 @@ spec: type: LoadBalancer networkAttachments: - storage - glanceAPIExternal: - networkAttachments: - - storage keystone: apiOverride: route: {} diff --git a/go.mod b/go.mod index 51982518d..112b1415a 100644 --- a/go.mod +++ b/go.mod @@ -121,3 +121,5 @@ replace github.com/openstack-k8s-operators/openstack-operator/apis => ./apis // mschuppert: map to latest commit from release-4.13 tag // must consistent within modules and service operators replace github.com/openshift/api => github.com/openshift/api v0.0.0-20230414143018-3367bc7e6ac7 //allow-merging + +replace github.com/openstack-k8s-operators/glance-operator/api => github.com/fmount/glance-operator/api v0.0.0-20231018072238-09a5287701da diff --git a/go.sum b/go.sum index d9fca8007..49ec2e6ad 100644 --- a/go.sum +++ b/go.sum @@ -35,6 +35,8 @@ github.com/evanphx/json-patch v5.6.0+incompatible h1:jBYDEEiFBPxA0v50tFdvOzQQTCv github.com/evanphx/json-patch/v5 v5.6.0 h1:b91NhWfaz02IuVxO9faSllyAtNXHMPkC5J8sJCLunww= github.com/evanphx/json-patch/v5 v5.6.0/go.mod h1:G79N1coSVB93tBe7j6PhzjmR3/2VvlbKOFpnXhI9Bw4= github.com/flowstack/go-jsonschema v0.1.1/go.mod h1:yL7fNggx1o8rm9RlgXv7hTBWxdBM0rVwpMwimd3F3N0= +github.com/fmount/glance-operator/api v0.0.0-20231018072238-09a5287701da h1:pfnTn5DC0yOgo6WeTh98qPx+0dsWCujrD3/RSgo/Vj8= +github.com/fmount/glance-operator/api v0.0.0-20231018072238-09a5287701da/go.mod h1:D+c4nLxVzSZDeYqAGrfD5po2+udzVkF5M5SCF9QeMMY= github.com/fsnotify/fsnotify v1.6.0 h1:n+5WquG0fcWoWp6xPWfHdbskMCQaFnG6PfBrh1Ky4HY= github.com/fsnotify/fsnotify v1.6.0/go.mod h1:sl3t1tCWJFWoRz9R8WJCbQihKKwmorjAbSClcnxKAGw= github.com/ghodss/yaml v1.0.0 h1:wQHKEahhL6wmXdzwWG11gIVCkOv05bNOh+Rxn0yngAk= @@ -139,8 +141,6 @@ github.com/openstack-k8s-operators/cinder-operator/api v0.3.1-0.20231006133827-c github.com/openstack-k8s-operators/cinder-operator/api v0.3.1-0.20231006133827-ce89e0fd01f2/go.mod h1:8NFIyjXZeC+T2UBcmTDTfSatRdhi2eaZlaAuzcT2rNk= github.com/openstack-k8s-operators/dataplane-operator/api v0.3.1-0.20231015102122-7f1bd9b4e18f h1:gl+3rXaKjCfwt6OOJjOcT+wsQtH2KQvNX4K1spBuO5M= github.com/openstack-k8s-operators/dataplane-operator/api v0.3.1-0.20231015102122-7f1bd9b4e18f/go.mod h1:UyIqxl7rB1yWpp5KmhUmdYk+LTDNP67KkrRJkjtxs2I= -github.com/openstack-k8s-operators/glance-operator/api v0.3.1-0.20231013112543-a07d8273b82d h1:WEG0KPgsujhwVh7W/IbJ8I8JTDUuJj6V5rWD6L+KzbI= -github.com/openstack-k8s-operators/glance-operator/api v0.3.1-0.20231013112543-a07d8273b82d/go.mod h1:D+c4nLxVzSZDeYqAGrfD5po2+udzVkF5M5SCF9QeMMY= github.com/openstack-k8s-operators/heat-operator/api v0.3.1-0.20231015090350-5fdcca35e29e h1:XBXHAOx6UbYT5IKiSX4GcFLrvc6ccdcHi39As7+1NvM= github.com/openstack-k8s-operators/heat-operator/api v0.3.1-0.20231015090350-5fdcca35e29e/go.mod h1:w4AkvOs7PCint2ZJSk2/ownZE3qQnVryNuqZsw0ZKM4= github.com/openstack-k8s-operators/horizon-operator/api v0.3.1-0.20231015112558-692aca16f97d h1:WID1OPHjN8saP8SK5SZfE9m31e5HYrTltIugrIHgt3w= diff --git a/hack/pin-bundle-images.sh b/hack/pin-bundle-images.sh index 1e64787ea..0b92a82a5 100755 --- a/hack/pin-bundle-images.sh +++ b/hack/pin-bundle-images.sh @@ -46,6 +46,9 @@ for MOD_PATH in $(go list -mod=readonly -m -json all | jq -r '. | select(.Path | REPO_CURL_URL="https://${CURL_REGISTRY}/api/v1/repository/${IMAGENAMESPACE}" fi else + # Current hack to point to a diff glance-operator-bundle built on top + # of https://github.com/openstack-k8s-operators/glance-operator/pull/329 + GITHUB_USER="fpantano" REPO_CURL_URL="https://${CURL_REGISTRY}/api/v1/repository/${GITHUB_USER}" REPO_URL="${CURL_REGISTRY}/${GITHUB_USER}" fi diff --git a/kuttl-test.yaml b/kuttl-test.yaml index cb31975d3..771ee66a7 100644 --- a/kuttl-test.yaml +++ b/kuttl-test.yaml @@ -19,7 +19,7 @@ kind: TestSuite reportFormat: JSON reportName: kuttl-test-openstack namespace: openstack-kuttl-tests -timeout: 1000 +timeout: 1380 parallel: 1 suppress: - events # Remove spammy event logs diff --git a/pkg/openstack/glance.go b/pkg/openstack/glance.go index 447235f64..57d4580a2 100644 --- a/pkg/openstack/glance.go +++ b/pkg/openstack/glance.go @@ -17,7 +17,6 @@ import ( k8s_errors "k8s.io/apimachinery/pkg/api/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/types" - "k8s.io/utils/ptr" ctrl "sigs.k8s.io/controller-runtime" ) @@ -39,19 +38,22 @@ func ReconcileGlance(ctx context.Context, instance *corev1beta1.OpenStackControl return ctrl.Result{}, nil } - serviceOverrides := map[service.Endpoint]service.RoutedOverrideSpec{} - if instance.Spec.Glance.Template.GlanceAPIExternal.Override.Service != nil { - serviceOverrides[service.EndpointPublic] = *instance.Spec.Glance.Template.GlanceAPIExternal.Override.Service - } - if instance.Spec.Glance.Template.GlanceAPIInternal.Override.Service != nil { - serviceOverrides[service.EndpointInternal] = *instance.Spec.Glance.Template.GlanceAPIInternal.Override.Service + // add selector to service overrides + for _, endpointType := range []service.Endpoint{service.EndpointPublic, service.EndpointInternal} { + if instance.Spec.Glance.Template.GlanceAPI.Override.Service == nil { + instance.Spec.Glance.Template.GlanceAPI.Override.Service = map[service.Endpoint]service.RoutedOverrideSpec{} + } + instance.Spec.Glance.Template.GlanceAPI.Override.Service[endpointType] = + AddServiceComponentLabel( + instance.Spec.Manila.Template.ManilaAPI.Override.Service[endpointType], + glance.Name) } // add selector to service overrides - for _, endpointType := range []service.Endpoint{service.EndpointPublic, service.EndpointInternal} { + /*for _, endpointType := range []service.Endpoint{service.EndpointPublic, service.EndpointInternal} { svcOverride := serviceOverrides[endpointType] serviceOverrides[endpointType] = AddServiceComponentLabel(svcOverride, glance.Name) - } + }*/ // When component services got created check if there is the need to create a route if err := helper.GetClient().Get(ctx, types.NamespacedName{Name: "glance", Namespace: instance.Namespace}, glance); err != nil { @@ -72,13 +74,13 @@ func ReconcileGlance(ctx context.Context, instance *corev1beta1.OpenStackControl } var ctrlResult reconcile.Result - serviceOverrides, ctrlResult, err = EnsureRoute( + instance.Spec.Glance.Template.GlanceAPI.Override.Service, ctrlResult, err = EnsureRoute( ctx, instance, helper, glance, svcs, - serviceOverrides, + instance.Spec.Glance.Template.GlanceAPI.Override.Service, instance.Spec.Glance.APIOverride.Route, corev1beta1.OpenStackControlPlaneExposeGlanceReadyCondition, ) @@ -92,8 +94,6 @@ func ReconcileGlance(ctx context.Context, instance *corev1beta1.OpenStackControl helper.GetLogger().Info("Reconciling Glance", "Glance.Namespace", instance.Namespace, "Glance.Name", "glance") op, err := controllerutil.CreateOrPatch(ctx, helper.GetClient(), glance, func() error { instance.Spec.Glance.Template.DeepCopyInto(&glance.Spec) - glance.Spec.GlanceAPIExternal.Override.Service = ptr.To(serviceOverrides[service.EndpointPublic]) - glance.Spec.GlanceAPIInternal.Override.Service = ptr.To(serviceOverrides[service.EndpointInternal]) if glance.Spec.Secret == "" { glance.Spec.Secret = instance.Spec.Secret diff --git a/tests/kuttl/common/assert-sample-deployment.yaml b/tests/kuttl/common/assert-sample-deployment.yaml index 9e1b69611..3226bf093 100644 --- a/tests/kuttl/common/assert-sample-deployment.yaml +++ b/tests/kuttl/common/assert-sample-deployment.yaml @@ -43,6 +43,9 @@ spec: template: databaseInstance: openstack storageRequest: 10G + secret: osp-secret + glanceAPI: + replicas: 1 cinder: template: databaseInstance: openstack diff --git a/tests/kuttl/tests/collapsed/01-assert-collapsed-cell.yaml b/tests/kuttl/tests/collapsed/01-assert-collapsed-cell.yaml index 2038be6c9..977e599a6 100644 --- a/tests/kuttl/tests/collapsed/01-assert-collapsed-cell.yaml +++ b/tests/kuttl/tests/collapsed/01-assert-collapsed-cell.yaml @@ -28,6 +28,8 @@ spec: template: databaseInstance: openstack storageRequest: 10G + glanceAPI: + replicas: 1 cinder: template: databaseInstance: openstack diff --git a/tests/kuttl/tests/galera-3replicas/01-assert-galera-3replicas.yaml b/tests/kuttl/tests/galera-3replicas/01-assert-galera-3replicas.yaml index 794f381df..b3f2ebf4a 100644 --- a/tests/kuttl/tests/galera-3replicas/01-assert-galera-3replicas.yaml +++ b/tests/kuttl/tests/galera-3replicas/01-assert-galera-3replicas.yaml @@ -44,6 +44,8 @@ spec: template: databaseInstance: openstack storageRequest: 10G + glanceAPI: + replicas: 1 cinder: template: databaseInstance: openstack diff --git a/tests/kuttl/tests/galera-basic/01-assert-galera.yaml b/tests/kuttl/tests/galera-basic/01-assert-galera.yaml index ccd7a9cc0..91f17a497 100644 --- a/tests/kuttl/tests/galera-basic/01-assert-galera.yaml +++ b/tests/kuttl/tests/galera-basic/01-assert-galera.yaml @@ -44,6 +44,8 @@ spec: template: databaseInstance: openstack storageRequest: 10G + glanceAPI: + replicas: 1 cinder: template: databaseInstance: openstack