mirror of
https://github.com/drone/drone-kaniko.git
synced 2026-06-04 18:23:50 +08:00
a1d07a3262
* added the PLUGIN_MULTIPLE_BUILD_ARGS for all registries * added the tests and README
210 lines
5.3 KiB
Go
210 lines
5.3 KiB
Go
package main
|
|
|
|
import (
|
|
"encoding/base64"
|
|
"io/ioutil"
|
|
"os"
|
|
"testing"
|
|
|
|
"github.com/drone/drone-kaniko/pkg/docker"
|
|
"github.com/drone/drone-kaniko/pkg/utils"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/urfave/cli"
|
|
)
|
|
|
|
func TestCreateDockerConfigForECRWithBaseRegistry(t *testing.T) {
|
|
accessKey := "access-key"
|
|
secretKey := "secret-key"
|
|
ecrRegistry := "ecr-registry"
|
|
dockerUsername := "dockeruser"
|
|
dockerPassword := "dockerpass"
|
|
dockerRegistry := "https://index.docker.io/v1/"
|
|
|
|
tempDir, err := ioutil.TempDir("", "docker-config-test")
|
|
assert.NoError(t, err)
|
|
defer os.RemoveAll(tempDir)
|
|
|
|
config := docker.NewConfig()
|
|
|
|
pullFromRegistryCreds := docker.RegistryCredentials{
|
|
Registry: dockerRegistry,
|
|
Username: dockerUsername,
|
|
Password: dockerPassword,
|
|
}
|
|
credentials := []docker.RegistryCredentials{
|
|
{Registry: ecrRegistry, Username: accessKey, Password: secretKey},
|
|
pullFromRegistryCreds,
|
|
}
|
|
|
|
err = config.CreateDockerConfig(credentials, tempDir)
|
|
assert.NoError(t, err)
|
|
|
|
expectedECRAuth := docker.Auth{Auth: base64.StdEncoding.EncodeToString([]byte(accessKey + ":" + secretKey))}
|
|
assert.Equal(t, expectedECRAuth, config.Auths[ecrRegistry])
|
|
|
|
expectedDockerAuth := docker.Auth{Auth: base64.StdEncoding.EncodeToString([]byte(dockerUsername + ":" + dockerPassword))}
|
|
assert.Equal(t, expectedDockerAuth, config.Auths[dockerRegistry])
|
|
}
|
|
|
|
func TestCustomStringSliceFlagIntegration(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
input string
|
|
expected []string
|
|
}{
|
|
{
|
|
name: "single build arg",
|
|
input: "ARG1=value1",
|
|
expected: []string{"ARG1=value1"},
|
|
},
|
|
{
|
|
name: "multiple build args with semicolon",
|
|
input: "ARG1=value1;ARG2=value2;ARG3=value3",
|
|
expected: []string{"ARG1=value1", "ARG2=value2", "ARG3=value3"},
|
|
},
|
|
{
|
|
name: "build args with spaces",
|
|
input: "ARG1=value with spaces;ARG2=another value",
|
|
expected: []string{"ARG1=value with spaces", "ARG2=another value"},
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
// Test the CustomStringSliceFlag directly
|
|
flag := &utils.CustomStringSliceFlag{}
|
|
err := flag.Set(tt.input)
|
|
if err != nil {
|
|
t.Errorf("Set() error = %v, want nil", err)
|
|
return
|
|
}
|
|
|
|
result := flag.GetValue()
|
|
if len(result) != len(tt.expected) {
|
|
t.Errorf("Got %d args, want %d", len(result), len(tt.expected))
|
|
return
|
|
}
|
|
|
|
for i, expected := range tt.expected {
|
|
if result[i] != expected {
|
|
t.Errorf("Got arg[%d] = %v, want %v", i, result[i], expected)
|
|
}
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestCLIIntegrationWithCustomFlag(t *testing.T) {
|
|
// Test CLI integration with proper flag setup
|
|
tests := []struct {
|
|
name string
|
|
args []string
|
|
expected []string
|
|
}{
|
|
{
|
|
name: "CLI with single arg",
|
|
args: []string{"ecr-test", "--args-new", "ARG1=value1"},
|
|
expected: []string{"ARG1=value1"},
|
|
},
|
|
{
|
|
name: "CLI with multiple args",
|
|
args: []string{"ecr-test", "--args-new", "ARG1=value1;ARG2=value2"},
|
|
expected: []string{"ARG1=value1", "ARG2=value2"},
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
app := cli.NewApp()
|
|
app.Name = "ecr-test"
|
|
|
|
var capturedArgs []string
|
|
|
|
app.Flags = []cli.Flag{
|
|
cli.GenericFlag{
|
|
Name: "args-new",
|
|
Usage: "build args new",
|
|
EnvVar: "PLUGIN_BUILD_ARGS_NEW",
|
|
Value: new(utils.CustomStringSliceFlag),
|
|
},
|
|
}
|
|
|
|
app.Action = func(c *cli.Context) error {
|
|
if genericFlag := c.Generic("args-new"); genericFlag != nil {
|
|
if customFlag, ok := genericFlag.(*utils.CustomStringSliceFlag); ok {
|
|
capturedArgs = customFlag.GetValue()
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
err := app.Run(tt.args)
|
|
if err != nil {
|
|
t.Errorf("CLI run error = %v, want nil", err)
|
|
return
|
|
}
|
|
|
|
if len(capturedArgs) != len(tt.expected) {
|
|
t.Errorf("Got %d args, want %d", len(capturedArgs), len(tt.expected))
|
|
return
|
|
}
|
|
|
|
for i, expected := range tt.expected {
|
|
if capturedArgs[i] != expected {
|
|
t.Errorf("Got arg[%d] = %v, want %v", i, capturedArgs[i], expected)
|
|
}
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestECRBuildArgsProcessing(t *testing.T) {
|
|
// Test that build args are correctly processed in the context of ECR plugin
|
|
tests := []struct {
|
|
name string
|
|
argsNew string
|
|
expectedCount int
|
|
expectedFirst string
|
|
}{
|
|
{
|
|
name: "docker build args format",
|
|
argsNew: "GOOS=linux;GOARCH=amd64;CGO_ENABLED=0",
|
|
expectedCount: 3,
|
|
expectedFirst: "GOOS=linux",
|
|
},
|
|
{
|
|
name: "aws specific args",
|
|
argsNew: "AWS_REGION=us-west-2;AWS_ACCOUNT_ID=123456789012",
|
|
expectedCount: 2,
|
|
expectedFirst: "AWS_REGION=us-west-2",
|
|
},
|
|
{
|
|
name: "single complex arg with special characters",
|
|
argsNew: "BUILD_DATE=$(date -u +'%Y-%m-%dT%H:%M:%SZ')",
|
|
expectedCount: 1,
|
|
expectedFirst: "BUILD_DATE=$(date -u +'%Y-%m-%dT%H:%M:%SZ')",
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
flag := &utils.CustomStringSliceFlag{}
|
|
err := flag.Set(tt.argsNew)
|
|
if err != nil {
|
|
t.Errorf("Set() error = %v, want nil", err)
|
|
return
|
|
}
|
|
|
|
args := flag.GetValue()
|
|
if len(args) != tt.expectedCount {
|
|
t.Errorf("Got %d args, want %d", len(args), tt.expectedCount)
|
|
return
|
|
}
|
|
|
|
if len(args) > 0 && args[0] != tt.expectedFirst {
|
|
t.Errorf("Got first arg = %v, want %v", args[0], tt.expectedFirst)
|
|
}
|
|
})
|
|
}
|
|
}
|