mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-18 05:18:24 +02:00
5cc1b8f418
* Update scanPolling.go Changing maxWaitTime from 15 to 30 to overcome WhiteSource results reflection in the backend issue. * Update configHelper.go * Reset configHelper changes to fix PR 3284 Committer: raghunathd8 * ignoreSourceFiles to fileSystemScan * Added ignoreSourceFiles param also * minor adjustment * minor adjustment again * updated unit test * tests fixed * fmt-ed Co-authored-by: Oliver Nocon <33484802+OliverNocon@users.noreply.github.com> Co-authored-by: raghunathd8 <root@docker-evaluation.openstack.eu-nl-1.cloud.sap> Co-authored-by: Sven Merk <33895725+nevskrem@users.noreply.github.com> Co-authored-by: ffeldmann <f.feldmann@sap.com>
275 lines
10 KiB
Go
275 lines
10 KiB
Go
package whitesource
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestRewriteUAConfigurationFile(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
t.Run("default", func(t *testing.T) {
|
|
config := ScanOptions{
|
|
BuildTool: "npm",
|
|
ConfigFilePath: "ua.props",
|
|
}
|
|
utilsMock := NewScanUtilsMock()
|
|
utilsMock.AddFile(config.ConfigFilePath, []byte("test = dummy"))
|
|
|
|
path, err := config.RewriteUAConfigurationFile(utilsMock, "")
|
|
assert.NoError(t, err)
|
|
newUAConfig, err := utilsMock.FileRead(path)
|
|
assert.NoError(t, err)
|
|
assert.Contains(t, string(newUAConfig), "test = dummy")
|
|
assert.Contains(t, string(newUAConfig), "failErrorLevel = ALL")
|
|
})
|
|
|
|
t.Run("accept non-existing file", func(t *testing.T) {
|
|
config := ScanOptions{
|
|
BuildTool: "npm",
|
|
ConfigFilePath: "ua.props",
|
|
}
|
|
utilsMock := NewScanUtilsMock()
|
|
|
|
path, err := config.RewriteUAConfigurationFile(utilsMock, "")
|
|
assert.NoError(t, err)
|
|
|
|
newUAConfig, err := utilsMock.FileRead(path)
|
|
assert.NoError(t, err)
|
|
assert.Contains(t, string(newUAConfig), "failErrorLevel = ALL")
|
|
})
|
|
|
|
t.Run("error - write file", func(t *testing.T) {
|
|
config := ScanOptions{
|
|
BuildTool: "npm",
|
|
ConfigFilePath: "ua.props",
|
|
}
|
|
utilsMock := NewScanUtilsMock()
|
|
utilsMock.FileWriteError = fmt.Errorf("failed to write file")
|
|
|
|
_, err := config.RewriteUAConfigurationFile(utilsMock, "")
|
|
assert.Contains(t, fmt.Sprint(err), "failed to write file")
|
|
})
|
|
}
|
|
|
|
func TestUpdateConfig(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
originalConfig := map[string]string{
|
|
"dependent": "dependentValue",
|
|
"forced": "forced_original",
|
|
"not_forced": "not_forced_original",
|
|
"dont_omit_forced": "dont_omit_forced_original",
|
|
"dont_omit_not_forced": "dont_omit_not_forced_original",
|
|
"append": "original_value appended by",
|
|
"append_empty": "",
|
|
}
|
|
testConfig := ConfigOptions{
|
|
{Name: "non_existing_forced", Value: "non_existing_forced_val", Force: true},
|
|
{Name: "non_existing_not_forced", Value: "non_existing_not_forced_val", Force: false},
|
|
{Name: "forced", Value: "forced_val", Force: true},
|
|
{Name: "not_forced", Value: "not_forced_val", Force: false},
|
|
{Name: "omit", Value: "omit_val", OmitIfPresent: "dependent"},
|
|
{Name: "dont_omit", Value: "dont_omit_val", OmitIfPresent: "dependent_notExisting"},
|
|
{Name: "dont_omit_forced", Value: "dont_omit_forced_val", OmitIfPresent: "dependent_notExisting", Force: true},
|
|
{Name: "dont_omit_not_forced", Value: "dont_omit_not_forced_val", OmitIfPresent: "dependent_notExisting", Force: false},
|
|
{Name: "append", Value: "appended_val", Append: true},
|
|
{Name: "append_empty", Value: "appended_val", Append: true},
|
|
}
|
|
|
|
updatedConfig := testConfig.updateConfig(&originalConfig)
|
|
|
|
assert.Equal(t, "dependentValue", updatedConfig["dependent"])
|
|
assert.Equal(t, "non_existing_forced_val", updatedConfig["non_existing_forced"])
|
|
assert.Equal(t, "non_existing_not_forced_val", updatedConfig["non_existing_not_forced"])
|
|
assert.Equal(t, "forced_val", updatedConfig["forced"])
|
|
assert.Equal(t, "not_forced_original", updatedConfig["not_forced"])
|
|
assert.NotEqual(t, "omit_val", updatedConfig["omit"])
|
|
assert.Equal(t, "dont_omit_val", updatedConfig["dont_omit"])
|
|
assert.Equal(t, "dont_omit_forced_val", updatedConfig["dont_omit_forced"])
|
|
assert.Equal(t, "dont_omit_not_forced_original", updatedConfig["dont_omit_not_forced"])
|
|
assert.Equal(t, "original_value appended by appended_val", updatedConfig["append"])
|
|
assert.Equal(t, "appended_val", updatedConfig["append_empty"])
|
|
}
|
|
|
|
func TestAddGeneralDefaults(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
utilsMock := NewScanUtilsMock()
|
|
|
|
t.Run("default", func(t *testing.T) {
|
|
testConfig := ConfigOptions{}
|
|
whitesourceConfig := ScanOptions{
|
|
OrgToken: "testOrgToken",
|
|
ProductName: "Test",
|
|
ProductToken: "testProductToken",
|
|
ProductVersion: "testVersion",
|
|
ProjectName: "testProject",
|
|
UserToken: "testuserKey",
|
|
}
|
|
testConfig.addGeneralDefaults(&whitesourceConfig, utilsMock, "")
|
|
assert.Equal(t, "checkPolicies", testConfig[0].Name)
|
|
assert.Equal(t, true, testConfig[0].Value)
|
|
assert.Equal(t, "forceCheckAllDependencies", testConfig[1].Name)
|
|
assert.Equal(t, true, testConfig[1].Value)
|
|
|
|
assert.Equal(t, "testOrgToken", testConfig[2].Value)
|
|
assert.Equal(t, "Test", testConfig[3].Value)
|
|
assert.Equal(t, "testVersion", testConfig[4].Value)
|
|
assert.Equal(t, "testProject", testConfig[5].Value)
|
|
assert.Equal(t, "testVersion", testConfig[6].Value)
|
|
assert.Equal(t, "testProductToken", testConfig[7].Value)
|
|
assert.Equal(t, "testuserKey", testConfig[8].Value)
|
|
})
|
|
|
|
t.Run("DIST product", func(t *testing.T) {
|
|
testConfig := ConfigOptions{}
|
|
whitesourceConfig := ScanOptions{
|
|
OrgToken: "testOrgToken",
|
|
ProductName: "DIST - Test",
|
|
ProductToken: "testProductToken",
|
|
ProductVersion: "testVersion",
|
|
ProjectName: "testProject",
|
|
UserToken: "testuserKey",
|
|
}
|
|
testConfig.addGeneralDefaults(&whitesourceConfig, utilsMock, "anotherProject")
|
|
assert.Equal(t, "checkPolicies", testConfig[0].Name)
|
|
assert.Equal(t, false, testConfig[0].Value)
|
|
assert.Equal(t, "forceCheckAllDependencies", testConfig[1].Name)
|
|
assert.Equal(t, false, testConfig[1].Value)
|
|
assert.Equal(t, "anotherProject", testConfig[5].Value)
|
|
})
|
|
|
|
t.Run("verbose", func(t *testing.T) {
|
|
testConfig := ConfigOptions{}
|
|
whitesourceConfig := ScanOptions{
|
|
Verbose: true,
|
|
}
|
|
testConfig.addGeneralDefaults(&whitesourceConfig, utilsMock, "")
|
|
assert.Equal(t, "log.level", testConfig[2].Name)
|
|
assert.Equal(t, "debug", testConfig[2].Value)
|
|
assert.Equal(t, "log.files.level", testConfig[3].Name)
|
|
assert.Equal(t, "debug", testConfig[3].Value)
|
|
})
|
|
|
|
t.Run("includes and excludes", func(t *testing.T) {
|
|
testConfig := ConfigOptions{}
|
|
whitesourceConfig := ScanOptions{
|
|
Excludes: []string{"**/excludes1", "**/excludes2"},
|
|
Includes: []string{"**/includes1", "**/includes2"},
|
|
}
|
|
testConfig.addGeneralDefaults(&whitesourceConfig, utilsMock, "")
|
|
assert.Equal(t, "excludes", testConfig[2].Name)
|
|
assert.Equal(t, "**/excludes1 **/excludes2", testConfig[2].Value)
|
|
assert.Equal(t, true, testConfig[2].Force)
|
|
assert.Equal(t, "includes", testConfig[3].Name)
|
|
assert.Equal(t, "**/includes1 **/includes2", testConfig[3].Value)
|
|
assert.Equal(t, true, testConfig[3].Force)
|
|
})
|
|
}
|
|
|
|
func TestAddBuildToolDefaults(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
t.Run("success case", func(t *testing.T) {
|
|
utilsMock := NewScanUtilsMock()
|
|
var testConfig ConfigOptions
|
|
whitesourceConfig := ScanOptions{
|
|
BuildTool: "dub",
|
|
}
|
|
err := testConfig.addBuildToolDefaults(&whitesourceConfig, utilsMock)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, ConfigOptions{{Name: "ignoreSourceFiles", Value: true, Force: true}, {Name: "includes", Value: "**/*.d **/*.di"}}, testConfig)
|
|
})
|
|
|
|
t.Run("success case", func(t *testing.T) {
|
|
utilsMock := NewScanUtilsMock()
|
|
var testConfig ConfigOptions
|
|
whitesourceConfig := ScanOptions{
|
|
BuildTool: "dub2",
|
|
}
|
|
err := testConfig.addBuildToolDefaults(&whitesourceConfig, utilsMock)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, ConfigOptions{{Name: "fileSystemScan", Value: false, Force: true}, {Name: "includes", Value: "**/*.d **/*.di"}}, testConfig)
|
|
})
|
|
|
|
t.Run("error case", func(t *testing.T) {
|
|
utilsMock := NewScanUtilsMock()
|
|
var testConfig ConfigOptions
|
|
whitesourceConfig := ScanOptions{
|
|
BuildTool: "notHardened",
|
|
}
|
|
err := testConfig.addBuildToolDefaults(&whitesourceConfig, utilsMock)
|
|
assert.EqualError(t, err, "configuration not hardened")
|
|
})
|
|
|
|
t.Run("maven - m2 path", func(t *testing.T) {
|
|
utilsMock := NewScanUtilsMock()
|
|
testConfig := ConfigOptions{}
|
|
whitesourceConfig := ScanOptions{
|
|
BuildTool: "maven",
|
|
M2Path: "test/.m2",
|
|
}
|
|
testConfig.addBuildToolDefaults(&whitesourceConfig, utilsMock)
|
|
assert.Contains(t, testConfig, ConfigOption{Name: "maven.m2RepositoryPath", Value: "test/.m2", Force: true})
|
|
assert.NotContains(t, testConfig, ConfigOption{Name: "maven.additionalArguments", Value: "", Force: true})
|
|
})
|
|
|
|
t.Run("maven - settings", func(t *testing.T) {
|
|
utilsMock := NewScanUtilsMock()
|
|
testConfig := ConfigOptions{}
|
|
whitesourceConfig := ScanOptions{
|
|
BuildTool: "maven",
|
|
ProjectSettingsFile: "project-settings.xml",
|
|
GlobalSettingsFile: "global-settings.xml",
|
|
BuildDescriptorExcludeList: []string{"unit-tests/pom.xml"},
|
|
}
|
|
utilsMock.AddFile("unit-tests/pom.xml", []byte("dummy"))
|
|
testConfig.addBuildToolDefaults(&whitesourceConfig, utilsMock)
|
|
assert.Contains(t, testConfig, ConfigOption{Name: "maven.additionalArguments", Value: "--global-settings global-settings.xml --settings project-settings.xml --projects !unit-tests", Append: true})
|
|
})
|
|
|
|
t.Run("Docker - default", func(t *testing.T) {
|
|
utilsMock := NewScanUtilsMock()
|
|
testConfig := ConfigOptions{}
|
|
whitesourceConfig := ScanOptions{
|
|
BuildTool: "docker",
|
|
}
|
|
utilsMock.AddFile("Dockerfile", []byte("dummy"))
|
|
testConfig.addBuildToolDefaults(&whitesourceConfig, utilsMock)
|
|
assert.Contains(t, testConfig, ConfigOption{Name: "docker.dockerfilePath", Value: "Dockerfile", Force: false})
|
|
})
|
|
|
|
t.Run("Docker - no builddescriptor found", func(t *testing.T) {
|
|
utilsMock := NewScanUtilsMock()
|
|
testConfig := ConfigOptions{}
|
|
whitesourceConfig := ScanOptions{
|
|
BuildTool: "docker",
|
|
}
|
|
testConfig.addBuildToolDefaults(&whitesourceConfig, utilsMock)
|
|
assert.NotContains(t, testConfig, ConfigOption{Name: "docker.dockerfilePath", Value: "Dockerfile", Force: false})
|
|
})
|
|
}
|
|
|
|
func TestMvnProjectExcludes(t *testing.T) {
|
|
utilsMock := NewScanUtilsMock()
|
|
utilsMock.AddFile("unit-tests/package.json", []byte("dummy"))
|
|
utilsMock.AddFile("unit-tests/pom.xml", []byte("dummy"))
|
|
utilsMock.AddFile("integration-tests/pom.xml", []byte("dummy"))
|
|
tt := []struct {
|
|
buildDescriptorExcludeList []string
|
|
expected []string
|
|
}{
|
|
{buildDescriptorExcludeList: []string{}, expected: []string{}},
|
|
{buildDescriptorExcludeList: []string{"unit-tests/package.json", "integration-tests/package.json"}, expected: []string{}},
|
|
{buildDescriptorExcludeList: []string{"unit-tests/pom.xml"}, expected: []string{"--projects", "!unit-tests"}},
|
|
{buildDescriptorExcludeList: []string{"unit-tests/pom.xml", "integration-tests/pom.xml"}, expected: []string{"--projects", "!unit-tests,!integration-tests"}},
|
|
}
|
|
|
|
for _, test := range tt {
|
|
assert.Equal(t, test.expected, mvnProjectExcludes(test.buildDescriptorExcludeList, utilsMock), test.buildDescriptorExcludeList)
|
|
}
|
|
}
|