github.com/SAP/jenkins-library@v1.362.0/cmd/abapAddonAssemblyKitCheckCVs.go (about) 1 package cmd 2 3 import ( 4 "github.com/SAP/jenkins-library/pkg/abap/aakaas" 5 abapbuild "github.com/SAP/jenkins-library/pkg/abap/build" 6 "github.com/SAP/jenkins-library/pkg/abaputils" 7 "github.com/SAP/jenkins-library/pkg/log" 8 "github.com/SAP/jenkins-library/pkg/telemetry" 9 "github.com/pkg/errors" 10 ) 11 12 func abapAddonAssemblyKitCheckCVs(config abapAddonAssemblyKitCheckCVsOptions, telemetryData *telemetry.CustomData, cpe *abapAddonAssemblyKitCheckCVsCommonPipelineEnvironment) { 13 utils := aakaas.NewAakBundle() 14 if err := runAbapAddonAssemblyKitCheckCVs(&config, telemetryData, &utils, cpe); err != nil { 15 log.Entry().WithError(err).Fatal("step execution failed") 16 } 17 } 18 19 func runAbapAddonAssemblyKitCheckCVs(config *abapAddonAssemblyKitCheckCVsOptions, telemetryData *telemetry.CustomData, utils *aakaas.AakUtils, cpe *abapAddonAssemblyKitCheckCVsCommonPipelineEnvironment) error { 20 21 log.Entry().Info("╔══════════════════════════════╗") 22 log.Entry().Info("║ abapAddonAssemblyKitCheckCVs ║") 23 log.Entry().Info("╚══════════════════════════════╝") 24 25 conn := new(abapbuild.Connector) 26 27 if err := conn.InitAAKaaS(config.AbapAddonAssemblyKitEndpoint, config.Username, config.Password, *utils, "", config.AbapAddonAssemblyKitCertificateFile, config.AbapAddonAssemblyKitCertificatePass); err != nil { 28 return err 29 } 30 31 log.Entry().Infof("Reading Product Version Information from addonDescriptor (aka addon.yml) file: %s", config.AddonDescriptorFileName) 32 addonDescriptor, err := (*utils).ReadAddonDescriptor(config.AddonDescriptorFileName) 33 if err != nil { 34 return err 35 } 36 37 for i, repo := range addonDescriptor.Repositories { 38 componentVersion := new(aakaas.ComponentVersion) 39 if err := componentVersion.ConstructComponentVersion(addonDescriptor.Repositories[i], *conn); err != nil { 40 return err 41 } 42 if err := componentVersion.Validate(); err != nil { 43 return err 44 } 45 componentVersion.CopyVersionFieldsToRepo(&addonDescriptor.Repositories[i]) 46 47 log.Entry().Infof("Using cCTS %t", repo.UseClassicCTS) 48 log.Entry().Infof("CommitId %s", repo.CommitID) 49 50 if !repo.UseClassicCTS && repo.CommitID == "" { 51 return errors.Errorf("CommitID missing in repo '%s' of the addon.yml", repo.Name) 52 } 53 } 54 55 // now Software Component Versions fields are valid, but maybe Product Version was checked before, so copy that part from CPE 56 // we don't care for errors 57 // scenario 1: config.AddonDescriptor is empty since checkCVs is the first step in the pipeline, then the empty result is fine anyway 58 // scenario 2: for some reason config.AddonDescriptor is corrupt - then we insert the valid data but delete the repositories which will ensure issue is found later on 59 addonDescriptorCPE, _ := abaputils.ConstructAddonDescriptorFromJSON([]byte(config.AddonDescriptor)) 60 if len(addonDescriptorCPE.AddonProduct) == 0 { 61 log.Entry().Info("No Product Version information present yet in the addonDescriptor of CommonPipelineEnvironment") 62 } else { 63 log.Entry().Infof("Information for Product Version %s taken from addonDescriptor of CommonPipelineEnvironment", addonDescriptorCPE.AddonProduct) 64 } 65 addonDescriptorCPE.SetRepositories(addonDescriptor.Repositories) 66 cpe.abap.addonDescriptor = string(addonDescriptorCPE.AsJSON()) 67 log.Entry().Info("Wrote addonDescriptor to CommonPipelineEnvironment") 68 return nil 69 } 70 71 // take the product part from CPE and the repositories part from the YAML file 72 func combineYAMLRepositoriesWithCPEProduct(addonDescriptor abaputils.AddonDescriptor, addonDescriptorFromCPE abaputils.AddonDescriptor) abaputils.AddonDescriptor { 73 addonDescriptorFromCPE.Repositories = addonDescriptor.Repositories 74 return addonDescriptorFromCPE 75 }