Files
Reloader/test/e2e/advanced/regex_test.go
2026-01-08 11:06:45 +01:00

135 lines
5.2 KiB
Go

package advanced
import (
"time"
. "github.com/onsi/ginkgo/v2"
. "github.com/onsi/gomega"
"github.com/stakater/Reloader/test/e2e/utils"
)
var _ = Describe("Regex Pattern Tests", func() {
var (
deploymentName string
matchingCM string
nonMatchingCM string
matchingSecret string
)
BeforeEach(func() {
deploymentName = utils.RandName("deploy")
matchingCM = "app-config-" + utils.RandName("cm")
nonMatchingCM = "other-" + utils.RandName("cm")
matchingSecret = "app-secret-" + utils.RandName("secret")
})
AfterEach(func() {
_ = utils.DeleteDeployment(ctx, kubeClient, testNamespace, deploymentName)
_ = utils.DeleteConfigMap(ctx, kubeClient, testNamespace, matchingCM)
_ = utils.DeleteConfigMap(ctx, kubeClient, testNamespace, nonMatchingCM)
_ = utils.DeleteSecret(ctx, kubeClient, testNamespace, matchingSecret)
})
Context("ConfigMap regex pattern", func() {
It("should reload when ConfigMap matching pattern changes", func() {
By("Creating a ConfigMap matching the pattern")
_, err := utils.CreateConfigMap(ctx, kubeClient, testNamespace, matchingCM,
map[string]string{"key": "initial"}, nil)
Expect(err).NotTo(HaveOccurred())
By("Creating a Deployment with ConfigMap pattern annotation")
_, err = utils.CreateDeployment(ctx, kubeClient, testNamespace, deploymentName,
utils.WithConfigMapEnvFrom(matchingCM),
utils.WithAnnotations(map[string]string{
utils.AnnotationConfigMapReload: "app-config-.*",
}),
)
Expect(err).NotTo(HaveOccurred())
By("Waiting for Deployment to be ready")
err = utils.WaitForDeploymentReady(ctx, kubeClient, testNamespace, deploymentName, utils.DeploymentReady)
Expect(err).NotTo(HaveOccurred())
By("Updating the matching ConfigMap")
err = utils.UpdateConfigMap(ctx, kubeClient, testNamespace, matchingCM,
map[string]string{"key": "updated"})
Expect(err).NotTo(HaveOccurred())
By("Waiting for Deployment to be reloaded")
reloaded, err := utils.WaitForDeploymentReloaded(ctx, kubeClient, testNamespace, deploymentName,
utils.AnnotationLastReloadedFrom, utils.ReloadTimeout)
Expect(err).NotTo(HaveOccurred())
Expect(reloaded).To(BeTrue(), "Deployment should be reloaded when matching ConfigMap changes")
})
It("should NOT reload when ConfigMap NOT matching pattern changes", func() {
By("Creating ConfigMaps - one matching, one not")
_, err := utils.CreateConfigMap(ctx, kubeClient, testNamespace, matchingCM,
map[string]string{"key": "initial"}, nil)
Expect(err).NotTo(HaveOccurred())
_, err = utils.CreateConfigMap(ctx, kubeClient, testNamespace, nonMatchingCM,
map[string]string{"other": "initial"}, nil)
Expect(err).NotTo(HaveOccurred())
By("Creating a Deployment with ConfigMap pattern annotation")
_, err = utils.CreateDeployment(ctx, kubeClient, testNamespace, deploymentName,
utils.WithConfigMapEnvFrom(matchingCM),
utils.WithAnnotations(map[string]string{
utils.AnnotationConfigMapReload: "app-config-.*",
}),
)
Expect(err).NotTo(HaveOccurred())
By("Waiting for Deployment to be ready")
err = utils.WaitForDeploymentReady(ctx, kubeClient, testNamespace, deploymentName, utils.DeploymentReady)
Expect(err).NotTo(HaveOccurred())
By("Updating the non-matching ConfigMap")
err = utils.UpdateConfigMap(ctx, kubeClient, testNamespace, nonMatchingCM,
map[string]string{"other": "updated"})
Expect(err).NotTo(HaveOccurred())
By("Verifying Deployment was NOT reloaded (pattern mismatch)")
time.Sleep(utils.NegativeTestWait)
reloaded, err := utils.WaitForDeploymentReloaded(ctx, kubeClient, testNamespace, deploymentName,
utils.AnnotationLastReloadedFrom, utils.ShortTimeout)
Expect(err).NotTo(HaveOccurred())
Expect(reloaded).To(BeFalse(), "Deployment should NOT reload when non-matching ConfigMap changes")
})
})
Context("Secret regex pattern", func() {
It("should reload when Secret matching pattern changes", func() {
By("Creating a Secret matching the pattern")
_, err := utils.CreateSecretFromStrings(ctx, kubeClient, testNamespace, matchingSecret,
map[string]string{"password": "initial"}, nil)
Expect(err).NotTo(HaveOccurred())
By("Creating a Deployment with Secret pattern annotation")
_, err = utils.CreateDeployment(ctx, kubeClient, testNamespace, deploymentName,
utils.WithSecretEnvFrom(matchingSecret),
utils.WithAnnotations(map[string]string{
utils.AnnotationSecretReload: "app-secret-.*",
}),
)
Expect(err).NotTo(HaveOccurred())
By("Waiting for Deployment to be ready")
err = utils.WaitForDeploymentReady(ctx, kubeClient, testNamespace, deploymentName, utils.DeploymentReady)
Expect(err).NotTo(HaveOccurred())
By("Updating the matching Secret")
err = utils.UpdateSecretFromStrings(ctx, kubeClient, testNamespace, matchingSecret,
map[string]string{"password": "updated"})
Expect(err).NotTo(HaveOccurred())
By("Waiting for Deployment to be reloaded")
reloaded, err := utils.WaitForDeploymentReloaded(ctx, kubeClient, testNamespace, deploymentName,
utils.AnnotationLastReloadedFrom, utils.ReloadTimeout)
Expect(err).NotTo(HaveOccurred())
Expect(reloaded).To(BeTrue(), "Deployment should be reloaded when matching Secret changes")
})
})
})