2020-03-09 08:58:59 +01:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
2020-11-10 17:14:55 +01:00
|
|
|
"errors"
|
|
|
|
"net/http"
|
2020-03-09 08:58:59 +01:00
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/SAP/jenkins-library/pkg/mock"
|
|
|
|
|
|
|
|
"github.com/SAP/jenkins-library/pkg/maven"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestRunMavenStaticCodeChecks(t *testing.T) {
|
|
|
|
t.Run("should run spotBugs and pmd with all configured options", func(t *testing.T) {
|
2020-10-29 18:58:40 +01:00
|
|
|
utils := newMavenStaticCodeChecksTestUtilsBundle()
|
2020-11-10 17:14:55 +01:00
|
|
|
utils.FilesMock.AddFile("unit-tests/pom.xml", []byte(`<project> </project>`))
|
|
|
|
utils.FilesMock.AddFile("integration-tests/pom.xml", []byte(`<project> </project>`))
|
|
|
|
|
2020-03-12 15:45:57 +01:00
|
|
|
config := mavenExecuteStaticCodeChecksOptions{
|
2020-03-09 08:58:59 +01:00
|
|
|
SpotBugs: true,
|
|
|
|
Pmd: true,
|
2020-03-30 15:59:59 +02:00
|
|
|
PmdMaxAllowedViolations: 10,
|
|
|
|
PmdFailurePriority: 2,
|
2020-03-09 08:58:59 +01:00
|
|
|
SpotBugsExcludeFilterFile: "excludeFilter.xml",
|
|
|
|
SpotBugsIncludeFilterFile: "includeFilter.xml",
|
|
|
|
MavenModulesExcludes: []string{"testing-lib", "test-helpers"},
|
|
|
|
}
|
|
|
|
expected := mock.ExecCall{
|
|
|
|
Exec: "mvn",
|
|
|
|
Params: []string{"-pl", "!unit-tests", "-pl", "!integration-tests",
|
|
|
|
"-pl", "!testing-lib", "-pl", "!test-helpers",
|
|
|
|
"-Dspotbugs.includeFilterFile=includeFilter.xml",
|
|
|
|
"-Dspotbugs.excludeFilterFile=excludeFilter.xml",
|
2020-03-30 15:59:59 +02:00
|
|
|
"-Dpmd.maxAllowedViolations=10",
|
|
|
|
"-Dpmd.failurePriority=2",
|
2020-04-24 10:41:49 +02:00
|
|
|
"-Dorg.slf4j.simpleLogger.log.org.apache.maven.cli.transfer.Slf4jMavenTransferListener=warn",
|
2020-03-09 08:58:59 +01:00
|
|
|
"--batch-mode",
|
2020-10-23 15:43:34 +02:00
|
|
|
"com.github.spotbugs:spotbugs-maven-plugin:4.1.4:check",
|
2021-05-04 14:43:40 +02:00
|
|
|
"org.apache.maven.plugins:maven-pmd-plugin:3.14.0:check",
|
2020-03-09 08:58:59 +01:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
currentDir, err := os.Getwd()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal("Could not get current working directory")
|
|
|
|
}
|
|
|
|
defer os.Chdir(currentDir)
|
|
|
|
os.Chdir("../test/resources/maven/")
|
|
|
|
|
2020-10-29 18:58:40 +01:00
|
|
|
err = runMavenStaticCodeChecks(&config, nil, utils)
|
2020-03-09 08:58:59 +01:00
|
|
|
|
|
|
|
assert.Nil(t, err)
|
2020-10-29 18:58:40 +01:00
|
|
|
assert.Equal(t, expected, utils.Calls[0])
|
2020-03-09 08:58:59 +01:00
|
|
|
})
|
2020-09-11 16:16:00 +02:00
|
|
|
t.Run("should warn and skip execution if all tools are turned off", func(t *testing.T) {
|
2020-10-29 18:58:40 +01:00
|
|
|
utils := newMavenStaticCodeChecksTestUtilsBundle()
|
2020-03-12 15:45:57 +01:00
|
|
|
config := mavenExecuteStaticCodeChecksOptions{
|
2020-03-09 08:58:59 +01:00
|
|
|
SpotBugs: false,
|
|
|
|
Pmd: false,
|
|
|
|
}
|
2020-10-29 18:58:40 +01:00
|
|
|
err := runMavenStaticCodeChecks(&config, nil, utils)
|
2020-09-11 16:16:00 +02:00
|
|
|
assert.Nil(t, err)
|
2020-10-29 18:58:40 +01:00
|
|
|
assert.Nil(t, utils.Calls)
|
2020-03-09 08:58:59 +01:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetPmdMavenParameters(t *testing.T) {
|
2020-03-30 15:59:59 +02:00
|
|
|
t.Run("should return maven options with max allowed violations and failrure priority", func(t *testing.T) {
|
2020-03-12 15:45:57 +01:00
|
|
|
config := mavenExecuteStaticCodeChecksOptions{
|
2020-03-30 15:59:59 +02:00
|
|
|
Pmd: true,
|
|
|
|
PmdFailurePriority: 2,
|
|
|
|
PmdMaxAllowedViolations: 5,
|
2020-03-09 08:58:59 +01:00
|
|
|
}
|
|
|
|
expected := maven.ExecuteOptions{
|
2021-05-04 14:43:40 +02:00
|
|
|
Goals: []string{"org.apache.maven.plugins:maven-pmd-plugin:3.14.0:check"},
|
2020-03-30 15:59:59 +02:00
|
|
|
Defines: []string{"-Dpmd.maxAllowedViolations=5", "-Dpmd.failurePriority=2"},
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.Equal(t, &expected, getPmdMavenParameters(&config))
|
|
|
|
})
|
|
|
|
t.Run("should return maven options without failure priority if out of bounds", func(t *testing.T) {
|
|
|
|
config := mavenExecuteStaticCodeChecksOptions{
|
|
|
|
Pmd: true,
|
|
|
|
PmdFailurePriority: 123,
|
|
|
|
PmdMaxAllowedViolations: 5,
|
|
|
|
}
|
|
|
|
expected := maven.ExecuteOptions{
|
2021-05-04 14:43:40 +02:00
|
|
|
Goals: []string{"org.apache.maven.plugins:maven-pmd-plugin:3.14.0:check"},
|
2020-03-30 15:59:59 +02:00
|
|
|
Defines: []string{"-Dpmd.maxAllowedViolations=5"},
|
2020-03-09 08:58:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
assert.Equal(t, &expected, getPmdMavenParameters(&config))
|
|
|
|
})
|
|
|
|
t.Run("should return maven goal only", func(t *testing.T) {
|
2020-03-12 15:45:57 +01:00
|
|
|
config := mavenExecuteStaticCodeChecksOptions{}
|
2020-03-09 08:58:59 +01:00
|
|
|
expected := maven.ExecuteOptions{
|
2021-05-04 14:43:40 +02:00
|
|
|
Goals: []string{"org.apache.maven.plugins:maven-pmd-plugin:3.14.0:check"}}
|
2020-03-09 08:58:59 +01:00
|
|
|
|
|
|
|
assert.Equal(t, &expected, getPmdMavenParameters(&config))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetSpotBugsMavenParameters(t *testing.T) {
|
2020-03-30 15:59:59 +02:00
|
|
|
t.Run("should return maven options with excludes-, include filters and max allowed violations", func(t *testing.T) {
|
2020-03-12 15:45:57 +01:00
|
|
|
config := mavenExecuteStaticCodeChecksOptions{
|
2020-03-30 15:59:59 +02:00
|
|
|
SpotBugs: true,
|
|
|
|
SpotBugsExcludeFilterFile: "excludeFilter.xml",
|
|
|
|
SpotBugsIncludeFilterFile: "includeFilter.xml",
|
|
|
|
SpotBugsMaxAllowedViolations: 123,
|
2020-03-09 08:58:59 +01:00
|
|
|
}
|
|
|
|
expected := maven.ExecuteOptions{
|
2020-10-23 15:43:34 +02:00
|
|
|
Goals: []string{"com.github.spotbugs:spotbugs-maven-plugin:4.1.4:check"},
|
2020-03-30 15:59:59 +02:00
|
|
|
Defines: []string{"-Dspotbugs.includeFilterFile=includeFilter.xml", "-Dspotbugs.excludeFilterFile=excludeFilter.xml", "-Dspotbugs.maxAllowedViolations=123"},
|
2020-03-09 08:58:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
assert.Equal(t, &expected, getSpotBugsMavenParameters(&config))
|
|
|
|
})
|
|
|
|
t.Run("should return maven goal only", func(t *testing.T) {
|
2020-03-12 15:45:57 +01:00
|
|
|
config := mavenExecuteStaticCodeChecksOptions{}
|
2020-03-09 08:58:59 +01:00
|
|
|
expected := maven.ExecuteOptions{
|
2020-10-23 15:43:34 +02:00
|
|
|
Goals: []string{"com.github.spotbugs:spotbugs-maven-plugin:4.1.4:check"}}
|
2020-03-09 08:58:59 +01:00
|
|
|
|
|
|
|
assert.Equal(t, &expected, getSpotBugsMavenParameters(&config))
|
|
|
|
})
|
|
|
|
}
|
2020-10-29 18:58:40 +01:00
|
|
|
|
|
|
|
type mavenStaticCodeChecksTestUtilsBundle struct {
|
|
|
|
*mock.ExecMockRunner
|
|
|
|
*mock.FilesMock
|
|
|
|
}
|
|
|
|
|
2020-11-10 17:14:55 +01:00
|
|
|
func (m mavenStaticCodeChecksTestUtilsBundle) DownloadFile(url, filename string, header http.Header, cookies []*http.Cookie) error {
|
|
|
|
return errors.New("Test should not download files.")
|
|
|
|
}
|
|
|
|
|
2020-10-29 18:58:40 +01:00
|
|
|
func newMavenStaticCodeChecksTestUtilsBundle() mavenStaticCodeChecksTestUtilsBundle {
|
|
|
|
utilsBundle := mavenStaticCodeChecksTestUtilsBundle{
|
|
|
|
ExecMockRunner: &mock.ExecMockRunner{},
|
|
|
|
FilesMock: &mock.FilesMock{},
|
|
|
|
}
|
|
|
|
return utilsBundle
|
|
|
|
}
|