1
0
mirror of https://github.com/SAP/jenkins-library.git synced 2025-01-22 05:33:10 +02:00
sap-jenkins-library/pkg/java/keytool_test.go
Christopher Fenner 9180f54f86
feat(sonar): reuse existing TLS truststore (#3312)
* do not load sap certificates with groovy

* add toggle

* add keytool package

* copy existing default truststore

* ignore import failure

* fix typo

* rename

* extract maven opts

* add todo

* add tests

Co-authored-by: Oliver Nocon <33484802+OliverNocon@users.noreply.github.com>
2021-12-16 12:49:15 +01:00

66 lines
2.1 KiB
Go

package java
import (
"os"
"path/filepath"
"strings"
"testing"
piperMock "github.com/SAP/jenkins-library/pkg/mock"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/mock"
"github.com/stretchr/testify/require"
)
func TestGetDefaultTruststorePath(t *testing.T) {
// prepare
os.Setenv("JAVA_HOME", mock.Anything)
require.Equal(t, mock.Anything, os.Getenv("JAVA_HOME"))
// test
result := GetDefaultTruststorePath()
// assert
assert.Equal(t, "lib/security/cacerts", defaultTruststorePath)
assert.Equal(t, filepath.Join(mock.Anything, defaultTruststorePath), result)
// restore
os.Unsetenv("JAVA_HOME")
}
func TestGetMavenOpts(t *testing.T) {
// test
result := GetMavenOpts(mock.Anything)
// assert
assert.Equal(t, "changeit", DefaultTruststorePassword)
assert.Equal(t, "-Djavax.net.ssl.trustStore="+mock.Anything+" -Djavax.net.ssl.trustStorePassword="+DefaultTruststorePassword, result)
}
func TestImportCert(t *testing.T) {
// prepare
secretstorePath := filepath.Join(mock.Anything, mock.Anything)
mockRunner := &piperMock.ExecMockRunner{}
// test
err := ImportCert(mockRunner, mock.Anything, secretstorePath)
// assert
assert.NoError(t, err)
assert.Len(t, mockRunner.Calls, 1)
for _, call := range mockRunner.Calls {
assert.Equal(t, "keytool", call.Exec)
assert.Equal(t, strings.Join(call.Params, " "), "-import -noprompt -storepass changeit -keystore mock.Anything -file "+secretstorePath+" -alias mock.Anything")
}
}
func TestImportTruststore(t *testing.T) {
// prepare
srcSecretstorePath := filepath.Join(mock.Anything, mock.Anything)
destSecretstorePath := filepath.Join(mock.Anything, mock.Anything)
mockRunner := &piperMock.ExecMockRunner{}
// test
err := ImportTruststore(mockRunner, destSecretstorePath, srcSecretstorePath)
// assert
assert.NoError(t, err)
assert.Len(t, mockRunner.Calls, 1)
for _, call := range mockRunner.Calls {
assert.Equal(t, "keytool", call.Exec)
assert.Equal(t, strings.Join(call.Params, " "), "-importkeystore -noprompt -srckeystore "+srcSecretstorePath+" -srcstorepass changeit -destkeystore "+destSecretstorePath+" -deststorepass changeit")
}
}