mirror of
				https://github.com/1Password/onepassword-operator.git
				synced 2025-10-22 15:38:06 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			79 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package e2e
 | |
| 
 | |
| import (
 | |
| 	"path/filepath"
 | |
| 
 | |
| 	. "github.com/onsi/ginkgo/v2"
 | |
| 	. "github.com/onsi/gomega"
 | |
| 
 | |
| 	"github.com/1Password/onepassword-operator/pkg/testhelper/kind"
 | |
| 	"github.com/1Password/onepassword-operator/pkg/testhelper/kube"
 | |
| 	"github.com/1Password/onepassword-operator/pkg/testhelper/operator"
 | |
| 	"github.com/1Password/onepassword-operator/pkg/testhelper/system"
 | |
| )
 | |
| 
 | |
| const (
 | |
| 	operatorImageName = "1password/onepassword-operator:latest"
 | |
| )
 | |
| 
 | |
| var _ = Describe("Onepassword Operator e2e", Ordered, func() {
 | |
| 	BeforeAll(func() {
 | |
| 		kube.SetContextNamespace("default")
 | |
| 
 | |
| 		operator.BuildOperatorImage()
 | |
| 		kind.LoadImageToKind(operatorImageName)
 | |
| 
 | |
| 		By("Create Connect 'op-credentials' credentials secret")
 | |
| 		kube.CreateOpCredentialsSecret()
 | |
| 
 | |
| 		By("Checking Connect 'op-credentials' secret is created")
 | |
| 		kube.CheckSecretExists("op-credentials")
 | |
| 
 | |
| 		By("Create 'onepassword-token' secret")
 | |
| 		kube.CreateSecretFromEnvVar("OP_CONNECT_TOKEN", "onepassword-token")
 | |
| 
 | |
| 		By("Checking 'onepassword-token' secret is created")
 | |
| 		kube.CheckSecretExists("onepassword-token")
 | |
| 
 | |
| 		By("Create 'onepassword-service-account-token' secret")
 | |
| 		kube.CreateSecretFromEnvVar("OP_SERVICE_ACCOUNT_TOKEN", "onepassword-service-account-token")
 | |
| 
 | |
| 		By("Checking 'onepassword-service-account-token' secret is created")
 | |
| 		kube.CheckSecretExists("onepassword-service-account-token")
 | |
| 
 | |
| 		operator.DeployOperator()
 | |
| 		operator.WaitingForOperatorPod()
 | |
| 	})
 | |
| 
 | |
| 	Context("Use the operator with Connect", func() {
 | |
| 		BeforeAll(func() {
 | |
| 			operator.WaitingForConnectPod()
 | |
| 		})
 | |
| 
 | |
| 		runCommonTestCases()
 | |
| 	})
 | |
| 
 | |
| 	Context("Use the operator with Service Account", func() {
 | |
| 		BeforeAll(func() {
 | |
| 			kube.PatchOperatorToUseServiceAccount()
 | |
| 			kube.DeleteSecret("login") // remove secret crated in previous test
 | |
| 		})
 | |
| 
 | |
| 		runCommonTestCases()
 | |
| 	})
 | |
| })
 | |
| 
 | |
| func runCommonTestCases() {
 | |
| 	It("Should create secret from manifest file", func() {
 | |
| 		By("Creating secret")
 | |
| 		root, err := system.GetProjectRoot()
 | |
| 		Expect(err).NotTo(HaveOccurred())
 | |
| 
 | |
| 		yamlPath := filepath.Join(root, "test", "e2e", "manifests", "secret.yaml")
 | |
| 		kube.Apply(yamlPath)
 | |
| 
 | |
| 		By("Checking for secret to be created")
 | |
| 		kube.CheckSecretExists("login")
 | |
| 	})
 | |
| }
 | 
