mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-06 04:13:55 +02:00
bd92804745
* Add static code checks stage * Rework go step to accept thresholds for the checks and fail maven build if above the thresholds
125 lines
4.3 KiB
Go
125 lines
4.3 KiB
Go
package cmd
|
|
|
|
import (
|
|
"os"
|
|
"testing"
|
|
|
|
"github.com/SAP/jenkins-library/pkg/log"
|
|
|
|
"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) {
|
|
execMockRunner := mock.ExecMockRunner{}
|
|
config := mavenExecuteStaticCodeChecksOptions{
|
|
SpotBugs: true,
|
|
Pmd: true,
|
|
PmdMaxAllowedViolations: 10,
|
|
PmdFailurePriority: 2,
|
|
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",
|
|
"-Dpmd.maxAllowedViolations=10",
|
|
"-Dpmd.failurePriority=2",
|
|
"--batch-mode",
|
|
"com.github.spotbugs:spotbugs-maven-plugin:3.1.12:check",
|
|
"org.apache.maven.plugins:maven-pmd-plugin:3.13.0:check",
|
|
},
|
|
}
|
|
|
|
currentDir, err := os.Getwd()
|
|
if err != nil {
|
|
t.Fatal("Could not get current working directory")
|
|
}
|
|
defer os.Chdir(currentDir)
|
|
os.Chdir("../test/resources/maven/")
|
|
|
|
err = runMavenStaticCodeChecks(&config, nil, &execMockRunner)
|
|
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, expected, execMockRunner.Calls[0])
|
|
})
|
|
t.Run("should log fatal if all tools are turned off", func(t *testing.T) {
|
|
var hasFailed bool
|
|
log.Entry().Logger.ExitFunc = func(int) { hasFailed = true }
|
|
execMockRunner := mock.ExecMockRunner{}
|
|
config := mavenExecuteStaticCodeChecksOptions{
|
|
SpotBugs: false,
|
|
Pmd: false,
|
|
}
|
|
_ = runMavenStaticCodeChecks(&config, nil, &execMockRunner)
|
|
assert.True(t, hasFailed, "expected command to exit with fatal")
|
|
})
|
|
}
|
|
|
|
func TestGetPmdMavenParameters(t *testing.T) {
|
|
t.Run("should return maven options with max allowed violations and failrure priority", func(t *testing.T) {
|
|
config := mavenExecuteStaticCodeChecksOptions{
|
|
Pmd: true,
|
|
PmdFailurePriority: 2,
|
|
PmdMaxAllowedViolations: 5,
|
|
}
|
|
expected := maven.ExecuteOptions{
|
|
Goals: []string{"org.apache.maven.plugins:maven-pmd-plugin:3.13.0:check"},
|
|
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{
|
|
Goals: []string{"org.apache.maven.plugins:maven-pmd-plugin:3.13.0:check"},
|
|
Defines: []string{"-Dpmd.maxAllowedViolations=5"},
|
|
}
|
|
|
|
assert.Equal(t, &expected, getPmdMavenParameters(&config))
|
|
})
|
|
t.Run("should return maven goal only", func(t *testing.T) {
|
|
config := mavenExecuteStaticCodeChecksOptions{}
|
|
expected := maven.ExecuteOptions{
|
|
Goals: []string{"org.apache.maven.plugins:maven-pmd-plugin:3.13.0:check"}}
|
|
|
|
assert.Equal(t, &expected, getPmdMavenParameters(&config))
|
|
})
|
|
}
|
|
|
|
func TestGetSpotBugsMavenParameters(t *testing.T) {
|
|
t.Run("should return maven options with excludes-, include filters and max allowed violations", func(t *testing.T) {
|
|
config := mavenExecuteStaticCodeChecksOptions{
|
|
SpotBugs: true,
|
|
SpotBugsExcludeFilterFile: "excludeFilter.xml",
|
|
SpotBugsIncludeFilterFile: "includeFilter.xml",
|
|
SpotBugsMaxAllowedViolations: 123,
|
|
}
|
|
expected := maven.ExecuteOptions{
|
|
Goals: []string{"com.github.spotbugs:spotbugs-maven-plugin:3.1.12:check"},
|
|
Defines: []string{"-Dspotbugs.includeFilterFile=includeFilter.xml", "-Dspotbugs.excludeFilterFile=excludeFilter.xml", "-Dspotbugs.maxAllowedViolations=123"},
|
|
}
|
|
|
|
assert.Equal(t, &expected, getSpotBugsMavenParameters(&config))
|
|
})
|
|
t.Run("should return maven goal only", func(t *testing.T) {
|
|
config := mavenExecuteStaticCodeChecksOptions{}
|
|
expected := maven.ExecuteOptions{
|
|
Goals: []string{"com.github.spotbugs:spotbugs-maven-plugin:3.1.12:check"}}
|
|
|
|
assert.Equal(t, &expected, getSpotBugsMavenParameters(&config))
|
|
})
|
|
}
|