From 74c6eae2438e6d7d73a53a54a48b28cfea9af497 Mon Sep 17 00:00:00 2001 From: tester Date: Mon, 9 Dec 2024 19:26:00 +0800 Subject: [PATCH] chore: store taskRuns in rh_advisiories Signed-off-by: Jing Qi --- pkg/clients/tekton/pipelineruns.go | 2 +- pkg/clients/tekton/taskruns.go | 36 ++++++++++++++++++++++++ tests/release/pipelines/rh_advisories.go | 3 ++ 3 files changed, 40 insertions(+), 1 deletion(-) diff --git a/pkg/clients/tekton/pipelineruns.go b/pkg/clients/tekton/pipelineruns.go index 618459c96..2a10e020e 100644 --- a/pkg/clients/tekton/pipelineruns.go +++ b/pkg/clients/tekton/pipelineruns.go @@ -239,7 +239,7 @@ func (t *TektonController) StorePipelineRun(prefix string, pipelineRun *pipeline pipelineRunYaml, err := yaml.Marshal(pipelineRun) if err != nil { - return err + g.GinkgoWriter.Printf("failed to store pipelineRun %s:%s: %s\n", pipelineRun.GetNamespace(), pipelineRun.GetName(), err.Error()) } artifacts["pipelineRun-"+pipelineRun.Name+".yaml"] = pipelineRunYaml diff --git a/pkg/clients/tekton/taskruns.go b/pkg/clients/tekton/taskruns.go index 4f677d649..2d2f47a01 100644 --- a/pkg/clients/tekton/taskruns.go +++ b/pkg/clients/tekton/taskruns.go @@ -91,6 +91,42 @@ func (t *TektonController) GetTaskRun(name, namespace string) (*pipeline.TaskRun return &taskRun, nil } +// StoreTaskRun stores a given TaskRun as an artifact. +func (t *TektonController) StoreTaskRun(prefix string, taskRun *pipeline.TaskRun) error { + artifacts := make(map[string][]byte) + taskRunLog, err := t.GetTaskRunLogs(prefix, taskRun.Name, taskRun.Namespace) + if err != nil { + return err + } + artifacts["taskRun-"+taskRun.Name+".log"] = []byte(taskRunLog) + + taskRunYaml, err := yaml.Marshal(taskRun) + if err != nil { + g.GinkgoWriter.Printf("failed to store taskRun %s:%s: %s\n", taskRun.GetNamespace(), taskRun.GetName(), err.Error()) + } + artifacts["taskRun-"+taskRun.Name+".yaml"] = taskRunYaml + + if err := logs.StoreArtifacts(artifacts); err != nil { + return err + } + + return nil +} + +func (t *TektonController) StoreTaskRunsForPipelineRun(c crclient.Client, pr *pipeline.PipelineRun string) error { + for _, chr := range pr.Status.ChildReferences { + taskRun := &pipeline.TaskRun{} + taskRunKey := types.NamespacedName{Namespace: pr.Namespace, Name: chr.Name} + if err := c.Get(context.Background(), taskRunKey, taskRun); err != nil { + return err + } + if err = StoreTaskRun(taskRun.Name, taskRun); err != nil{ + g.GinkgoWriter.Printf("failed to store taskRun %s:%s: %s\n", taskRun.GetNamespace(), taskRun.GetName(), err.Error()) + } + } + return nil +} + // GetTaskRunLogs returns logs of a specified taskRun. func (t *TektonController) GetTaskRunLogs(pipelineRunName, pipelineTaskName, namespace string) (map[string]string, error) { tektonClient := t.PipelineClient().TektonV1beta1().PipelineRuns(namespace) diff --git a/tests/release/pipelines/rh_advisories.go b/tests/release/pipelines/rh_advisories.go index f550b091a..42cb920a3 100644 --- a/tests/release/pipelines/rh_advisories.go +++ b/tests/release/pipelines/rh_advisories.go @@ -97,6 +97,9 @@ var _ = framework.ReleasePipelinesSuiteDescribe("e2e tests for rh-advisories pip if err = managedFw.AsKubeDeveloper.TektonController.StorePipelineRun(pipelineRun.Name, pipelineRun); err != nil { GinkgoWriter.Printf("failed to store PipelineRun %s:%s: %s\n", pipelineRun.GetNamespace(), pipelineRun.GetName(), err.Error()) } + if err = managedFw.AsKubeDeveloper.TektonController.StoreTaskRunsForPipelineRun(pipelineRun); err != nil { + GinkgoWriter.Printf("failed to store TaskRuns for PipelineRun %s:%s: %s\n", pipelineRun.GetNamespace(), pipelineRun.GetName(), err.Error()) + } if err = devFw.AsKubeDeveloper.ReleaseController.StoreRelease(releaseCR); err != nil { GinkgoWriter.Printf("failed to store Release %s:%s: %s\n", releaseCR.GetNamespace(), releaseCR.GetName(), err.Error()) }