From e5bf9f75f12b90c0744b3f682ce08d85862008a3 Mon Sep 17 00:00:00 2001 From: Jing Qi Date: Mon, 9 Sep 2024 08:24:36 +0800 Subject: [PATCH] feat(RELEASE-1043): add e2e test for rhel-ai pipeline Signed-off-by: Jing Qi --- pkg/clients/release/plans.go | 62 ++-- tests/build/build.go | 2 +- tests/konflux-demo/konflux-demo.go | 2 +- tests/release/pipelines/fbc_release.go | 2 +- .../release/pipelines/multiarch_advisories.go | 2 +- .../pipelines/push_disk_images_to_cdn.go | 278 ++++++++++++++++++ .../pipelines/push_to_external_registry.go | 2 +- tests/release/pipelines/release_to_github.go | 2 +- tests/release/pipelines/rh_advisories.go | 2 +- .../pipelines/rh_push_to_external_registry.go | 2 +- .../release/pipelines/rh_push_to_redhat_io.go | 2 +- tests/release/pipelines/rhtap_service_push.go | 2 +- .../missing_release_plan_and_admission.go | 2 +- .../release_plan_and_admission_matched.go | 2 +- 14 files changed, 334 insertions(+), 30 deletions(-) create mode 100644 tests/release/pipelines/push_disk_images_to_cdn.go diff --git a/pkg/clients/release/plans.go b/pkg/clients/release/plans.go index 885b1251dc..674691b697 100644 --- a/pkg/clients/release/plans.go +++ b/pkg/clients/release/plans.go @@ -10,6 +10,7 @@ import ( releaseApi "github.com/konflux-ci/release-service/api/v1alpha1" releaseMetadata "github.com/konflux-ci/release-service/metadata" k8sErrors "k8s.io/apimachinery/pkg/api/errors" + tektonv1 "github.com/tektoncd/pipeline/pkg/apis/pipeline/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/types" ) @@ -43,26 +44,51 @@ func (r *ReleaseController) CreateReleasePlan(name, namespace, application, targ } // CreateReleasePlanAdmission creates a new ReleasePlanAdmission using the given parameters. -func (r *ReleaseController) CreateReleasePlanAdmission(name, namespace, environment, origin, policy, serviceAccountName string, applications []string, autoRelease bool, pipelineRef *tektonutils.PipelineRef, data *runtime.RawExtension) (*releaseApi.ReleasePlanAdmission, error) { - releasePlanAdmission := &releaseApi.ReleasePlanAdmission{ - ObjectMeta: metav1.ObjectMeta{ - Name: name, - Namespace: namespace, - Labels: map[string]string{ - releaseMetadata.AutoReleaseLabel: strconv.FormatBool(autoRelease), +func (r *ReleaseController) CreateReleasePlanAdmission(name, namespace, environment, origin, policy, serviceAccountName string, applications []string, autoRelease bool, pipelineRef *tektonutils.PipelineRef, data *runtime.RawExtension, timeouts *tektonv1.TimeoutFields) (*releaseApi.ReleasePlanAdmission, error) { + var releasePlanAdmission *releaseApi.ReleasePlanAdmission + if timeouts != nil { + releasePlanAdmission = &releaseApi.ReleasePlanAdmission{ + ObjectMeta: metav1.ObjectMeta{ + Name: name, + Namespace: namespace, + Labels: map[string]string{ + releaseMetadata.AutoReleaseLabel: strconv.FormatBool(autoRelease), + }, }, - }, - Spec: releaseApi.ReleasePlanAdmissionSpec{ - Applications: applications, - Data: data, - Environment: environment, - Origin: origin, - Pipeline: &tektonutils.Pipeline{ - PipelineRef: *pipelineRef, - ServiceAccountName: serviceAccountName, + Spec: releaseApi.ReleasePlanAdmissionSpec{ + Applications: applications, + Data: data, + Environment: environment, + Origin: origin, + Pipeline: &tektonutils.Pipeline{ + PipelineRef: *pipelineRef, + ServiceAccountName: serviceAccountName, + Timeouts: *timeouts, + }, + Policy: policy, }, - Policy: policy, - }, + } + } else { + releasePlanAdmission = &releaseApi.ReleasePlanAdmission{ + ObjectMeta: metav1.ObjectMeta{ + Name: name, + Namespace: namespace, + Labels: map[string]string{ + releaseMetadata.AutoReleaseLabel: strconv.FormatBool(autoRelease), + }, + }, + Spec: releaseApi.ReleasePlanAdmissionSpec{ + Applications: applications, + Data: data, + Environment: environment, + Origin: origin, + Pipeline: &tektonutils.Pipeline{ + PipelineRef: *pipelineRef, + ServiceAccountName: serviceAccountName, + }, + Policy: policy, + }, + } } return releasePlanAdmission, r.KubeRest().Create(context.Background(), releasePlanAdmission) diff --git a/tests/build/build.go b/tests/build/build.go index 1365d9afc5..23e0e283d0 100644 --- a/tests/build/build.go +++ b/tests/build/build.go @@ -1506,7 +1506,7 @@ var _ = framework.BuildSuiteDescribe("Build service E2E tests", Label("build-ser {Name: "url", Value: constants.RELEASE_CATALOG_DEFAULT_URL}, {Name: "revision", Value: constants.RELEASE_CATALOG_DEFAULT_REVISION}, {Name: "pathInRepo", Value: "pipelines/e2e/e2e.yaml"}, - }}, &runtime.RawExtension{Raw: rawData}) + }}, &runtime.RawExtension{Raw: rawData}, nil) Expect(err).NotTo(HaveOccurred()) }) diff --git a/tests/konflux-demo/konflux-demo.go b/tests/konflux-demo/konflux-demo.go index 370376bb45..4db4fe9318 100644 --- a/tests/konflux-demo/konflux-demo.go +++ b/tests/konflux-demo/konflux-demo.go @@ -462,7 +462,7 @@ func createReleaseConfig(fw framework.Framework, managedNamespace, componentName {Name: "revision", Value: releasecommon.RelSvcCatalogRevision}, {Name: "pathInRepo", Value: "pipelines/e2e/e2e.yaml"}, }, - }, nil) + }, nil, nil) Expect(err).NotTo(HaveOccurred()) _, err = fw.AsKubeAdmin.TektonController.CreatePVCInAccessMode("release-pvc", managedNamespace, corev1.ReadWriteOnce) diff --git a/tests/release/pipelines/fbc_release.go b/tests/release/pipelines/fbc_release.go index 4af00a8e94..5dff6196d0 100644 --- a/tests/release/pipelines/fbc_release.go +++ b/tests/release/pipelines/fbc_release.go @@ -321,6 +321,6 @@ func createFBCReleasePlanAdmission(fbcRPAName string, managedFw framework.Framew }, }, &runtime.RawExtension{ Raw: data, - }) + }, nil) Expect(err).NotTo(HaveOccurred()) } diff --git a/tests/release/pipelines/multiarch_advisories.go b/tests/release/pipelines/multiarch_advisories.go index 0898c507c4..20a055834b 100644 --- a/tests/release/pipelines/multiarch_advisories.go +++ b/tests/release/pipelines/multiarch_advisories.go @@ -271,6 +271,6 @@ func createMultiArchReleasePlanAdmission(multiarchRPAName string, managedFw fram }, }, &runtime.RawExtension{ Raw: data, - }) + }, nil) Expect(err).NotTo(HaveOccurred()) } diff --git a/tests/release/pipelines/push_disk_images_to_cdn.go b/tests/release/pipelines/push_disk_images_to_cdn.go new file mode 100644 index 0000000000..50e0c007df --- /dev/null +++ b/tests/release/pipelines/push_disk_images_to_cdn.go @@ -0,0 +1,278 @@ +package pipelines + +import ( + "encoding/json" + "fmt" + "time" + + appservice "github.com/konflux-ci/application-api/api/v1alpha1" + ecp "github.com/enterprise-contract/enterprise-contract-controller/api/v1alpha1" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + releasecommon "github.com/konflux-ci/e2e-tests/tests/release" + releaseapi "github.com/konflux-ci/release-service/api/v1alpha1" + tektonutils "github.com/konflux-ci/release-service/tekton/utils" + tektonv1 "github.com/tektoncd/pipeline/pkg/apis/pipeline/v1" + + "github.com/devfile/library/v2/pkg/util" + "github.com/konflux-ci/e2e-tests/pkg/constants" + "github.com/konflux-ci/e2e-tests/pkg/framework" + "github.com/konflux-ci/e2e-tests/pkg/utils" + "github.com/konflux-ci/e2e-tests/pkg/utils/tekton" + "k8s.io/apimachinery/pkg/runtime" + "knative.dev/pkg/apis" + + . "github.com/onsi/ginkgo/v2" + . "github.com/onsi/gomega" +) + +const ( + rhaiServiceAccountName = "release-service-account" + rhaiCatalogPathInRepo = "pipelines/push-disk-images-to-cdn/push-disk-images-to-cdn.yaml" + rhaiGitSourceURL = "https://gitlab.com/redhat/rhel-ai/disk-images/nvidia-bootc" + rhaiGitSrcSHA = "5b0ad5399cac20d8d7e321566a3ac3baa82ff91f" +) + +var rhaiComponentName = "rhai-comp-" + util.GenerateRandomString(4) + +var _ = framework.ReleasePipelinesSuiteDescribe("e2e tests for push-disk-images-to-cdn pipeline", Label("release-pipelines", "push-disk-images-to-cdn"), func() { + defer GinkgoRecover() + + var devWorkspace = utils.GetEnv(constants.RELEASE_DEV_WORKSPACE_ENV, constants.DevReleaseTeam) + var managedWorkspace = utils.GetEnv(constants.RELEASE_MANAGED_WORKSPACE_ENV, constants.ManagedReleaseTeam) + + var devNamespace = devWorkspace + "-tenant" + var managedNamespace = managedWorkspace + "-tenant" + + var err error + var devFw *framework.Framework + var managedFw *framework.Framework + var rhaiApplicationName = "rhai-app-" + util.GenerateRandomString(4) + var rhaiReleasePlanName = "rhai-rp-" + util.GenerateRandomString(4) + var rhaiReleasePlanAdmissionName = "rhai-rpa-" + util.GenerateRandomString(4) + var rhaiEnterpriseContractPolicyName = "rhai-policy-" + util.GenerateRandomString(4) + var sampleImage = "quay.io/hacbs-release-tests/disk-image-test@sha256:a56644589bed7c7d939e5aa9475131bda64f24a9b3e52defa5751a1d6774232f" + + var snapshotPush *appservice.Snapshot + var releaseCR *releaseapi.Release + + AfterEach(framework.ReportFailure(&devFw)) + + Describe("Push-disk-images-to-cdn happy path", Label("PushDisk"), func() { + BeforeAll(func() { + devFw = releasecommon.NewFramework(devWorkspace) + managedFw = releasecommon.NewFramework(managedWorkspace) + + managedNamespace = managedFw.UserNamespace + + err = managedFw.AsKubeAdmin.CommonController.LinkSecretToServiceAccount(managedNamespace, releasecommon.RedhatAppstudioUserSecret, constants.DefaultPipelineServiceAccount, true) + Expect(err).ToNot(HaveOccurred()) + + _, err = devFw.AsKubeDeveloper.HasController.CreateApplication(rhaiApplicationName, devNamespace) + Expect(err).NotTo(HaveOccurred()) + + _, err = devFw.AsKubeDeveloper.ReleaseController.CreateReleasePlan(rhaiReleasePlanName, devNamespace, rhaiApplicationName, managedNamespace, "true", nil, nil) + Expect(err).NotTo(HaveOccurred()) + + createRHAIReleasePlanAdmission(rhaiReleasePlanAdmissionName, *managedFw, devNamespace, managedNamespace, rhaiApplicationName, rhaiEnterpriseContractPolicyName, rhaiCatalogPathInRepo) + + createRHAIEnterpriseContractPolicy(rhaiEnterpriseContractPolicyName, *managedFw, devNamespace, managedNamespace) + + snapshotPush, err = releasecommon.CreateSnapshotWithImageSource(*devFw, rhaiComponentName, rhaiApplicationName, devNamespace, sampleImage, rhaiGitSourceURL, rhaiGitSrcSHA, "", "", "", "") + Expect(err).ShouldNot(HaveOccurred()) + }) + + AfterAll(func() { + devFw = releasecommon.NewFramework(devWorkspace) + managedFw = releasecommon.NewFramework(managedWorkspace) + Expect(devFw.AsKubeDeveloper.HasController.DeleteApplication(rhaiApplicationName, devNamespace, false)).NotTo(HaveOccurred()) + Expect(managedFw.AsKubeDeveloper.TektonController.DeleteEnterpriseContractPolicy(rhaiEnterpriseContractPolicyName, managedNamespace, false)).NotTo(HaveOccurred()) + Expect(managedFw.AsKubeDeveloper.ReleaseController.DeleteReleasePlanAdmission(rhaiReleasePlanAdmissionName, managedNamespace, false)).NotTo(HaveOccurred()) + }) + + var _ = Describe("Post-release verification", func() { + + It("verifies the rhai release pipelinerun is running and succeeds", func() { + Eventually(func() error { + releaseCR, err = devFw.AsKubeDeveloper.ReleaseController.GetRelease("", snapshotPush.Name, devNamespace) + if err != nil { + return err + } + return nil + }, 10*time.Minute, releasecommon.DefaultInterval).Should(Succeed()) + + Eventually(func() error { + pipelineRun, err := managedFw.AsKubeAdmin.ReleaseController.GetPipelineRunInNamespace(managedNamespace, releaseCR.GetName(), releaseCR.GetNamespace()) + if err != nil { + return fmt.Errorf("PipelineRun has not been created yet for release %s/%s", releaseCR.GetNamespace(), releaseCR.GetName()) + } + + for _, condition := range pipelineRun.Status.Conditions { + GinkgoWriter.Printf("PipelineRun %s reason: %s\n", pipelineRun.Name, condition.Reason) + } + + if !pipelineRun.IsDone(){ + return fmt.Errorf("PipelineRun %s has still not finished yet", pipelineRun.Name) + } + + if pipelineRun.GetStatusCondition().GetCondition(apis.ConditionSucceeded).IsTrue() { + return nil + } else { + prLogs := "" + if prLogs, err = tekton.GetFailedPipelineRunLogs(managedFw.AsKubeAdmin.ReleaseController.KubeRest(), managedFw.AsKubeAdmin.ReleaseController.KubeInterface(), pipelineRun); err != nil { + GinkgoWriter.Printf("failed to get PLR logs: %+v", err) + Expect(err).ShouldNot(HaveOccurred()) + return nil + } + GinkgoWriter.Printf("logs: %s", prLogs) + Expect(prLogs).To(Equal(""), fmt.Sprintf("PipelineRun %s failed", pipelineRun.Name)) + return nil + } + }, releasecommon.BuildPipelineRunCompletionTimeout, releasecommon.DefaultInterval).Should(Succeed(), fmt.Sprintf("timed out when waiting for the release PipelineRun to be finished for the release %s/%s", releaseCR.GetName(), releaseCR.GetNamespace())) + }) + + It("verifies release CR completed and set succeeded.", func() { + Eventually(func() error { + releaseCR, err = devFw.AsKubeDeveloper.ReleaseController.GetRelease("", snapshotPush.Name, devNamespace) + if err != nil { + return err + } + GinkgoWriter.Printf("releaseCR: %s", releaseCR.Name) + conditions := releaseCR.Status.Conditions + GinkgoWriter.Printf("len of conditions: %d", len(conditions)) + if len(conditions) > 0 { + for _, c := range conditions { + GinkgoWriter.Printf("type of c: %s", c.Type) + if c.Type == "Released" { + GinkgoWriter.Printf("status of c: %s", c.Status) + if c.Status == "True" { + GinkgoWriter.Println("Release CR is released") + return nil + } else if c.Status == "False" { + GinkgoWriter.Println("Release CR failed") + Expect(string(c.Status)).To(Equal("True"), fmt.Sprintf("Release %s failed", releaseCR.Name)) + return nil + } else { + return fmt.Errorf("release %s/%s is not marked as finished yet", releaseCR.GetNamespace(), releaseCR.GetName()) + } + } + } + } + return nil + }, releasecommon.ReleaseCreationTimeout, releasecommon.DefaultInterval).Should(Succeed()) + }) + + }) + }) +}) + +func createRHAIEnterpriseContractPolicy(rhaiECPName string, managedFw framework.Framework, devNamespace, managedNamespace string) { + releasePublicKeyDecoded := []byte("-----BEGIN PUBLIC KEY-----\n" + + "MFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEHHTvfqOgdrdt9TXDyYDMYlwZ8r8r\n" + + "AsiNjiVlB/DrkEdj3mNgxW7Papn1MgtxqRL/gJ3Jql2Z9tOYKNA08ojFAg==\n" + + "-----END PUBLIC KEY-----") + Expect(managedFw.AsKubeAdmin.TektonController.CreateOrUpdateSigningSecret( + releasePublicKeyDecoded, releasecommon.PublicSecretNameAuth, managedNamespace)).To(Succeed()) + err = managedFw.AsKubeAdmin.CommonController.LinkSecretToServiceAccount(managedNamespace, releasecommon.PublicSecretNameAuth, rhaiServiceAccountName, true) + Expect(err).ToNot(HaveOccurred()) + + _, _ = managedFw.AsKubeAdmin.CommonController.CreateRole("role-release-service-account", managedNamespace, map[string][]string{ + "apiGroupsList": {""}, + "roleResources": {"secrets"}, + "roleVerbs": {"get", "list", "watch"}, + }) + + _, _ = managedFw.AsKubeAdmin.CommonController.CreateRoleBinding("role-release-service-account-binding", managedNamespace, "ServiceAccount", "release-service-account", managedNamespace, "Role", "role-release-service-account", "rbac.authorization.k8s.io") + + defaultEcPolicySpec := ecp.EnterpriseContractPolicySpec{ + Description: "Red Hat's enterprise requirements", + PublicKey: fmt.Sprintf("k8s://%s/%s", managedNamespace, releasecommon.PublicSecretNameAuth), + Sources: []ecp.Source{{ + Name: "Default", + Policy: []string{releasecommon.EcPolicyLibPath, releasecommon.EcPolicyReleasePath}, + Data: []string{releasecommon.EcPolicyDataBundle, releasecommon.EcPolicyDataPath}, + }}, + Configuration: &ecp.EnterpriseContractPolicyConfiguration{ + Exclude: []string{"step_image_registries", "tasks.required_tasks_found:prefetch-dependencies"}, + Include: []string{"@slsa3"}, + }, + } + + _, err := managedFw.AsKubeDeveloper.TektonController.CreateEnterpriseContractPolicy(rhaiECPName, managedNamespace, defaultEcPolicySpec) + Expect(err).NotTo(HaveOccurred()) + +} + +func createRHAIReleasePlanAdmission(rhaiRPAName string, managedFw framework.Framework, devNamespace, managedNamespace, rhaiAppName, rhaiECPName, pathInRepoValue string) { + var err error + + data, err := json.Marshal(map[string]interface{}{ + "mapping": map[string]interface{}{ + "components": []map[string]interface{}{ + { + "name": rhaiComponentName, + "staged": map[string]interface{}{ + "destination": "rhelai-1_DOT_1-for-rhel-9-x86_64-isos", + "version": "1.1", + "files": []map[string]interface{}{ + { + "filename": "rhel-ai-nvidia-1.1-{{ timestamp }}"+util.GenerateRandomString(4)+"-x86_64-kvm.qcow2", + "source": "disk.qcow2", + }, + /* comment below disk to save time for testing + { + "filename": "rhel-ai-nvidia-1.1"+"-{{ timestamp }}"+util.GenerateRandomString(4)+"-x86_64.raw", + "source": "disk.raw", + }, + { + "filename": "rhel-ai-nvidia-1.1"+"-{{ timestamp }}"+util.GenerateRandomString(4)+"-x86_64-boot.iso", + "source": "install.iso", + }, + */ + }, + }, + "contentGateway": map[string]interface{}{ + "productName": "E2ETest Red Hat Enterprise Linux AI", + "productCode": "RHELAIE2ETest", + "productVersionName": "RHELAI 1.1", + "filePrefix": "rhel-ai-nvidia-1.1", + }, + }, + }, + }, + "tags": []string{"time-{{ timestamp }}", "git-{{ git_sha }}" }, + "cdn": map[string]interface{}{ + "env": "stage", + }, + "sign": map[string]interface{}{ + "configMapName": "hacbs-signing-pipeline-config-redhatbeta2", + }, + "pyxis": map[string]interface{}{ + "server": "stage", + "secret": "pyxis", + }, + "releaseNotes": map[string]interface{}{ + "product_id": "932", + "product_name": "E2ETest Red Hat Enterprise Linux AI", + "product_version": "1.1", + "type": "RHSA", + }, + }) + Expect(err).NotTo(HaveOccurred()) + + timeouts := &tektonv1.TimeoutFields{ + Pipeline: &metav1.Duration{Duration: 4 * time.Hour}, + Tasks: &metav1.Duration{Duration: 2 * time.Hour}, + } + + _, err = managedFw.AsKubeAdmin.ReleaseController.CreateReleasePlanAdmission(rhaiRPAName, managedNamespace, "", devNamespace, rhaiECPName, rhaiServiceAccountName, []string{rhaiAppName}, true, &tektonutils.PipelineRef{ + Resolver: "git", + Params: []tektonutils.Param{ + {Name: "url", Value: releasecommon.RelSvcCatalogURL}, + {Name: "revision", Value: releasecommon.RelSvcCatalogRevision}, + {Name: "pathInRepo", Value: pathInRepoValue}, + }, + }, &runtime.RawExtension{ + Raw: data, + }, timeouts) + Expect(err).NotTo(HaveOccurred()) +} diff --git a/tests/release/pipelines/push_to_external_registry.go b/tests/release/pipelines/push_to_external_registry.go index 2c2cebfecc..344491939c 100644 --- a/tests/release/pipelines/push_to_external_registry.go +++ b/tests/release/pipelines/push_to_external_registry.go @@ -113,7 +113,7 @@ var _ = framework.ReleasePipelinesSuiteDescribe("Push to external registry", Lab }, }, &runtime.RawExtension{ Raw: data, - }) + }, nil) Expect(err).NotTo(HaveOccurred()) _, err = fw.AsKubeAdmin.TektonController.CreatePVCInAccessMode(releasecommon.ReleasePvcName, managedNamespace, corev1.ReadWriteOnce) diff --git a/tests/release/pipelines/release_to_github.go b/tests/release/pipelines/release_to_github.go index 6c45ff1bc8..5418609b82 100644 --- a/tests/release/pipelines/release_to_github.go +++ b/tests/release/pipelines/release_to_github.go @@ -231,6 +231,6 @@ func createGHReleasePlanAdmission(sampRPAName string, managedFw framework.Framew }, }, &runtime.RawExtension{ Raw: data, - }) + }, nil) Expect(err).NotTo(HaveOccurred()) } diff --git a/tests/release/pipelines/rh_advisories.go b/tests/release/pipelines/rh_advisories.go index 4a703773c0..d914fd5470 100644 --- a/tests/release/pipelines/rh_advisories.go +++ b/tests/release/pipelines/rh_advisories.go @@ -271,6 +271,6 @@ func createADVSReleasePlanAdmission(advsRPAName string, managedFw framework.Fram }, }, &runtime.RawExtension{ Raw: data, - }) + }, nil) Expect(err).NotTo(HaveOccurred()) } diff --git a/tests/release/pipelines/rh_push_to_external_registry.go b/tests/release/pipelines/rh_push_to_external_registry.go index 228ba7162d..ceb66c309f 100644 --- a/tests/release/pipelines/rh_push_to_external_registry.go +++ b/tests/release/pipelines/rh_push_to_external_registry.go @@ -166,7 +166,7 @@ var _ = framework.ReleasePipelinesSuiteDescribe("[HACBS-1571]test-release-e2e-pu }, }, &runtime.RawExtension{ Raw: data, - }) + }, nil) Expect(err).NotTo(HaveOccurred()) _, err = fw.AsKubeAdmin.TektonController.CreatePVCInAccessMode(releasecommon.ReleasePvcName, managedNamespace, corev1.ReadWriteOnce) diff --git a/tests/release/pipelines/rh_push_to_redhat_io.go b/tests/release/pipelines/rh_push_to_redhat_io.go index 50474fd606..83ac01ab8f 100644 --- a/tests/release/pipelines/rh_push_to_redhat_io.go +++ b/tests/release/pipelines/rh_push_to_redhat_io.go @@ -247,6 +247,6 @@ func createRHIOReleasePlanAdmission(rhioRPAName string, managedFw framework.Fram }, }, &runtime.RawExtension{ Raw: data, - }) + }, nil) Expect(err).NotTo(HaveOccurred()) } diff --git a/tests/release/pipelines/rhtap_service_push.go b/tests/release/pipelines/rhtap_service_push.go index 128428fa0c..68b740283f 100644 --- a/tests/release/pipelines/rhtap_service_push.go +++ b/tests/release/pipelines/rhtap_service_push.go @@ -279,7 +279,7 @@ func createRHTAPReleasePlanAdmission(rhtapRPAName string, managedFw framework.Fr }, }, &runtime.RawExtension{ Raw: data, - }) + }, nil) Expect(err).NotTo(HaveOccurred()) } diff --git a/tests/release/service/missing_release_plan_and_admission.go b/tests/release/service/missing_release_plan_and_admission.go index 3980998308..e47203bfe0 100644 --- a/tests/release/service/missing_release_plan_and_admission.go +++ b/tests/release/service/missing_release_plan_and_admission.go @@ -52,7 +52,7 @@ var _ = framework.ReleaseServiceSuiteDescribe("[HACBS-2360] Release CR fails whe {Name: "revision", Value: releasecommon.RelSvcCatalogRevision}, {Name: "pathInRepo", Value: "pipelines/e2e/e2e.yaml"}, }, - }, nil) + }, nil, nil) Expect(err).NotTo(HaveOccurred()) _, err = fw.AsKubeAdmin.ReleaseController.CreateRelease(releaseName, devNamespace, snapshotName, releasecommon.SourceReleasePlanName) Expect(err).NotTo(HaveOccurred()) diff --git a/tests/release/service/release_plan_and_admission_matched.go b/tests/release/service/release_plan_and_admission_matched.go index 1f16dbde15..8fab1e6898 100644 --- a/tests/release/service/release_plan_and_admission_matched.go +++ b/tests/release/service/release_plan_and_admission_matched.go @@ -75,7 +75,7 @@ var _ = framework.ReleaseServiceSuiteDescribe("ReleasePlan and ReleasePlanAdmiss {Name: "revision", Value: releasecommon.RelSvcCatalogRevision}, {Name: "pathInRepo", Value: "pipelines/e2e/e2e.yaml"}, }, - }, nil) + }, nil, nil) Expect(err).NotTo(HaveOccurred()) })