mirror of
https://github.com/SAP/jenkins-library.git
synced 2024-12-14 11:03:09 +02:00
ffc931aad1
* Added unit tag as argument. Added description to runTests command. Changed code generator to have unit build tag in generated unit test files. * Added unit build tag to all unit test files. * added to new unit test unit build tag * Update verify-go.yml * small fix --------- Co-authored-by: Muhammadali Nazarov <Muhammadali.Nazarov@acronis.com> Co-authored-by: Christopher Fenner <26137398+CCFenner@users.noreply.github.com>
139 lines
4.6 KiB
Go
139 lines
4.6 KiB
Go
//go:build unit
|
|
// +build unit
|
|
|
|
package cmd
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestMavenBuild(t *testing.T) {
|
|
|
|
cpe := mavenBuildCommonPipelineEnvironment{}
|
|
|
|
t.Run("mavenBuild should install the artifact", func(t *testing.T) {
|
|
mockedUtils := newMavenMockUtils()
|
|
|
|
config := mavenBuildOptions{}
|
|
|
|
err := runMavenBuild(&config, nil, &mockedUtils, &cpe)
|
|
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, mockedUtils.Calls[0].Exec, "mvn")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "install")
|
|
})
|
|
|
|
t.Run("mavenBuild should skip integration tests", func(t *testing.T) {
|
|
mockedUtils := newMavenMockUtils()
|
|
mockedUtils.AddFile("integration-tests/pom.xml", []byte{})
|
|
|
|
config := mavenBuildOptions{}
|
|
|
|
err := runMavenBuild(&config, nil, &mockedUtils, &cpe)
|
|
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, mockedUtils.Calls[0].Exec, "mvn")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "-pl", "!integration-tests")
|
|
})
|
|
|
|
t.Run("mavenBuild should flatten", func(t *testing.T) {
|
|
mockedUtils := newMavenMockUtils()
|
|
|
|
config := mavenBuildOptions{Flatten: true}
|
|
|
|
err := runMavenBuild(&config, nil, &mockedUtils, &cpe)
|
|
|
|
assert.Nil(t, err)
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "flatten:flatten")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "-Dflatten.mode=resolveCiFriendliesOnly")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "-DupdatePomFile=true")
|
|
})
|
|
|
|
t.Run("mavenBuild should run only verify", func(t *testing.T) {
|
|
mockedUtils := newMavenMockUtils()
|
|
|
|
config := mavenBuildOptions{Verify: true}
|
|
|
|
err := runMavenBuild(&config, nil, &mockedUtils, &cpe)
|
|
|
|
assert.Nil(t, err)
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "verify")
|
|
assert.NotContains(t, mockedUtils.Calls[0].Params, "install")
|
|
})
|
|
|
|
t.Run("mavenBuild should createBOM", func(t *testing.T) {
|
|
mockedUtils := newMavenMockUtils()
|
|
|
|
config := mavenBuildOptions{CreateBOM: true}
|
|
|
|
err := runMavenBuild(&config, nil, &mockedUtils, &cpe)
|
|
|
|
assert.Nil(t, err)
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "org.cyclonedx:cyclonedx-maven-plugin:2.7.1:makeAggregateBom")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "-DschemaVersion=1.2")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "-DincludeBomSerialNumber=true")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "-DincludeCompileScope=true")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "-DincludeProvidedScope=true")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "-DincludeRuntimeScope=true")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "-DincludeSystemScope=true")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "-DincludeTestScope=false")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "-DincludeLicenseText=false")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "-DoutputFormat=xml")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "-DoutputName=bom-maven")
|
|
})
|
|
|
|
t.Run("mavenBuild include install and deploy when publish is true", func(t *testing.T) {
|
|
mockedUtils := newMavenMockUtils()
|
|
|
|
config := mavenBuildOptions{Publish: true, Verify: false}
|
|
|
|
err := runMavenBuild(&config, nil, &mockedUtils, &cpe)
|
|
|
|
assert.Nil(t, err)
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "install")
|
|
assert.NotContains(t, mockedUtils.Calls[0].Params, "verify")
|
|
assert.Contains(t, mockedUtils.Calls[1].Params, "deploy")
|
|
|
|
})
|
|
|
|
t.Run("mavenBuild with deploy must skip build, install and test", func(t *testing.T) {
|
|
mockedUtils := newMavenMockUtils()
|
|
|
|
config := mavenBuildOptions{Publish: true, Verify: false}
|
|
|
|
err := runMavenBuild(&config, nil, &mockedUtils, &cpe)
|
|
|
|
assert.Nil(t, err)
|
|
assert.Contains(t, mockedUtils.Calls[1].Params, "-Dmaven.main.skip=true")
|
|
assert.Contains(t, mockedUtils.Calls[1].Params, "-Dmaven.test.skip=true")
|
|
assert.Contains(t, mockedUtils.Calls[1].Params, "-Dmaven.install.skip=true")
|
|
|
|
})
|
|
|
|
t.Run("mavenBuild with deploy must include alt repo id and url when passed as parameter", func(t *testing.T) {
|
|
mockedUtils := newMavenMockUtils()
|
|
|
|
config := mavenBuildOptions{Publish: true, Verify: false, AltDeploymentRepositoryID: "ID", AltDeploymentRepositoryURL: "http://sampleRepo.com"}
|
|
|
|
err := runMavenBuild(&config, nil, &mockedUtils, &cpe)
|
|
|
|
assert.Nil(t, err)
|
|
assert.Contains(t, mockedUtils.Calls[1].Params, "-DaltDeploymentRepository=ID::default::http://sampleRepo.com")
|
|
})
|
|
|
|
t.Run("mavenBuild accepts profiles", func(t *testing.T) {
|
|
mockedUtils := newMavenMockUtils()
|
|
|
|
config := mavenBuildOptions{Profiles: []string{"profile1", "profile2"}}
|
|
|
|
err := runMavenBuild(&config, nil, &mockedUtils, &cpe)
|
|
|
|
assert.Nil(t, err)
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "--activate-profiles")
|
|
assert.Contains(t, mockedUtils.Calls[0].Params, "profile1,profile2")
|
|
})
|
|
|
|
}
|