You've already forked sap-jenkins-library
							
							
				mirror of
				https://github.com/SAP/jenkins-library.git
				synced 2025-10-30 23:57:50 +02:00 
			
		
		
		
	* Add ans implementation * Remove todo comment * Rename test function Co-authored-by: Linda Siebert <39100394+LindaSieb@users.noreply.github.com> * Better wording Co-authored-by: Linda Siebert <39100394+LindaSieb@users.noreply.github.com> * Add reading of response body function * Use http pkg ReadResponseBody * Check read error * Better test case description * Fix formatting * Create own package for read response body * Omit empty nested resource struct * Separate Resource struct from Event struct * Merge and unmarshall instead of only unmarshalling * Improve status code error message * Remove unchangeable event fields * Separate event parts * Change log level setter function * Restructure ans send test * Revert exporting readResponseBody function Instead the code is duplicated in the xsuaa and ans package * Add check correct ans setup request * Add set options function for mocking * Review fixes * Correct function name * Use strict unmarshalling * Validate event * Move functions * Add documentation comments * improve test * Validate event * Add logrus hook for ans * Set defaults on new hook creation * Fix log level on error * Don't alter entry log level * Set severity fatal on 'fatal error' log message * Ensure that log entries don't affect each other * Remove unnecessary correlationID * Use file path instead of event template string * Improve warning messages * Add empty log message check * Allow configuration from file and string * Add sourceEventId to tags * Change resourceType to Pipeline * Use structured config approach * Use new log level set function * Check correct setup and return error * Mock http requests * Only send log level warning or higher * Use new function name * One-liner ifs * Improve test name * Fix tests * Prevent double firing * Reduce Fire test size * Add error message to test * Reduce newANSHook test size * Further check error * Rename to defaultEvent in hook struct * Reduce ifs further * Fix set error category test The ansHook Fire test cannot run in parallel, as it would affect the other tests that use the error category. * Change function name to SetServiceKey * Validate event * Rename to eventTemplate in hook struct * Move copy to event.go * Fix function mix * Remove unnecessary cleanup * Remove parallel test The translation fails now and again when parallel is on. * Remove prefix test * Remove unused copyEvent function * Fix ifs * Add docu comment * Register ans hook from pkg * register hook and setup event template seperately * Exclusively read eventTemplate from environment * setupEventTemplate tests * adjust hook levels test * sync tests- wlill still fail * migrate TestANSHook_registerANSHook test * fixes * Introduce necessary parameters * Setup hook test * Use file instead * Adapt helper for ans * Generate go files * Add ans config to general config * Change generator * Regenerate steps * Allow hook config from user config Merges with hook config from defaults * Remove ans flags from root command * Get environment variables * Generate files * Add test when calling merge twice * Update generator * Regenerate steps * Check two location for ans service key env var * Re-generate * Fix if * Generate files with fix * Duplicate config struct * Add type casting test for ans config * Fix helper * Fix format * Fix type casting of config * Revert "Allow hook config from user config" This reverts commit 4864499a4c497998c9ffc3e157ef491be955e68e. * Revert "Add test when calling merge twice" This reverts commit b82320fd07b82f5a597c5071049d918bcf62de00. * Add ans config tests * Improve helper code * Re-generate commands * Fix helper unit tests * Change to only one argument * Fix helper tests * Re-generate * Revert piper and config changes * Re-generate missing step * Generate new steps * [ANS] Add servicekey credential to environment (#3684) * Add ANS credential * Switch to hooks and remove comments * Add subsection for ans Co-authored-by: Oliver Feldmann <oliver.feldmann@sap.com> * Remove changes to piper.go * Remove formatting * Add test for ANS * Define hook credential seperately from step credential * Add test for retrieval from general section * Add comment * Get ans hook info from DefaultValueCache * [ANS] Add documentation (#3704) * Add ANS credential * Switch to hooks and remove comments * Add subsection for ans Co-authored-by: Oliver Feldmann <oliver.feldmann@sap.com> * Remove changes to piper.go * Remove formatting * Add test for ANS * Define hook credential seperately from step credential * Add test for retrieval from general section * Add comment * Add documentation * Review changes * Review comments * Improve documentation further * Add note of two event templates * Add log level destinction * Further improvements * Improve text * Remove unused things * Add ANS credential * Switch to hooks and remove comments * Add subsection for ans Co-authored-by: Oliver Feldmann <oliver.feldmann@sap.com> * Remove changes to piper.go * Remove formatting * Add test for ANS * Define hook credential seperately from step credential * Add test for retrieval from general section * Add comment * Get ans hook info from DefaultValueCache * Improvements Co-authored-by: Linda Siebert <linda.siebert@sap.com> Co-authored-by: Linda Siebert <39100394+LindaSieb@users.noreply.github.com> Co-authored-by: Oliver Feldmann <oliver.feldmann@sap.com> * New lines Co-authored-by: Oliver Feldmann <oliver.feldmann@sap.com> Co-authored-by: Roland Stengel <r.stengel@sap.com> Co-authored-by: Thorsten Duda <thorsten.duda@sap.com>
		
			
				
	
	
		
			343 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			343 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Code generated by piper's step-generator. DO NOT EDIT.
 | |
| 
 | |
| package cmd
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"os"
 | |
| 	"reflect"
 | |
| 	"strings"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/SAP/jenkins-library/pkg/config"
 | |
| 	"github.com/SAP/jenkins-library/pkg/gcs"
 | |
| 	"github.com/SAP/jenkins-library/pkg/log"
 | |
| 	"github.com/SAP/jenkins-library/pkg/splunk"
 | |
| 	"github.com/SAP/jenkins-library/pkg/telemetry"
 | |
| 	"github.com/SAP/jenkins-library/pkg/validation"
 | |
| 	"github.com/bmatcuk/doublestar"
 | |
| 	"github.com/spf13/cobra"
 | |
| )
 | |
