|
@@ -1,290 +1,145 @@
|
|
package main
|
|
package main
|
|
|
|
|
|
import (
|
|
import (
|
|
- "io/ioutil"
|
|
|
|
- "os"
|
|
|
|
- "strings"
|
|
|
|
"testing"
|
|
"testing"
|
|
|
|
|
|
"github.com/Sirupsen/logrus"
|
|
"github.com/Sirupsen/logrus"
|
|
cliflags "github.com/docker/docker/cli/flags"
|
|
cliflags "github.com/docker/docker/cli/flags"
|
|
"github.com/docker/docker/daemon"
|
|
"github.com/docker/docker/daemon"
|
|
- "github.com/docker/docker/opts"
|
|
|
|
- "github.com/docker/docker/pkg/mflag"
|
|
|
|
- "github.com/docker/go-connections/tlsconfig"
|
|
|
|
|
|
+ "github.com/docker/docker/pkg/testutil/assert"
|
|
|
|
+ "github.com/docker/docker/pkg/testutil/tempfile"
|
|
|
|
+ "github.com/spf13/pflag"
|
|
)
|
|
)
|
|
|
|
|
|
|
|
+func defaultOptions(configFile string) daemonOptions {
|
|
|
|
+ opts := daemonOptions{
|
|
|
|
+ daemonConfig: &daemon.Config{},
|
|
|
|
+ flags: &pflag.FlagSet{},
|
|
|
|
+ common: cliflags.NewCommonOptions(),
|
|
|
|
+ }
|
|
|
|
+ opts.common.InstallFlags(opts.flags)
|
|
|
|
+ opts.daemonConfig.InstallFlags(opts.flags)
|
|
|
|
+ opts.flags.StringVar(&opts.configFile, flagDaemonConfigFile, defaultDaemonConfigFile, "")
|
|
|
|
+ opts.configFile = configFile
|
|
|
|
+ return opts
|
|
|
|
+}
|
|
|
|
+
|
|
func TestLoadDaemonCliConfigWithoutOverriding(t *testing.T) {
|
|
func TestLoadDaemonCliConfigWithoutOverriding(t *testing.T) {
|
|
- c := &daemon.Config{}
|
|
|
|
- common := &cliflags.CommonFlags{
|
|
|
|
- Debug: true,
|
|
|
|
- }
|
|
|
|
|
|
+ opts := defaultOptions("")
|
|
|
|
+ opts.common.Debug = true
|
|
|
|
|
|
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
|
|
|
|
- loadedConfig, err := loadDaemonCliConfig(c, flags, common, "/tmp/fooobarbaz")
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if loadedConfig == nil {
|
|
|
|
- t.Fatalf("expected configuration %v, got nil", c)
|
|
|
|
- }
|
|
|
|
|
|
+ loadedConfig, err := loadDaemonCliConfig(opts)
|
|
|
|
+ assert.NilError(t, err)
|
|
|
|
+ assert.NotNil(t, loadedConfig)
|
|
if !loadedConfig.Debug {
|
|
if !loadedConfig.Debug {
|
|
t.Fatalf("expected debug to be copied from the common flags, got false")
|
|
t.Fatalf("expected debug to be copied from the common flags, got false")
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
func TestLoadDaemonCliConfigWithTLS(t *testing.T) {
|
|
func TestLoadDaemonCliConfigWithTLS(t *testing.T) {
|
|
- c := &daemon.Config{}
|
|
|
|
- common := &cliflags.CommonFlags{
|
|
|
|
- TLS: true,
|
|
|
|
- TLSOptions: &tlsconfig.Options{
|
|
|
|
- CAFile: "/tmp/ca.pem",
|
|
|
|
- },
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
|
|
|
|
- loadedConfig, err := loadDaemonCliConfig(c, flags, common, "/tmp/fooobarbaz")
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if loadedConfig == nil {
|
|
|
|
- t.Fatalf("expected configuration %v, got nil", c)
|
|
|
|
- }
|
|
|
|
- if loadedConfig.CommonTLSOptions.CAFile != "/tmp/ca.pem" {
|
|
|
|
- t.Fatalf("expected /tmp/ca.pem, got %s: %q", loadedConfig.CommonTLSOptions.CAFile, loadedConfig)
|
|
|
|
- }
|
|
|
|
|
|
+ opts := defaultOptions("")
|
|
|
|
+ opts.common.TLSOptions.CAFile = "/tmp/ca.pem"
|
|
|
|
+ opts.common.TLS = true
|
|
|
|
+
|
|
|
|
+ loadedConfig, err := loadDaemonCliConfig(opts)
|
|
|
|
+ assert.NilError(t, err)
|
|
|
|
+ assert.NotNil(t, loadedConfig)
|
|
|
|
+ assert.Equal(t, loadedConfig.CommonTLSOptions.CAFile, "/tmp/ca.pem")
|
|
}
|
|
}
|
|
|
|
|
|
func TestLoadDaemonCliConfigWithConflicts(t *testing.T) {
|
|
func TestLoadDaemonCliConfigWithConflicts(t *testing.T) {
|
|
- c := &daemon.Config{}
|
|
|
|
- common := &cliflags.CommonFlags{}
|
|
|
|
- f, err := ioutil.TempFile("", "docker-config-")
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- configFile := f.Name()
|
|
|
|
- defer os.Remove(configFile)
|
|
|
|
-
|
|
|
|
- f.Write([]byte(`{"labels": ["l3=foo"]}`))
|
|
|
|
- f.Close()
|
|
|
|
-
|
|
|
|
- var labels []string
|
|
|
|
|
|
+ tempFile := tempfile.NewTempFile(t, "config", `{"labels": ["l3=foo"]}`)
|
|
|
|
+ defer tempFile.Remove()
|
|
|
|
+ configFile := tempFile.Name()
|
|
|
|
|
|
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
|
|
|
|
- flags.String([]string{daemonConfigFileFlag}, "", "")
|
|
|
|
- flags.Var(opts.NewNamedListOptsRef("labels", &labels, opts.ValidateLabel), []string{"-label"}, "")
|
|
|
|
|
|
+ opts := defaultOptions(configFile)
|
|
|
|
+ flags := opts.flags
|
|
|
|
|
|
- flags.Set(daemonConfigFileFlag, configFile)
|
|
|
|
- if err := flags.Set("-label", "l1=bar"); err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if err := flags.Set("-label", "l2=baz"); err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
|
|
+ assert.NilError(t, flags.Set(flagDaemonConfigFile, configFile))
|
|
|
|
+ assert.NilError(t, flags.Set("label", "l1=bar"))
|
|
|
|
+ assert.NilError(t, flags.Set("label", "l2=baz"))
|
|
|
|
|
|
- _, err = loadDaemonCliConfig(c, flags, common, configFile)
|
|
|
|
- if err == nil {
|
|
|
|
- t.Fatalf("expected configuration error, got nil")
|
|
|
|
- }
|
|
|
|
- if !strings.Contains(err.Error(), "labels") {
|
|
|
|
- t.Fatalf("expected labels conflict, got %v", err)
|
|
|
|
- }
|
|
|
|
|
|
+ _, err := loadDaemonCliConfig(opts)
|
|
|
|
+ assert.Error(t, err, "as a flag and in the configuration file: labels")
|
|
}
|
|
}
|
|
|
|
|
|
func TestLoadDaemonCliConfigWithTLSVerify(t *testing.T) {
|
|
func TestLoadDaemonCliConfigWithTLSVerify(t *testing.T) {
|
|
- c := &daemon.Config{}
|
|
|
|
- common := &cliflags.CommonFlags{
|
|
|
|
- TLSOptions: &tlsconfig.Options{
|
|
|
|
- CAFile: "/tmp/ca.pem",
|
|
|
|
- },
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- f, err := ioutil.TempFile("", "docker-config-")
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- configFile := f.Name()
|
|
|
|
- defer os.Remove(configFile)
|
|
|
|
-
|
|
|
|
- f.Write([]byte(`{"tlsverify": true}`))
|
|
|
|
- f.Close()
|
|
|
|
|
|
+ tempFile := tempfile.NewTempFile(t, "config", `{"tlsverify": true}`)
|
|
|
|
+ defer tempFile.Remove()
|
|
|
|
|
|
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
|
|
|
|
- flags.Bool([]string{"-tlsverify"}, false, "")
|
|
|
|
- loadedConfig, err := loadDaemonCliConfig(c, flags, common, configFile)
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if loadedConfig == nil {
|
|
|
|
- t.Fatalf("expected configuration %v, got nil", c)
|
|
|
|
- }
|
|
|
|
|
|
+ opts := defaultOptions(tempFile.Name())
|
|
|
|
+ opts.common.TLSOptions.CAFile = "/tmp/ca.pem"
|
|
|
|
|
|
- if !loadedConfig.TLS {
|
|
|
|
- t.Fatalf("expected TLS enabled, got %q", loadedConfig)
|
|
|
|
- }
|
|
|
|
|
|
+ loadedConfig, err := loadDaemonCliConfig(opts)
|
|
|
|
+ assert.NilError(t, err)
|
|
|
|
+ assert.NotNil(t, loadedConfig)
|
|
|
|
+ assert.Equal(t, loadedConfig.TLS, true)
|
|
}
|
|
}
|
|
|
|
|
|
func TestLoadDaemonCliConfigWithExplicitTLSVerifyFalse(t *testing.T) {
|
|
func TestLoadDaemonCliConfigWithExplicitTLSVerifyFalse(t *testing.T) {
|
|
- c := &daemon.Config{}
|
|
|
|
- common := &cliflags.CommonFlags{
|
|
|
|
- TLSOptions: &tlsconfig.Options{
|
|
|
|
- CAFile: "/tmp/ca.pem",
|
|
|
|
- },
|
|
|
|
- }
|
|
|
|
|
|
+ tempFile := tempfile.NewTempFile(t, "config", `{"tlsverify": false}`)
|
|
|
|
+ defer tempFile.Remove()
|
|
|
|
|
|
- f, err := ioutil.TempFile("", "docker-config-")
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- configFile := f.Name()
|
|
|
|
- defer os.Remove(configFile)
|
|
|
|
-
|
|
|
|
- f.Write([]byte(`{"tlsverify": false}`))
|
|
|
|
- f.Close()
|
|
|
|
-
|
|
|
|
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
|
|
|
|
- flags.Bool([]string{"-tlsverify"}, false, "")
|
|
|
|
- loadedConfig, err := loadDaemonCliConfig(c, flags, common, configFile)
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if loadedConfig == nil {
|
|
|
|
- t.Fatalf("expected configuration %v, got nil", c)
|
|
|
|
- }
|
|
|
|
|
|
+ opts := defaultOptions(tempFile.Name())
|
|
|
|
+ opts.common.TLSOptions.CAFile = "/tmp/ca.pem"
|
|
|
|
|
|
- if !loadedConfig.TLS {
|
|
|
|
- t.Fatalf("expected TLS enabled, got %q", loadedConfig)
|
|
|
|
- }
|
|
|
|
|
|
+ loadedConfig, err := loadDaemonCliConfig(opts)
|
|
|
|
+ assert.NilError(t, err)
|
|
|
|
+ assert.NotNil(t, loadedConfig)
|
|
|
|
+ assert.Equal(t, loadedConfig.TLS, true)
|
|
}
|
|
}
|
|
|
|
|
|
func TestLoadDaemonCliConfigWithoutTLSVerify(t *testing.T) {
|
|
func TestLoadDaemonCliConfigWithoutTLSVerify(t *testing.T) {
|
|
- c := &daemon.Config{}
|
|
|
|
- common := &cliflags.CommonFlags{
|
|
|
|
- TLSOptions: &tlsconfig.Options{
|
|
|
|
- CAFile: "/tmp/ca.pem",
|
|
|
|
- },
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- f, err := ioutil.TempFile("", "docker-config-")
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- configFile := f.Name()
|
|
|
|
- defer os.Remove(configFile)
|
|
|
|
|
|
+ tempFile := tempfile.NewTempFile(t, "config", `{}`)
|
|
|
|
+ defer tempFile.Remove()
|
|
|
|
|
|
- f.Write([]byte(`{}`))
|
|
|
|
- f.Close()
|
|
|
|
|
|
+ opts := defaultOptions(tempFile.Name())
|
|
|
|
+ opts.common.TLSOptions.CAFile = "/tmp/ca.pem"
|
|
|
|
|
|
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
|
|
|
|
- loadedConfig, err := loadDaemonCliConfig(c, flags, common, configFile)
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if loadedConfig == nil {
|
|
|
|
- t.Fatalf("expected configuration %v, got nil", c)
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- if loadedConfig.TLS {
|
|
|
|
- t.Fatalf("expected TLS disabled, got %q", loadedConfig)
|
|
|
|
- }
|
|
|
|
|
|
+ loadedConfig, err := loadDaemonCliConfig(opts)
|
|
|
|
+ assert.NilError(t, err)
|
|
|
|
+ assert.NotNil(t, loadedConfig)
|
|
|
|
+ assert.Equal(t, loadedConfig.TLS, false)
|
|
}
|
|
}
|
|
|
|
|
|
func TestLoadDaemonCliConfigWithLogLevel(t *testing.T) {
|
|
func TestLoadDaemonCliConfigWithLogLevel(t *testing.T) {
|
|
- c := &daemon.Config{}
|
|
|
|
- common := &cliflags.CommonFlags{}
|
|
|
|
-
|
|
|
|
- f, err := ioutil.TempFile("", "docker-config-")
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- configFile := f.Name()
|
|
|
|
- defer os.Remove(configFile)
|
|
|
|
-
|
|
|
|
- f.Write([]byte(`{"log-level": "warn"}`))
|
|
|
|
- f.Close()
|
|
|
|
-
|
|
|
|
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
|
|
|
|
- flags.String([]string{"-log-level"}, "", "")
|
|
|
|
- loadedConfig, err := loadDaemonCliConfig(c, flags, common, configFile)
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if loadedConfig == nil {
|
|
|
|
- t.Fatalf("expected configuration %v, got nil", c)
|
|
|
|
- }
|
|
|
|
- if loadedConfig.LogLevel != "warn" {
|
|
|
|
- t.Fatalf("expected warn log level, got %v", loadedConfig.LogLevel)
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- if logrus.GetLevel() != logrus.WarnLevel {
|
|
|
|
- t.Fatalf("expected warn log level, got %v", logrus.GetLevel())
|
|
|
|
- }
|
|
|
|
|
|
+ tempFile := tempfile.NewTempFile(t, "config", `{"log-level": "warn"}`)
|
|
|
|
+ defer tempFile.Remove()
|
|
|
|
+
|
|
|
|
+ opts := defaultOptions(tempFile.Name())
|
|
|
|
+ loadedConfig, err := loadDaemonCliConfig(opts)
|
|
|
|
+ assert.NilError(t, err)
|
|
|
|
+ assert.NotNil(t, loadedConfig)
|
|
|
|
+ assert.Equal(t, loadedConfig.LogLevel, "warn")
|
|
|
|
+ assert.Equal(t, logrus.GetLevel(), logrus.WarnLevel)
|
|
}
|
|
}
|
|
|
|
|
|
func TestLoadDaemonConfigWithEmbeddedOptions(t *testing.T) {
|
|
func TestLoadDaemonConfigWithEmbeddedOptions(t *testing.T) {
|
|
- c := &daemon.Config{}
|
|
|
|
- common := &cliflags.CommonFlags{}
|
|
|
|
-
|
|
|
|
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
|
|
|
|
- flags.String([]string{"-tlscacert"}, "", "")
|
|
|
|
- flags.String([]string{"-log-driver"}, "", "")
|
|
|
|
-
|
|
|
|
- f, err := ioutil.TempFile("", "docker-config-")
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- configFile := f.Name()
|
|
|
|
- defer os.Remove(configFile)
|
|
|
|
-
|
|
|
|
- f.Write([]byte(`{"tlscacert": "/etc/certs/ca.pem", "log-driver": "syslog"}`))
|
|
|
|
- f.Close()
|
|
|
|
-
|
|
|
|
- loadedConfig, err := loadDaemonCliConfig(c, flags, common, configFile)
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if loadedConfig == nil {
|
|
|
|
- t.Fatal("expected configuration, got nil")
|
|
|
|
- }
|
|
|
|
- if loadedConfig.CommonTLSOptions.CAFile != "/etc/certs/ca.pem" {
|
|
|
|
- t.Fatalf("expected CA file path /etc/certs/ca.pem, got %v", loadedConfig.CommonTLSOptions.CAFile)
|
|
|
|
- }
|
|
|
|
- if loadedConfig.LogConfig.Type != "syslog" {
|
|
|
|
- t.Fatalf("expected LogConfig type syslog, got %v", loadedConfig.LogConfig.Type)
|
|
|
|
- }
|
|
|
|
|
|
+ content := `{"tlscacert": "/etc/certs/ca.pem", "log-driver": "syslog"}`
|
|
|
|
+ tempFile := tempfile.NewTempFile(t, "config", content)
|
|
|
|
+ defer tempFile.Remove()
|
|
|
|
+
|
|
|
|
+ opts := defaultOptions(tempFile.Name())
|
|
|
|
+ loadedConfig, err := loadDaemonCliConfig(opts)
|
|
|
|
+ assert.NilError(t, err)
|
|
|
|
+ assert.NotNil(t, loadedConfig)
|
|
|
|
+ assert.Equal(t, loadedConfig.CommonTLSOptions.CAFile, "/etc/certs/ca.pem")
|
|
|
|
+ assert.Equal(t, loadedConfig.LogConfig.Type, "syslog")
|
|
}
|
|
}
|
|
|
|
|
|
func TestLoadDaemonConfigWithRegistryOptions(t *testing.T) {
|
|
func TestLoadDaemonConfigWithRegistryOptions(t *testing.T) {
|
|
- c := &daemon.Config{}
|
|
|
|
- common := &cliflags.CommonFlags{}
|
|
|
|
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
|
|
|
|
- c.ServiceOptions.InstallCliFlags(flags, absentFromHelp)
|
|
|
|
-
|
|
|
|
- f, err := ioutil.TempFile("", "docker-config-")
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- configFile := f.Name()
|
|
|
|
- defer os.Remove(configFile)
|
|
|
|
-
|
|
|
|
- f.Write([]byte(`{"registry-mirrors": ["https://mirrors.docker.com"], "insecure-registries": ["https://insecure.docker.com"]}`))
|
|
|
|
- f.Close()
|
|
|
|
-
|
|
|
|
- loadedConfig, err := loadDaemonCliConfig(c, flags, common, configFile)
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if loadedConfig == nil {
|
|
|
|
- t.Fatal("expected configuration, got nil")
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- m := loadedConfig.Mirrors
|
|
|
|
- if len(m) != 1 {
|
|
|
|
- t.Fatalf("expected 1 mirror, got %d", len(m))
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- r := loadedConfig.InsecureRegistries
|
|
|
|
- if len(r) != 1 {
|
|
|
|
- t.Fatalf("expected 1 insecure registries, got %d", len(r))
|
|
|
|
- }
|
|
|
|
|
|
+ content := `{
|
|
|
|
+ "registry-mirrors": ["https://mirrors.docker.com"],
|
|
|
|
+ "insecure-registries": ["https://insecure.docker.com"],
|
|
|
|
+ }`
|
|
|
|
+ tempFile := tempfile.NewTempFile(t, "config", content)
|
|
|
|
+ defer tempFile.Remove()
|
|
|
|
+
|
|
|
|
+ opts := defaultOptions(tempFile.Name())
|
|
|
|
+ loadedConfig, err := loadDaemonCliConfig(opts)
|
|
|
|
+ assert.NilError(t, err)
|
|
|
|
+ assert.NotNil(t, loadedConfig)
|
|
|
|
+
|
|
|
|
+ assert.Equal(t, len(loadedConfig.Mirrors), 1)
|
|
|
|
+ assert.Equal(t, len(loadedConfig.InsecureRegistries), 1)
|
|
}
|
|
}
|