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  }