mirror of
				https://github.com/1Password/onepassword-operator.git
				synced 2025-10-25 00:40:49 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			190 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			190 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| /*
 | |
| MIT License
 | |
| 
 | |
| Copyright (c) 2020-2022 1Password
 | |
| 
 | |
| Permission is hereby granted, free of charge, to any person obtaining a copy
 | |
| of this software and associated documentation files (the "Software"), to deal
 | |
| in the Software without restriction, including without limitation the rights
 | |
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 | |
| copies of the Software, and to permit persons to whom the Software is
 | |
| furnished to do so, subject to the following conditions:
 | |
| 
 | |
| The above copyright notice and this permission notice shall be included in all
 | |
| copies or substantial portions of the Software.
 | |
| 
 | |
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | |
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | |
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | |
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | |
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 | |
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 | |
| SOFTWARE.
 | |
| */
 | |
| 
 | |
| package controllers
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"path/filepath"
 | |
| 	"regexp"
 | |
| 	"testing"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/1Password/onepassword-operator/pkg/mocks"
 | |
| 
 | |
| 	. "github.com/onsi/ginkgo/v2"
 | |
| 	. "github.com/onsi/gomega"
 | |
| 
 | |
| 	"k8s.io/client-go/kubernetes/scheme"
 | |
| 	"k8s.io/client-go/rest"
 | |
| 	ctrl "sigs.k8s.io/controller-runtime"
 | |
| 	"sigs.k8s.io/controller-runtime/pkg/client"
 | |
| 	"sigs.k8s.io/controller-runtime/pkg/envtest"
 | |
| 	logf "sigs.k8s.io/controller-runtime/pkg/log"
 | |
| 	"sigs.k8s.io/controller-runtime/pkg/log/zap"
 | |
| 
 | |
| 	onepasswordcomv1 "github.com/1Password/onepassword-operator/api/v1"
 | |
| 	//+kubebuilder:scaffold:imports
 | |
| )
 | |
| 
 | |
| // These tests use Ginkgo (BDD-style Go testing framework). Refer to
 | |
| // http://onsi.github.io/ginkgo/ to learn more about Ginkgo.
 | |
| 
 | |
| const (
 | |
| 	username = "test-user"
 | |
| 	password = "QmHumKc$mUeEem7caHtbaBaJ"
 | |
| 
 | |
| 	username2 = "test-user2"
 | |
| 	password2 = "4zotzqDqXKasLFT2jzTs"
 | |
| 
 | |
| 	annotationRegExpString = "^operator.1password.io\\/[a-zA-Z\\.]+"
 | |
| )
 | |
| 
 | |
| // Define utility constants for object names and testing timeouts/durations and intervals.
 | |
| const (
 | |
| 	namespace = "default"
 | |
| 
 | |
| 	timeout  = time.Second * 10
 | |
| 	duration = time.Second * 10
 | |
| 	interval = time.Millisecond * 250
 | |
| )
 | |
| 
 | |
