Files
onepassword-operator/test/e2e/e2e_test.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")
})
}