| 
 | |
| type gradleExecuteBuildOptions struct {
 | |
| 	Path               string `json:"path,omitempty"`
 | |
| 	Task               string `json:"task,omitempty"`
 | |
| 	Publish            bool   `json:"publish,omitempty"`
 | |
| 	RepositoryURL      string `json:"repositoryUrl,omitempty"`
 | |
| 	RepositoryPassword string `json:"repositoryPassword,omitempty"`
 | |
| 	RepositoryUsername string `json:"repositoryUsername,omitempty"`
 | |
| 	CreateBOM          bool   `json:"createBOM,omitempty"`
 | |
| 	ArtifactVersion    string `json:"artifactVersion,omitempty"`
 | |
| 	ArtifactGroupID    string `json:"artifactGroupId,omitempty"`
 | |
| 	ArtifactID         string `json:"artifactId,omitempty"`
 | |
| 	UseWrapper         bool   `json:"useWrapper,omitempty"`
 | |
| }
 | |
| 
 | |
| type gradleExecuteBuildReports struct {
 | |
| }
 | |
| 
 | |
| func (p *gradleExecuteBuildReports) persist(stepConfig gradleExecuteBuildOptions, gcpJsonKeyFilePath string, gcsBucketId string, gcsFolderPath string, gcsSubFolder string) {
 | |
| 	if gcsBucketId == "" {
 | |
| 		log.Entry().Info("persisting reports to GCS is disabled, because gcsBucketId is empty")
 | |
| 		return
 | |
| 	}
 | |
| 	log.Entry().Info("Uploading reports to Google Cloud Storage...")
 | |
| 	content := []gcs.ReportOutputParam{
 | |
| 		{FilePattern: "**/bom.xml", ParamRef: "", StepResultType: "sbom"},
 | |
| 	}
 | |
| 	envVars := []gcs.EnvVar{
 | |
| 		{Name: "GOOGLE_APPLICATION_CREDENTIALS", Value: gcpJsonKeyFilePath, Modified: false},
 | |
| 	}
 | |
| 	gcsClient, err := gcs.NewClient(gcs.WithEnvVars(envVars))
 | |
| 	if err != nil {
 | |
| 		log.Entry().Errorf("creation of GCS client failed: %v", err)
 | |
| 		return
 | |
| 	}
 | |
| 	defer gcsClient.Close()
 | |
| 	structVal := reflect.ValueOf(&stepConfig).Elem()
 | |
| 	inputParameters := map[string]string{}
 | |
| 	for i := 0; i < structVal.NumField(); i++ {
 | |
| 		field := structVal.Type().Field(i)
 | |
| 		if field.Type.String() == "string" {
 | |
| 			paramName := strings.Split(field.Tag.Get("json"), ",")
 | |
| 			paramValue, _ := structVal.Field(i).Interface().(string)
 | |
| 			inputParameters[paramName[0]] = paramValue
 | |
| 		}
 | |
| 	}
 | |
| 	if err := gcs.PersistReportsToGCS(gcsClient, content, inputParameters, gcsFolderPath, gcsBucketId, gcsSubFolder, doublestar.Glob, os.Stat); err != nil {
 | |
| 		log.Entry().Errorf("failed to persist reports: %v", err)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // GradleExecuteBuildCommand This step runs a gradle build command with parameters provided to the step.
 | |
| func GradleExecuteBuildCommand() *cobra.Command {
 | |
| 	const STEP_NAME = "gradleExecuteBuild"
 | |
| 
 | |
| 	metadata := gradleExecuteBuildMetadata()
 | |
| 	var stepConfig gradleExecuteBuildOptions
 | |
| 	var startTime time.Time
 | |
| 	var reports gradleExecuteBuildReports
 | |
| 	var logCollector *log.CollectorHook
 | |
| 	var splunkClient *splunk.Splunk
 | |
| 	telemetryClient := &telemetry.Telemetry{}
 | |
| 
 | |
| 	var createGradleExecuteBuildCmd = &cobra.Command{
 | |
| 		Use:   STEP_NAME,
 | |
| 		Short: "This step runs a gradle build command with parameters provided to the step.",
 | |
| 		Long:  `This step runs a gradle build command with parameters provided to the step.`,
 | |
| 		PreRunE: func(cmd *cobra.Command, _ []string) error {
 | |
| 			startTime = time.Now()
 | |
| 			log.SetStepName(STEP_NAME)
 | |
| 			log.SetVerbose(GeneralConfig.Verbose)
 | |
| 
 | |
| 			GeneralConfig.GitHubAccessTokens = ResolveAccessTokens(GeneralConfig.GitHubTokens)
 | |
| 
 | |
| 			path, _ := os.Getwd()
 | |
| 			fatalHook := &log.FatalHook{CorrelationID: GeneralConfig.CorrelationID, Path: path}
 | |
| 			log.RegisterHook(fatalHook)
 | |
| 
 | |
| 			err := PrepareConfig(cmd, &metadata, STEP_NAME, &stepConfig, config.OpenPiperFile)
 | |
| 			if err != nil {
 | |
| 				log.SetErrorCategory(log.ErrorConfiguration)
 | |
| 				return err
 | |
| 			}
 | |
| 			log.RegisterSecret(stepConfig.RepositoryPassword)
 | |
| 			log.RegisterSecret(stepConfig.RepositoryUsername)
 | |
| 
 | |
| 			if len(GeneralConfig.HookConfig.SentryConfig.Dsn) > 0 {
 | |
| 				sentryHook := log.NewSentryHook(GeneralConfig.HookConfig.SentryConfig.Dsn, GeneralConfig.CorrelationID)
 | |
| 				log.RegisterHook(&sentryHook)
 | |
| 			}
 | |
| 
 | |
| 			if len(GeneralConfig.HookConfig.SplunkConfig.Dsn) > 0 {
 | |
| 				splunkClient = &splunk.Splunk{}
 | |
| 				logCollector = &log.CollectorHook{CorrelationID: GeneralConfig.CorrelationID}
 | |
| 				log.RegisterHook(logCollector)
 | |
| 			}
 | |
| 
 | |
| 			if err = log.RegisterANSHookIfConfigured(GeneralConfig.CorrelationID); err != nil {
 | |
| 				log.Entry().WithError(err).Warn("failed to set up SAP Alert Notification Service log hook")
 | |
| 			}
 | |
| 
 | |
| 			validation, err := validation.New(validation.WithJSONNamesForStructFields(), validation.WithPredefinedErrorMessages())
 | |
| 			if err != nil {
 | |
| 				return err
 | |
| 			}
 | |
| 			if err = validation.ValidateStruct(stepConfig); err != nil {
 | |
| 				log.SetErrorCategory(log.ErrorConfiguration)
 | |
| 				return err
 | |
| 			}
 | |
| 
 | |
| 			return nil
 | |
| 		},
 | |
| 		Run: func(_ *cobra.Command, _ []string) {
 | |
| 			stepTelemetryData := telemetry.CustomData{}
 | |
| 			stepTelemetryData.ErrorCode = "1"
 | |
| 			handler := func() {
 | |
| 				reports.persist(stepConfig, GeneralConfig.GCPJsonKeyFilePath, GeneralConfig.GCSBucketId, GeneralConfig.GCSFolderPath, GeneralConfig.GCSSubFolder)
 | |
| 				config.RemoveVaultSecretFiles()
 | |
| 				stepTelemetryData.Duration = fmt.Sprintf("%v", time.Since(startTime).Milliseconds())
 | |
| 				stepTelemetryData.ErrorCategory = log.GetErrorCategory().String()
 | |
| 				stepTelemetryData.PiperCommitHash = GitCommit
 | |
| 				telemetryClient.SetData(&stepTelemetryData)
 | |
| 				telemetryClient.Send()
 | |
| 				if len(GeneralConfig.HookConfig.SplunkConfig.Dsn) > 0 {
 | |
| 					splunkClient.Send(telemetryClient.GetData(), logCollector)
 | |
| 				}
 | |
| 			}
 | |
| 			log.DeferExitHandler(handler)
 | |
| 			defer handler()
 | |
| 			telemetryClient.Initialize(GeneralConfig.NoTelemetry, STEP_NAME)
 | |
| 			if len(GeneralConfig.HookConfig.SplunkConfig.Dsn) > 0 {
 | |
| 				splunkClient.Initialize(GeneralConfig.CorrelationID,
 | |
| 					GeneralConfig.HookConfig.SplunkConfig.Dsn,
 | |
| 					GeneralConfig.HookConfig.SplunkConfig.Token,
 | |
| 					GeneralConfig.HookConfig.SplunkConfig.Index,
 | |
| 					GeneralConfig.HookConfig.SplunkConfig.SendLogs)
 | |
| 			}
 | |
| 			gradleExecuteBuild(stepConfig, &stepTelemetryData)
 | |
| 			stepTelemetryData.ErrorCode = "0"
 | |
| 			log.Entry().Info("SUCCESS")
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	addGradleExecuteBuildFlags(createGradleExecuteBuildCmd, &stepConfig)
 | |
| 	return createGradleExecuteBuildCmd
 | |
| }
 | |
| 
 | |
| func addGradleExecuteBuildFlags(cmd *cobra.Command, stepConfig *gradleExecuteBuildOptions) {
 | |
| 	cmd.Flags().StringVar(&stepConfig.Path, "path", os.Getenv("PIPER_path"), "Path to the folder with build.gradle (or build.gradle.kts) file which should be executed.")
 | |
| 	cmd.Flags().StringVar(&stepConfig.Task, "task", `build`, "Gradle task that should be executed.")
 | |
| 	cmd.Flags().BoolVar(&stepConfig.Publish, "publish", false, "Configures gradle to publish the artifact to a repository.")
 | |
| 	cmd.Flags().StringVar(&stepConfig.RepositoryURL, "repositoryUrl", os.Getenv("PIPER_repositoryUrl"), "Url to the repository to which the project artifacts should be published.")
 | |
| 	cmd.Flags().StringVar(&stepConfig.RepositoryPassword, "repositoryPassword", os.Getenv("PIPER_repositoryPassword"), "Password for the repository to which the project artifacts should be published.")
 | |
| 	cmd.Flags().StringVar(&stepConfig.RepositoryUsername, "repositoryUsername", os.Getenv("PIPER_repositoryUsername"), "Username for the repository to which the project artifacts should be published.")
 | |
| 	cmd.Flags().BoolVar(&stepConfig.CreateBOM, "createBOM", false, "Creates the bill of materials (BOM) using CycloneDX plugin.")
 | |
| 	cmd.Flags().StringVar(&stepConfig.ArtifactVersion, "artifactVersion", os.Getenv("PIPER_artifactVersion"), "Version of the artifact to be built.")
 | |
| 	cmd.Flags().StringVar(&stepConfig.ArtifactGroupID, "artifactGroupId", os.Getenv("PIPER_artifactGroupId"), "The group of the artifact.")
 | |
| 	cmd.Flags().StringVar(&stepConfig.ArtifactID, "artifactId", os.Getenv("PIPER_artifactId"), "The name of the artifact.")
 | |
| 	cmd.Flags().BoolVar(&stepConfig.UseWrapper, "useWrapper", false, "If set to false all commands are executed using 'gradle', otherwise 'gradlew' is executed.")
 | |
| 
 | |
| }
 | |
| 
 | |
| // retrieve step metadata
 | |
| func gradleExecuteBuildMetadata() config.StepData {
 | |
| 	var theMetaData = config.StepData{
 | |
| 		Metadata: config.StepMetadata{
 | |
| 			Name:        "gradleExecuteBuild",
 | |
| 			Aliases:     []config.Alias{},
 | |
| 			Description: "This step runs a gradle build command with parameters provided to the step.",
 | |
| 		},
 | |
| 		Spec: config.StepSpec{
 | |
| 			Inputs: config.StepInputs{
 | |
| 				Parameters: []config.StepParameters{
 | |
| 					{
 | |
| 						Name:        "path",
 | |
| 						ResourceRef: []config.ResourceReference{},
 | |
| 						Scope:       []string{"PARAMETERS", "STAGES", "STEPS"},
 | |
| 						Type:        "string",
 | |
| 						Mandatory:   false,
 | |
| 						Aliases:     []config.Alias{{Name: "buildGradlePath"}},
 | |
| 						Default:     os.Getenv("PIPER_path"),
 | |
| 					},
 | |
| 					{
 | |
| 						Name:        "task",
 | |
| 						ResourceRef: []config.ResourceReference{},
 | |
| 						Scope:       []string{"PARAMETERS", "STAGES", "STEPS"},
 | |
| 						Type:        "string",
 | |
| 						Mandatory:   false,
 | |
| 						Aliases:     []config.Alias{},
 | |
| 						Default:     `build`,
 | |
| 					},
 | |
| 					{
 | |
| 						Name:        "publish",
 | |
| 						ResourceRef: []config.ResourceReference{},
 | |
| 						Scope:       []string{"STEPS", "STAGES", "PARAMETERS"},
 | |
| 						Type:        "bool",
 | |
| 						Mandatory:   false,
 | |
| 						Aliases:     []config.Alias{},
 | |
| 						Default:     false,
 | |
| 					},
 | |
| 					{
 | |
| 						Name: "repositoryUrl",
 | |
| 						ResourceRef: []config.ResourceReference{
 | |
| 							{
 | |
| 								Name:  "commonPipelineEnvironment",
 | |
| 								Param: "custom/repositoryUrl",
 | |
| 							},
 | |
| 						},
 | |
| 						Scope:     []string{"GENERAL", "PARAMETERS", "STAGES", "STEPS"},
 | |
| 						Type:      "string",
 | |
| 						Mandatory: false,
 | |
| 						Aliases:   []config.Alias{},
 | |
| 						Default:   os.Getenv("PIPER_repositoryUrl"),
 | |
| 					},
 | |
| 					{
 | |
| 						Name: "repositoryPassword",
 | |
| 						ResourceRef: []config.ResourceReference{
 | |
| 							{
 | |
| 								Name:  "commonPipelineEnvironment",
 | |
| 								Param: "custom/repositoryPassword",
 | |
| 							},
 | |
| 						},
 | |
| 						Scope:     []string{"GENERAL", "PARAMETERS", "STAGES", "STEPS"},
 | |
| 						Type:      "string",
 | |
| 						Mandatory: false,
 | |
| 						Aliases:   []config.Alias{},
 | |
| 						Default:   os.Getenv("PIPER_repositoryPassword"),
 | |
| 					},
 | |
| 					{
 | |
| 						Name: "repositoryUsername",
 | |
| 						ResourceRef: []config.ResourceReference{
 | |
| 							{
 | |
| 								Name:  "commonPipelineEnvironment",
 | |
| 								Param: "custom/repositoryUsername",
 | |
| 							},
 | |
| 						},
 | |
| 						Scope:     []string{"GENERAL", "PARAMETERS", "STAGES", "STEPS"},
 | |
| 						Type:      "string",
 | |
| 						Mandatory: false,
 | |
| 						Aliases:   []config.Alias{},
 | |
| 						Default:   os.Getenv("PIPER_repositoryUsername"),
 | |
| 					},
 | |
| 					{
 | |
| 						Name:        "createBOM",
 | |
| 						ResourceRef: []config.ResourceReference{},
 | |
| 						Scope:       []string{"GENERAL", "STEPS", "STAGES", "PARAMETERS"},
 | |
| 						Type:        "bool",
 | |
| 						Mandatory:   false,
 | |
| 						Aliases:     []config.Alias{},
 | |
| 						Default:     false,
 | |
| 					},
 | |
| 					{
 | |
| 						Name: "artifactVersion",
 | |
| 						ResourceRef: []config.ResourceReference{
 | |
| 							{
 | |
| 								Name:  "commonPipelineEnvironment",
 | |
| 								Param: "artifactVersion",
 | |
| 							},
 | |
| 						},
 | |
| 						Scope:     []string{"GENERAL", "PARAMETERS", "STAGES", "STEPS"},
 | |
| 						Type:      "string",
 | |
| 						Mandatory: false,
 | |
| 						Aliases:   []config.Alias{},
 | |
| 						Default:   os.Getenv("PIPER_artifactVersion"),
 | |
| 					},
 | |
| 					{
 | |
| 						Name: "artifactGroupId",
 | |
| 						ResourceRef: []config.ResourceReference{
 | |
| 							{
 | |
| 								Name:  "commonPipelineEnvironment",
 | |
| 								Param: "groupId",
 | |
| 							},
 | |
| 						},
 | |
| 						Scope:     []string{"PARAMETERS", "STAGES", "STEPS"},
 | |
| 						Type:      "string",
 | |
| 						Mandatory: false,
 | |
| 						Aliases:   []config.Alias{},
 | |
| 						Default:   os.Getenv("PIPER_artifactGroupId"),
 | |
| 					},
 | |
| 					{
 | |
| 						Name: "artifactId",
 | |
| 						ResourceRef: []config.ResourceReference{
 | |
| 							{
 | |
| 								Name:  "commonPipelineEnvironment",
 | |
| 								Param: "artifactId",
 | |
| 							},
 | |
| 						},
 | |
| 						Scope:     []string{"PARAMETERS", "STAGES", "STEPS"},
 | |
| 						Type:      "string",
 | |
| 						Mandatory: false,
 | |
| 						Aliases:   []config.Alias{},
 | |
| 						Default:   os.Getenv("PIPER_artifactId"),
 | |
| 					},
 | |
| 					{
 | |
| 						Name:        "useWrapper",
 | |
| 						ResourceRef: []config.ResourceReference{},
 | |
| 						Scope:       []string{"STEPS", "STAGES", "PARAMETERS"},
 | |
| 						Type:        "bool",
 | |
| 						Mandatory:   false,
 | |
| 						Aliases:     []config.Alias{},
 | |
| 						Default:     false,
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 			Containers: []config.Container{
 | |
| 				{Name: "gradle", Image: "gradle:6-jdk11-alpine"},
 | |
| 			},
 | |
| 			Outputs: config.StepOutputs{
 | |
| 				Resources: []config.StepResources{
 | |
| 					{
 | |
| 						Name: "reports",
 | |
| 						Type: "reports",
 | |
| 						Parameters: []map[string]interface{}{
 | |
| 							{"filePattern": "**/bom.xml", "type": "sbom"},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 	return theMetaData
 | |
| }
 |