Add ClusterIP service to impersonator-config-controller informer.
Prior to this fix, this controller did not correctly react to changes to the ClusterIP service. It would still eventually react with a long delay due to our 5 minute resync interval. Signed-off-by: Matt Moyer <moyerm@vmware.com>
This commit is contained in:
parent
8afbb4eb4f
commit
5f679059d5
@ -143,7 +143,15 @@ func NewImpersonatorConfigController(
|
|||||||
withInformer(
|
withInformer(
|
||||||
servicesInformer,
|
servicesInformer,
|
||||||
pinnipedcontroller.SimpleFilterWithSingletonQueue(func(obj metav1.Object) bool {
|
pinnipedcontroller.SimpleFilterWithSingletonQueue(func(obj metav1.Object) bool {
|
||||||
return obj.GetNamespace() == namespace && obj.GetName() == generatedLoadBalancerServiceName
|
if obj.GetNamespace() != namespace {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
switch obj.GetName() {
|
||||||
|
case generatedLoadBalancerServiceName, generatedClusterIPServiceName:
|
||||||
|
return true
|
||||||
|
default:
|
||||||
|
return false
|
||||||
|
}
|
||||||
}),
|
}),
|
||||||
controllerlib.InformerOption{},
|
controllerlib.InformerOption{},
|
||||||
),
|
),
|
||||||
|
@ -131,11 +131,12 @@ func TestImpersonatorConfigControllerOptions(t *testing.T) {
|
|||||||
|
|
||||||
when("watching Service objects", func() {
|
when("watching Service objects", func() {
|
||||||
var subject controllerlib.Filter
|
var subject controllerlib.Filter
|
||||||
var target, wrongNamespace, wrongName, unrelated *corev1.Service
|
var targetLBService, targetClusterIPService, wrongNamespace, wrongName, unrelated *corev1.Service
|
||||||
|
|
||||||
it.Before(func() {
|
it.Before(func() {
|
||||||
subject = servicesInformerFilter
|
subject = servicesInformerFilter
|
||||||
target = &corev1.Service{ObjectMeta: metav1.ObjectMeta{Name: generatedLoadBalancerServiceName, Namespace: installedInNamespace}}
|
targetLBService = &corev1.Service{ObjectMeta: metav1.ObjectMeta{Name: generatedLoadBalancerServiceName, Namespace: installedInNamespace}}
|
||||||
|
targetClusterIPService = &corev1.Service{ObjectMeta: metav1.ObjectMeta{Name: generatedClusterIPServiceName, Namespace: installedInNamespace}}
|
||||||
wrongNamespace = &corev1.Service{ObjectMeta: metav1.ObjectMeta{Name: generatedLoadBalancerServiceName, Namespace: "wrong-namespace"}}
|
wrongNamespace = &corev1.Service{ObjectMeta: metav1.ObjectMeta{Name: generatedLoadBalancerServiceName, Namespace: "wrong-namespace"}}
|
||||||
wrongName = &corev1.Service{ObjectMeta: metav1.ObjectMeta{Name: "wrong-name", Namespace: installedInNamespace}}
|
wrongName = &corev1.Service{ObjectMeta: metav1.ObjectMeta{Name: "wrong-name", Namespace: installedInNamespace}}
|
||||||
unrelated = &corev1.Service{ObjectMeta: metav1.ObjectMeta{Name: "wrong-name", Namespace: "wrong-namespace"}}
|
unrelated = &corev1.Service{ObjectMeta: metav1.ObjectMeta{Name: "wrong-name", Namespace: "wrong-namespace"}}
|
||||||
@ -143,10 +144,14 @@ func TestImpersonatorConfigControllerOptions(t *testing.T) {
|
|||||||
|
|
||||||
when("the target Service changes", func() {
|
when("the target Service changes", func() {
|
||||||
it("returns true to trigger the sync method", func() {
|
it("returns true to trigger the sync method", func() {
|
||||||
r.True(subject.Add(target))
|
r.True(subject.Add(targetLBService))
|
||||||
r.True(subject.Update(target, unrelated))
|
r.True(subject.Update(targetLBService, unrelated))
|
||||||
r.True(subject.Update(unrelated, target))
|
r.True(subject.Update(unrelated, targetLBService))
|
||||||
r.True(subject.Delete(target))
|
r.True(subject.Delete(targetLBService))
|
||||||
|
r.True(subject.Add(targetClusterIPService))
|
||||||
|
r.True(subject.Update(targetClusterIPService, unrelated))
|
||||||
|
r.True(subject.Update(unrelated, targetClusterIPService))
|
||||||
|
r.True(subject.Delete(targetClusterIPService))
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user