framework.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. /*
  2. Licensed under the Apache License, Version 2.0 (the "License");
  3. you may not use this file except in compliance with the License.
  4. You may obtain a copy of the License at
  5. http://www.apache.org/licenses/LICENSE-2.0
  6. Unless required by applicable law or agreed to in writing, software
  7. distributed under the License is distributed on an "AS IS" BASIS,
  8. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  9. See the License for the specific language governing permissions and
  10. limitations under the License.
  11. */
  12. package framework
  13. import (
  14. "os"
  15. // nolint
  16. . "github.com/onsi/ginkgo"
  17. // nolint
  18. . "github.com/onsi/gomega"
  19. api "k8s.io/api/core/v1"
  20. "k8s.io/apimachinery/pkg/runtime"
  21. "k8s.io/client-go/kubernetes"
  22. kscheme "k8s.io/client-go/kubernetes/scheme"
  23. "k8s.io/client-go/rest"
  24. "k8s.io/client-go/tools/clientcmd"
  25. crclient "sigs.k8s.io/controller-runtime/pkg/client"
  26. esv1alpha1 "github.com/external-secrets/external-secrets/apis/externalsecrets/v1alpha1"
  27. "github.com/external-secrets/external-secrets/e2e/framework/addon"
  28. "github.com/external-secrets/external-secrets/e2e/framework/util"
  29. )
  30. var Scheme = runtime.NewScheme()
  31. func init() {
  32. _ = kscheme.AddToScheme(Scheme)
  33. _ = esv1alpha1.AddToScheme(Scheme)
  34. }
  35. type Framework struct {
  36. BaseName string
  37. // KubeConfig which was used to create the connection.
  38. KubeConfig *rest.Config
  39. // Kubernetes API clientsets
  40. KubeClientSet kubernetes.Interface
  41. // controller-runtime client for newer controllers
  42. CRClient crclient.Client
  43. // Namespace in which all test resources should reside
  44. Namespace *api.Namespace
  45. Addons []addon.Addon
  46. }
  47. // New returns a new framework instance with defaults.
  48. func New(baseName string) *Framework {
  49. f := &Framework{
  50. BaseName: baseName,
  51. }
  52. f.KubeConfig, f.KubeClientSet, f.CRClient = NewConfig()
  53. BeforeEach(f.BeforeEach)
  54. AfterEach(f.AfterEach)
  55. return f
  56. }
  57. // BeforeEach creates a namespace.
  58. func (f *Framework) BeforeEach() {
  59. var err error
  60. By("Building a namespace api object")
  61. f.Namespace, err = util.CreateKubeNamespace(f.BaseName, f.KubeClientSet)
  62. Expect(err).NotTo(HaveOccurred())
  63. By("Using the namespace " + f.Namespace.Name)
  64. }
  65. // AfterEach deletes the namespace and cleans up the registered addons.
  66. func (f *Framework) AfterEach() {
  67. for _, a := range f.Addons {
  68. err := a.Uninstall()
  69. Expect(err).ToNot(HaveOccurred())
  70. }
  71. // reset addons to default once the run is done
  72. f.Addons = []addon.Addon{}
  73. By("deleting test namespace")
  74. err := util.DeleteKubeNamespace(f.Namespace.Name, f.KubeClientSet)
  75. Expect(err).NotTo(HaveOccurred())
  76. }
  77. func (f *Framework) Install(a addon.Addon) {
  78. f.Addons = append(f.Addons, a)
  79. By("installing addon")
  80. err := a.Setup(&addon.Config{
  81. KubeConfig: f.KubeConfig,
  82. KubeClientSet: f.KubeClientSet,
  83. CRClient: f.CRClient,
  84. })
  85. Expect(err).NotTo(HaveOccurred())
  86. err = a.Install()
  87. Expect(err).NotTo(HaveOccurred())
  88. }
  89. // NewConfig loads and returns the kubernetes credentials from the environment.
  90. // KUBECONFIG env var takes precedence and falls back to in-cluster config.
  91. func NewConfig() (*rest.Config, *kubernetes.Clientset, crclient.Client) {
  92. var kubeConfig *rest.Config
  93. var err error
  94. kcPath := os.Getenv("KUBECONFIG")
  95. if kcPath != "" {
  96. kubeConfig, err = clientcmd.BuildConfigFromFlags("", kcPath)
  97. Expect(err).NotTo(HaveOccurred())
  98. } else {
  99. kubeConfig, err = rest.InClusterConfig()
  100. Expect(err).NotTo(HaveOccurred())
  101. }
  102. By("creating a kubernetes client")
  103. kubeClientSet, err := kubernetes.NewForConfig(kubeConfig)
  104. Expect(err).NotTo(HaveOccurred())
  105. By("creating a controller-runtime client")
  106. CRClient, err := crclient.New(kubeConfig, crclient.Options{Scheme: Scheme})
  107. Expect(err).NotTo(HaveOccurred())
  108. return kubeConfig, kubeClientSet, CRClient
  109. }