diff --git a/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sManager.kt b/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sManager.kt index ac2165303f083be066c4398e294e456f1d268dad..f8f7f9800ecb2b19f56d3dfe85c8f9cfc153b9f5 100644 --- a/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sManager.kt +++ b/theodolite-quarkus/src/main/kotlin/theodolite/k8s/K8sManager.kt @@ -39,16 +39,35 @@ class K8sManager(private val client: NamespacedKubernetesClient) { */ fun remove(resource: KubernetesResource) { when (resource) { - is Deployment -> + is Deployment -> { + val label = resource.spec.selector.matchLabels["app"]!! this.client.apps().deployments().delete(resource) + blockUntilDeleted(label) + } is Service -> this.client.services().delete(resource) is ConfigMap -> this.client.configMaps().delete(resource) - is StatefulSet -> + is StatefulSet -> { + val label = resource.spec.selector.matchLabels["app"]!! this.client.apps().statefulSets().delete(resource) + blockUntilDeleted(label) + } is ServiceMonitorWrapper -> resource.delete(client) else -> throw IllegalArgumentException("Unknown Kubernetes resource.") } } + + + private fun blockUntilDeleted(label: String) { + var deleted = false + do { + val pods = this.client.pods().withLabel(label).list().items + if (pods.isNullOrEmpty()) { + deleted = true + } + Thread.sleep(1000) + } while (!deleted) + } + } diff --git a/theodolite-quarkus/src/main/kotlin/theodolite/patcher/EnvVarPatcher.kt b/theodolite-quarkus/src/main/kotlin/theodolite/patcher/EnvVarPatcher.kt index 16bd9aa34127b79c97e8f9d195d4757145a3fa93..b640df1da2ca1c139bb5b02e9e42bad9e7d08d74 100644 --- a/theodolite-quarkus/src/main/kotlin/theodolite/patcher/EnvVarPatcher.kt +++ b/theodolite-quarkus/src/main/kotlin/theodolite/patcher/EnvVarPatcher.kt @@ -2,7 +2,6 @@ package theodolite.patcher import io.fabric8.kubernetes.api.model.Container import io.fabric8.kubernetes.api.model.EnvVar -import io.fabric8.kubernetes.api.model.EnvVarSource import io.fabric8.kubernetes.api.model.KubernetesResource import io.fabric8.kubernetes.api.model.apps.Deployment @@ -39,7 +38,9 @@ class EnvVarPatcher( val x = container.env.filter { envVar -> envVar.name == k } if (x.isEmpty()) { - val newVar = EnvVar(k, v, EnvVarSource()) + val newVar = EnvVar() + newVar.name = k + newVar.value = v container.env.add(newVar) } else { x.forEach {