5a5f8564ba
Relates to a82fff6377/docs/packages.md (proxies)
> (..) the first four of these are the standard built-in build-arg options
> available for `docker build`
> (..) The last, `all_proxy`, is a standard var used for socks proxying. Since
> it is not built into `docker build`, if you want to use it, you will need to
> add the following line to the dockerfile:
>
> ARG all_proxy
Given the we support all other commonly known proxy env-vars by default, it makes
sense to add this one as well.
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
104 lines
3.8 KiB
Go
104 lines
3.8 KiB
Go
package dockerfile // import "github.com/docker/docker/builder/dockerfile"
|
|
|
|
import (
|
|
"bytes"
|
|
"strings"
|
|
"testing"
|
|
|
|
"gotest.tools/v3/assert"
|
|
is "gotest.tools/v3/assert/cmp"
|
|
)
|
|
|
|
func strPtr(source string) *string {
|
|
return &source
|
|
}
|
|
|
|
func TestGetAllAllowed(t *testing.T) {
|
|
buildArgs := NewBuildArgs(map[string]*string{
|
|
"ArgNotUsedInDockerfile": strPtr("fromopt1"),
|
|
"ArgOverriddenByOptions": strPtr("fromopt2"),
|
|
"ArgNoDefaultInDockerfileFromOptions": strPtr("fromopt3"),
|
|
"HTTP_PROXY": strPtr("theproxy"),
|
|
"all_proxy": strPtr("theproxy2"),
|
|
})
|
|
|
|
buildArgs.AddMetaArg("ArgFromMeta", strPtr("frommeta1"))
|
|
buildArgs.AddMetaArg("ArgFromMetaOverridden", strPtr("frommeta2"))
|
|
buildArgs.AddMetaArg("ArgFromMetaNotUsed", strPtr("frommeta3"))
|
|
|
|
buildArgs.AddArg("ArgOverriddenByOptions", strPtr("fromdockerfile2"))
|
|
buildArgs.AddArg("ArgWithDefaultInDockerfile", strPtr("fromdockerfile1"))
|
|
buildArgs.AddArg("ArgNoDefaultInDockerfile", nil)
|
|
buildArgs.AddArg("ArgNoDefaultInDockerfileFromOptions", nil)
|
|
buildArgs.AddArg("ArgFromMeta", nil)
|
|
buildArgs.AddArg("ArgFromMetaOverridden", strPtr("fromdockerfile3"))
|
|
|
|
all := buildArgs.GetAllAllowed()
|
|
expected := map[string]string{
|
|
"HTTP_PROXY": "theproxy",
|
|
"all_proxy": "theproxy2",
|
|
"ArgOverriddenByOptions": "fromopt2",
|
|
"ArgWithDefaultInDockerfile": "fromdockerfile1",
|
|
"ArgNoDefaultInDockerfileFromOptions": "fromopt3",
|
|
"ArgFromMeta": "frommeta1",
|
|
"ArgFromMetaOverridden": "fromdockerfile3",
|
|
}
|
|
assert.Check(t, is.DeepEqual(expected, all))
|
|
}
|
|
|
|
func TestGetAllMeta(t *testing.T) {
|
|
buildArgs := NewBuildArgs(map[string]*string{
|
|
"ArgNotUsedInDockerfile": strPtr("fromopt1"),
|
|
"ArgOverriddenByOptions": strPtr("fromopt2"),
|
|
"ArgNoDefaultInMetaFromOptions": strPtr("fromopt3"),
|
|
"HTTP_PROXY": strPtr("theproxy"),
|
|
})
|
|
|
|
buildArgs.AddMetaArg("ArgFromMeta", strPtr("frommeta1"))
|
|
buildArgs.AddMetaArg("ArgOverriddenByOptions", strPtr("frommeta2"))
|
|
buildArgs.AddMetaArg("ArgNoDefaultInMetaFromOptions", nil)
|
|
|
|
all := buildArgs.GetAllMeta()
|
|
expected := map[string]string{
|
|
"HTTP_PROXY": "theproxy",
|
|
"ArgFromMeta": "frommeta1",
|
|
"ArgOverriddenByOptions": "fromopt2",
|
|
"ArgNoDefaultInMetaFromOptions": "fromopt3",
|
|
}
|
|
assert.Check(t, is.DeepEqual(expected, all))
|
|
}
|
|
|
|
func TestWarnOnUnusedBuildArgs(t *testing.T) {
|
|
buildArgs := NewBuildArgs(map[string]*string{
|
|
"ThisArgIsUsed": strPtr("fromopt1"),
|
|
"ThisArgIsNotUsed": strPtr("fromopt2"),
|
|
"HTTPS_PROXY": strPtr("referenced builtin"),
|
|
"HTTP_PROXY": strPtr("unreferenced builtin"),
|
|
})
|
|
buildArgs.AddArg("ThisArgIsUsed", nil)
|
|
buildArgs.AddArg("HTTPS_PROXY", nil)
|
|
|
|
buffer := new(bytes.Buffer)
|
|
buildArgs.WarnOnUnusedBuildArgs(buffer)
|
|
out := buffer.String()
|
|
assert.Assert(t, !strings.Contains(out, "ThisArgIsUsed"), out)
|
|
assert.Assert(t, !strings.Contains(out, "HTTPS_PROXY"), out)
|
|
assert.Assert(t, !strings.Contains(out, "HTTP_PROXY"), out)
|
|
assert.Check(t, is.Contains(out, "ThisArgIsNotUsed"))
|
|
}
|
|
|
|
func TestIsUnreferencedBuiltin(t *testing.T) {
|
|
buildArgs := NewBuildArgs(map[string]*string{
|
|
"ThisArgIsUsed": strPtr("fromopt1"),
|
|
"ThisArgIsNotUsed": strPtr("fromopt2"),
|
|
"HTTPS_PROXY": strPtr("referenced builtin"),
|
|
"HTTP_PROXY": strPtr("unreferenced builtin"),
|
|
})
|
|
buildArgs.AddArg("ThisArgIsUsed", nil)
|
|
buildArgs.AddArg("HTTPS_PROXY", nil)
|
|
|
|
assert.Check(t, buildArgs.IsReferencedOrNotBuiltin("ThisArgIsUsed"))
|
|
assert.Check(t, buildArgs.IsReferencedOrNotBuiltin("ThisArgIsNotUsed"))
|
|
assert.Check(t, buildArgs.IsReferencedOrNotBuiltin("HTTPS_PROXY"))
|
|
assert.Check(t, !buildArgs.IsReferencedOrNotBuiltin("HTTP_PROXY"))
|
|
}
|