mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-22 05:33:10 +02:00
61dfa9d3d9
* adding my steps * messy step * Update abapEnvironmentAssembly.go * clean up * change yaml * corrections * Update cloudFoundryDeploy.go * update * delete simulation step * remove simulate * Update PiperGoUtils.groovy * Update PiperGoUtils.groovy * Update CommonStepsTest.groovy * add docu * Update abapEnvironmentAssembly.md * changes due to PR * Update .gitignore * b * CV list * Update abapEnvironmentAssembly.go * testing with simulation * Update abapEnvironmentAssembly.go * remove simulation * renaming * Update mkdocs.yml * moving service key to yaml and fixing code climate * Update abapEnvironmentAssemblePackages.go * Update abapEnvironmentAssemblePackages.go * Update abapEnvironmentAssemblePackages.go * Update abapEnvironmentAssemblePackages.go * change input * Update abapEnvironmentAssemblePackages.go * change json tag * fixed error handling * documentation * Update abapEnvironmentAssemblePackages.md * Update abapEnvironmentAssemblePackages.md * fixing code climate issues * fixing code climate issues * Update abapEnvironmentAssemblePackages.yaml * fixing code climate issues * Update abapEnvironmentAssemblePackages.yaml * adding unittests * adding unittests and improved logging * yaml -> json * change scope of cfServiceKeyName * correct indentation * Update CommonStepsTest.groovy * maintain correct step order * AAKaaS Checks as First Step * remove old coding Co-authored-by: rosemarieB <45030247+rosemarieB@users.noreply.github.com> Co-authored-by: Daniel Mieg <56156797+DanielMieg@users.noreply.github.com> Co-authored-by: Christopher Fenner <26137398+CCFenner@users.noreply.github.com> Co-authored-by: Chris <42861202+bluesbrother84@users.noreply.github.com>
129 lines
4.0 KiB
Go
129 lines
4.0 KiB
Go
package cmd
|
|
|
|
import (
|
|
"encoding/json"
|
|
"testing"
|
|
|
|
abapbuild "github.com/SAP/jenkins-library/pkg/abap/build"
|
|
"github.com/SAP/jenkins-library/pkg/abaputils"
|
|
"github.com/pkg/errors"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestCheckPVStep(t *testing.T) {
|
|
var config abapAddonAssemblyKitCheckPVOptions
|
|
var cpe abapAddonAssemblyKitCheckPVCommonPipelineEnvironment
|
|
client := &abaputils.ClientMock{
|
|
Body: responseCheckPV,
|
|
}
|
|
t.Run("step success", func(t *testing.T) {
|
|
config.AddonDescriptorFileName = "success"
|
|
err := runAbapAddonAssemblyKitCheckPV(&config, nil, client, &cpe, mockReadAddonDescriptor)
|
|
assert.NoError(t, err, "Did not expect error")
|
|
var addonDescriptorFinal abaputils.AddonDescriptor
|
|
json.Unmarshal([]byte(cpe.abap.addonDescriptor), &addonDescriptorFinal)
|
|
assert.Equal(t, "0003", addonDescriptorFinal.AddonVersion)
|
|
assert.Equal(t, "0002", addonDescriptorFinal.AddonSpsLevel)
|
|
assert.Equal(t, "0001", addonDescriptorFinal.AddonPatchLevel)
|
|
})
|
|
t.Run("step error - in ReadAddonDescriptor", func(t *testing.T) {
|
|
config.AddonDescriptorFileName = "failing"
|
|
err := runAbapAddonAssemblyKitCheckPV(&config, nil, client, &cpe, mockReadAddonDescriptor)
|
|
assert.Error(t, err, "Did expect error")
|
|
assert.Equal(t, err.Error(), "error in ReadAddonDescriptor")
|
|
})
|
|
t.Run("step error - in validate", func(t *testing.T) {
|
|
config.AddonDescriptorFileName = "success"
|
|
client := &abaputils.ClientMock{
|
|
Body: "ErrorBody",
|
|
Error: errors.New("error during validation"),
|
|
}
|
|
err := runAbapAddonAssemblyKitCheckPV(&config, nil, client, &cpe, mockReadAddonDescriptor)
|
|
assert.Error(t, err, "Did expect error")
|
|
})
|
|
}
|
|
|
|
func TestInitPV(t *testing.T) {
|
|
t.Run("test init", func(t *testing.T) {
|
|
conn := new(abapbuild.Connector)
|
|
conn.Client = &abaputils.ClientMock{}
|
|
prodvers := abaputils.AddonDescriptor{
|
|
AddonProduct: "/DRNMSPC/PRD01",
|
|
AddonVersionYAML: "3.2.1",
|
|
}
|
|
|
|
var pv productVersion
|
|
pv.init(prodvers, *conn)
|
|
assert.Equal(t, "/DRNMSPC/PRD01", pv.Name)
|
|
assert.Equal(t, "3.2.1", pv.VersionYAML)
|
|
})
|
|
}
|
|
|
|
func TestValidatePV(t *testing.T) {
|
|
conn := new(abapbuild.Connector)
|
|
t.Run("test validate - success", func(t *testing.T) {
|
|
conn.Client = &abaputils.ClientMock{
|
|
Body: responseCheckPV,
|
|
}
|
|
pv := productVersion{
|
|
Connector: *conn,
|
|
Name: "/DRNMSPC/PRD01",
|
|
VersionYAML: "3.2.1",
|
|
}
|
|
err := pv.validateAndResolveVersionFields()
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, "0003", pv.Version)
|
|
assert.Equal(t, "0002", pv.SpsLevel)
|
|
assert.Equal(t, "0001", pv.PatchLevel)
|
|
})
|
|
t.Run("test validate - with error", func(t *testing.T) {
|
|
conn.Client = &abaputils.ClientMock{
|
|
Body: "ErrorBody",
|
|
Error: errors.New("Validation failed"),
|
|
}
|
|
pv := productVersion{
|
|
Connector: *conn,
|
|
Name: "/DRNMSPC/PRD01",
|
|
VersionYAML: "3.2.1",
|
|
}
|
|
err := pv.validateAndResolveVersionFields()
|
|
assert.Error(t, err)
|
|
assert.Equal(t, "", pv.Version)
|
|
assert.Equal(t, "", pv.SpsLevel)
|
|
assert.Equal(t, "", pv.PatchLevel)
|
|
})
|
|
}
|
|
|
|
func TestCopyFieldsPV(t *testing.T) {
|
|
t.Run("test copyFieldsToRepo", func(t *testing.T) {
|
|
prodVers := abaputils.AddonDescriptor{
|
|
AddonProduct: "/DRNMSPC/PRD01",
|
|
AddonVersionYAML: "1.2.3",
|
|
}
|
|
var pv productVersion
|
|
pv.Version = "0003"
|
|
pv.SpsLevel = "0002"
|
|
pv.PatchLevel = "0001"
|
|
pv.transferVersionFields(&prodVers)
|
|
assert.Equal(t, "0003", prodVers.AddonVersion)
|
|
assert.Equal(t, "0002", prodVers.AddonSpsLevel)
|
|
assert.Equal(t, "0001", prodVers.AddonPatchLevel)
|
|
})
|
|
}
|
|
|
|
var responseCheckPV = `{
|
|
"d": {
|
|
"__metadata": {
|
|
"id": "https://W7Q.DMZWDF.SAP.CORP:443/odata/aas_ocs_package/ProductVersionSet(Name='%2FDRNMSPC%2FPRD01',Version='0001')",
|
|
"uri": "https://W7Q.DMZWDF.SAP.CORP:443/odata/aas_ocs_package/ProductVersionSet(Name='%2FDRNMSPC%2FPRD01',Version='0001')",
|
|
"type": "SSDA.AAS_ODATA_PACKAGE_SRV.ProductVersion"
|
|
},
|
|
"Name": "/DRNMSPC/PRD01",
|
|
"Version": "0003",
|
|
"SpsLevel": "0002",
|
|
"PatchLevel": "0001",
|
|
"Vendor": "",
|
|
"VendorType": ""
|
|
}
|
|
}`
|