1
0
mirror of https://github.com/SAP/jenkins-library.git synced 2024-12-16 11:09:33 +02:00
sap-jenkins-library/pkg/cnbutils/privacy/privacy_test.go
Ralf Pannemans e7db09db12
feat(cnbBuild): added dockerimage to the telemetry data (#3501)
Co-authored-by: Philipp Stehle <philipp.stehle@sap.com>
Co-authored-by: Sumit Kulhadia <sumit.kulhadia@sap.com>
Co-authored-by: Johannes Dillmann <j.dillmann@sap.com>
2022-02-16 13:28:51 +01:00

140 lines
3.1 KiB
Go

package privacy_test
import (
"testing"
"github.com/SAP/jenkins-library/pkg/cnbutils/privacy"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func TestCnbPrivacy_FilterBuildpacks(t *testing.T) {
t.Parallel()
t.Run("allows paketo", func(t *testing.T) {
aliases := []string{
"paketobuildpacks/nodejs:v1",
"docker.io/paketobuildpacks/nodejs:v1",
"index.docker.io/paketobuildpacks/nodejs:v1",
"gcr.io/paketo-buildpacks/nodejs:v1",
}
filtered := privacy.FilterBuildpacks(aliases)
require.Len(t, filtered, len(aliases))
for i := range filtered {
assert.Equal(t, aliases[i], filtered[i])
}
})
t.Run("allows heroku", func(t *testing.T) {
aliases := []string{
"public.ecr.aws/heroku-buildpacks/heroku-jvm-buildpack@sha256:3a8ee9ebf88e47c5e30bc5712fb2794380aed75552499f92bd6773ec446421ef",
}
filtered := privacy.FilterBuildpacks(aliases)
require.Len(t, filtered, len(aliases))
for i := range filtered {
assert.Equal(t, aliases[i], filtered[i])
}
})
t.Run("allows google buildpacks", func(t *testing.T) {
aliases := []string{
"gcr.io/buildpacks/java:latest",
"gcr.io/buildpacks/java",
}
filtered := privacy.FilterBuildpacks(aliases)
require.Len(t, filtered, len(aliases))
for i := range filtered {
assert.Equal(t, aliases[i], filtered[i])
}
})
t.Run("filters others", func(t *testing.T) {
images := []string{
"test/nodejs:v1",
"my-mirror.de/paketobuildpacks/nodejs:v1",
"gcr.io/my-project/paketo-buildpacks/nodejs:v1",
}
filtered := privacy.FilterBuildpacks(images)
require.Len(t, filtered, len(images))
for _, image := range filtered {
assert.Equal(t, "<redacted>", image)
}
})
t.Run("fails gracefully on parse error", func(t *testing.T) {
images := []string{
"test/nodejs v1 spaces are not allowed",
}
filtered := privacy.FilterBuildpacks(images)
require.Len(t, filtered, len(images))
for _, image := range filtered {
assert.Equal(t, "<error>", image)
}
})
}
func TestCnbPrivacy_FilterEnv(t *testing.T) {
t.Parallel()
t.Run("copies only allow listed keys", func(t *testing.T) {
env := map[string]interface{}{
"PRIVATE": "paketobuildpacks/nodejs:v1",
"BP_NODE_VERSION": "8",
"BP_JVM_VERSION": "11",
}
filteredEnv := privacy.FilterEnv(env)
assert.Equal(t, map[string]interface{}{
"BP_NODE_VERSION": "8",
"BP_JVM_VERSION": "11",
}, filteredEnv)
})
t.Run("works on nil map", func(t *testing.T) {
var env map[string]interface{} = nil
filteredEnv := privacy.FilterEnv(env)
assert.Empty(t, filteredEnv)
})
}
func TestCnbPrivacy_FilterBuilder(t *testing.T) {
t.Parallel()
t.Run("allows paketo", func(t *testing.T) {
builder := []string{
"paketobuildpacks/builder:tiny",
"paketobuildpacks/builder:base",
"paketobuildpacks/builder:full",
}
for _, b := range builder {
filteredBuilder := privacy.FilterBuilder(b)
assert.Equal(t, b, filteredBuilder)
}
})
t.Run("filters unknown builders", func(t *testing.T) {
builder := "notpaketobuildpacks/builder:base"
filteredBuilder := privacy.FilterBuilder(builder)
assert.Equal(t, "<redacted>", filteredBuilder)
})
}