| var (
 | |
| 	cfg                       *rest.Config
 | |
| 	k8sClient                 client.Client
 | |
| 	testEnv                   *envtest.Environment
 | |
| 	ctx                       context.Context
 | |
| 	cancel                    context.CancelFunc
 | |
| 	onePasswordItemReconciler *OnePasswordItemReconciler
 | |
| 	deploymentReconciler      *DeploymentReconciler
 | |
| 
 | |
| 	item1 = &TestItem{
 | |
| 		Name:    "test-item",
 | |
| 		Version: 123,
 | |
| 		Path:    "vaults/hfnjvi6aymbsnfc2xeeoheizda/items/nwrhuano7bcwddcviubpp4mhfq",
 | |
| 		Data: map[string]string{
 | |
| 			"username": username,
 | |
| 			"password": password,
 | |
| 		},
 | |
| 		SecretData: map[string][]byte{
 | |
| 			"password": []byte(password),
 | |
| 			"username": []byte(username),
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	item2 = &TestItem{
 | |
| 		Name:    "test-item2",
 | |
| 		Path:    "vaults/hfnjvi6aymbsnfc2xeeoheizd2/items/nwrhuano7bcwddcviubpp4mhf2",
 | |
| 		Version: 456,
 | |
| 		Data: map[string]string{
 | |
| 			"username": username2,
 | |
| 			"password": password2,
 | |
| 		},
 | |
| 		SecretData: map[string][]byte{
 | |
| 			"password": []byte(password2),
 | |
| 			"username": []byte(username2),
 | |
| 		},
 | |
| 	}
 | |
| )
 | |
| 
 | |
| type TestItem struct {
 | |
| 	Name       string
 | |
| 	Version    int
 | |
| 	Path       string
 | |
| 	Data       map[string]string
 | |
| 	SecretData map[string][]byte
 | |
| }
 | |
| 
 | |
| func TestAPIs(t *testing.T) {
 | |
| 	RegisterFailHandler(Fail)
 | |
| 
 | |
| 	RunSpecs(t, "Controller Suite")
 | |
| }
 | |
| 
 | |
| var _ = BeforeSuite(func() {
 | |
| 	logf.SetLogger(zap.New(zap.WriteTo(GinkgoWriter), zap.UseDevMode(true)))
 | |
| 
 | |
| 	ctx, cancel = context.WithCancel(context.TODO())
 | |
| 
 | |
| 	By("bootstrapping test environment")
 | |
| 	testEnv = &envtest.Environment{
 | |
| 		CRDDirectoryPaths:     []string{filepath.Join("..", "config", "crd", "bases")},
 | |
| 		ErrorIfCRDPathMissing: true,
 | |
| 	}
 | |
| 
 | |
| 	var err error
 | |
| 	// cfg is defined in this file globally.
 | |
| 	cfg, err = testEnv.Start()
 | |
| 	Expect(err).NotTo(HaveOccurred())
 | |
| 	Expect(cfg).NotTo(BeNil())
 | |
| 
 | |
| 	err = onepasswordcomv1.AddToScheme(scheme.Scheme)
 | |
| 	Expect(err).NotTo(HaveOccurred())
 | |
| 
 | |
| 	//+kubebuilder:scaffold:scheme
 | |
| 
 | |
| 	k8sClient, err = client.New(cfg, client.Options{Scheme: scheme.Scheme})
 | |
| 	Expect(err).NotTo(HaveOccurred())
 | |
| 	Expect(k8sClient).NotTo(BeNil())
 | |
| 
 | |
| 	k8sManager, err := ctrl.NewManager(cfg, ctrl.Options{
 | |
| 		Scheme: scheme.Scheme,
 | |
| 	})
 | |
| 	Expect(err).ToNot(HaveOccurred())
 | |
| 
 | |
| 	opConnectClient := &mocks.TestClient{}
 | |
| 
 | |
| 	onePasswordItemReconciler = &OnePasswordItemReconciler{
 | |
| 		Client:          k8sManager.GetClient(),
 | |
| 		Scheme:          k8sManager.GetScheme(),
 | |
| 		OpConnectClient: opConnectClient,
 | |
| 	}
 | |
| 	err = (onePasswordItemReconciler).SetupWithManager(k8sManager)
 | |
| 	Expect(err).ToNot(HaveOccurred())
 | |
| 
 | |
| 	r, _ := regexp.Compile(annotationRegExpString)
 | |
| 	deploymentReconciler = &DeploymentReconciler{
 | |
| 		Client:             k8sManager.GetClient(),
 | |
| 		Scheme:             k8sManager.GetScheme(),
 | |
| 		OpConnectClient:    opConnectClient,
 | |
| 		OpAnnotationRegExp: r,
 | |
| 	}
 | |
| 	err = (deploymentReconciler).SetupWithManager(k8sManager)
 | |
| 	Expect(err).ToNot(HaveOccurred())
 | |
| 
 | |
| 	go func() {
 | |
| 		defer GinkgoRecover()
 | |
| 		err = k8sManager.Start(ctx)
 | |
| 		Expect(err).ToNot(HaveOccurred(), "failed to run manager")
 | |
| 	}()
 | |
| 
 | |
| })
 | |
| 
 | |
| var _ = AfterSuite(func() {
 | |
| 	cancel()
 | |
| 	By("tearing down the test environment")
 | |
| 	err := testEnv.Stop()
 | |
| 	Expect(err).NotTo(HaveOccurred())
 | |
| })
 | 
