util_test.go 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. /*
  2. Copyright © The ESO Authors
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. https://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. */
  13. package util
  14. import (
  15. "context"
  16. "testing"
  17. corev1 "k8s.io/api/core/v1"
  18. metav1api "k8s.io/apimachinery/pkg/api/meta"
  19. metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
  20. "k8s.io/apimachinery/pkg/runtime/schema"
  21. "sigs.k8s.io/controller-runtime/pkg/client"
  22. "sigs.k8s.io/controller-runtime/pkg/client/apiutil"
  23. "sigs.k8s.io/controller-runtime/pkg/client/fake"
  24. esv1alpha1 "github.com/external-secrets/external-secrets/apis/externalsecrets/v1alpha1"
  25. esv2alpha1 "github.com/external-secrets/external-secrets/apis/externalsecrets/v2alpha1"
  26. )
  27. func TestClearKnownNamespaceFinalizers(t *testing.T) {
  28. t.Parallel()
  29. ctx := context.Background()
  30. cl := fake.NewClientBuilder().WithScheme(scheme).WithObjects(
  31. &corev1.Secret{
  32. ObjectMeta: metav1.ObjectMeta{
  33. Name: "target-secret",
  34. Namespace: "e2e-tests-demo-12345",
  35. Finalizers: []string{"example.com/finalizer"},
  36. },
  37. },
  38. &esv1alpha1.PushSecret{
  39. ObjectMeta: metav1.ObjectMeta{
  40. Name: "push-secret",
  41. Namespace: "e2e-tests-demo-12345",
  42. Finalizers: []string{"pushsecret.externalsecrets.io/finalizer"},
  43. },
  44. },
  45. ).Build()
  46. if err := ClearKnownNamespaceFinalizers(ctx, cl, "e2e-tests-demo-12345"); err != nil {
  47. t.Fatalf("ClearKnownNamespaceFinalizers() error = %v", err)
  48. }
  49. var secret corev1.Secret
  50. if err := cl.Get(ctx, client.ObjectKey{Name: "target-secret", Namespace: "e2e-tests-demo-12345"}, &secret); err != nil {
  51. t.Fatalf("Get(secret) error = %v", err)
  52. }
  53. if len(secret.Finalizers) != 0 {
  54. t.Fatalf("expected secret finalizers to be cleared, got %v", secret.Finalizers)
  55. }
  56. var pushSecret esv1alpha1.PushSecret
  57. if err := cl.Get(ctx, client.ObjectKey{Name: "push-secret", Namespace: "e2e-tests-demo-12345"}, &pushSecret); err != nil {
  58. t.Fatalf("Get(pushsecret) error = %v", err)
  59. }
  60. if len(pushSecret.Finalizers) != 0 {
  61. t.Fatalf("expected pushsecret finalizers to be cleared, got %v", pushSecret.Finalizers)
  62. }
  63. }
  64. func TestCleanupTerminatingE2ENamespaces(t *testing.T) {
  65. t.Parallel()
  66. ctx := context.Background()
  67. now := metav1.Now()
  68. cl := fake.NewClientBuilder().WithScheme(scheme).WithObjects(
  69. &corev1.Namespace{
  70. ObjectMeta: metav1.ObjectMeta{
  71. Name: "e2e-tests-demo-12345",
  72. Finalizers: []string{"kubernetes"},
  73. DeletionTimestamp: &now,
  74. },
  75. },
  76. &corev1.Namespace{
  77. ObjectMeta: metav1.ObjectMeta{
  78. Name: "plain-namespace",
  79. },
  80. },
  81. &corev1.Secret{
  82. ObjectMeta: metav1.ObjectMeta{
  83. Name: "target-secret",
  84. Namespace: "e2e-tests-demo-12345",
  85. Finalizers: []string{"example.com/finalizer"},
  86. },
  87. },
  88. &corev1.Secret{
  89. ObjectMeta: metav1.ObjectMeta{
  90. Name: "untouched-secret",
  91. Namespace: "plain-namespace",
  92. Finalizers: []string{"example.com/finalizer"},
  93. },
  94. },
  95. ).Build()
  96. if err := CleanupTerminatingE2ENamespaces(ctx, cl); err != nil {
  97. t.Fatalf("CleanupTerminatingE2ENamespaces() error = %v", err)
  98. }
  99. var cleaned corev1.Secret
  100. if err := cl.Get(ctx, client.ObjectKey{Name: "target-secret", Namespace: "e2e-tests-demo-12345"}, &cleaned); err != nil {
  101. t.Fatalf("Get(cleaned) error = %v", err)
  102. }
  103. if len(cleaned.Finalizers) != 0 {
  104. t.Fatalf("expected terminating e2e namespace secret finalizers to be cleared, got %v", cleaned.Finalizers)
  105. }
  106. var untouched corev1.Secret
  107. if err := cl.Get(ctx, client.ObjectKey{Name: "untouched-secret", Namespace: "plain-namespace"}, &untouched); err != nil {
  108. t.Fatalf("Get(untouched) error = %v", err)
  109. }
  110. if len(untouched.Finalizers) != 1 {
  111. t.Fatalf("expected non-e2e namespace secret finalizers to remain, got %v", untouched.Finalizers)
  112. }
  113. }
  114. func TestIsMissingAPIResourceError(t *testing.T) {
  115. t.Parallel()
  116. gv := schema.GroupVersion{Group: "generators.external-secrets.io", Version: "v1alpha1"}
  117. discoveryErr := apiutil.ErrResourceDiscoveryFailed{
  118. gv: &metav1api.NoResourceMatchError{
  119. PartialResource: gv.WithResource(""),
  120. },
  121. }
  122. if !IsMissingAPIResourceError(&discoveryErr) {
  123. t.Fatal("expected missing resource discovery failure to be treated as ignorable")
  124. }
  125. if !IsMissingAPIResourceError(&metav1api.NoResourceMatchError{}) {
  126. t.Fatal("expected no-match error to be treated as ignorable")
  127. }
  128. if IsMissingAPIResourceError(context.Canceled) {
  129. t.Fatal("did not expect unrelated errors to be treated as ignorable")
  130. }
  131. }
  132. func TestSchemeIncludesV2StoreTypes(t *testing.T) {
  133. t.Parallel()
  134. tests := []struct {
  135. name string
  136. object client.Object
  137. wantGV schema.GroupVersionKind
  138. }{
  139. {
  140. name: "ProviderStore",
  141. object: &esv2alpha1.ProviderStore{},
  142. wantGV: esv2alpha1.SchemeGroupVersion.WithKind("ProviderStore"),
  143. },
  144. {
  145. name: "ClusterProviderStore",
  146. object: &esv2alpha1.ClusterProviderStore{},
  147. wantGV: esv2alpha1.SchemeGroupVersion.WithKind("ClusterProviderStore"),
  148. },
  149. }
  150. for _, tt := range tests {
  151. tt := tt
  152. t.Run(tt.name, func(t *testing.T) {
  153. t.Parallel()
  154. gvk, err := apiutil.GVKForObject(tt.object, scheme)
  155. if err != nil {
  156. t.Fatalf("GVKForObject(%s) error = %v", tt.name, err)
  157. }
  158. if gvk != tt.wantGV {
  159. t.Fatalf("GVKForObject(%s) = %s, want %s", tt.name, gvk.String(), tt.wantGV.String())
  160. }
  161. })
  162. }
  163. }