123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242 |
- // +build !windows
- package main
- import (
- "io/ioutil"
- "os"
- "testing"
- cliflags "github.com/docker/docker/cli/flags"
- "github.com/docker/docker/daemon"
- "github.com/docker/docker/opts"
- "github.com/docker/docker/pkg/mflag"
- )
- func TestLoadDaemonCliConfigWithDaemonFlags(t *testing.T) {
- c := &daemon.Config{}
- common := &cliflags.CommonFlags{
- Debug: true,
- LogLevel: "info",
- }
- f, err := ioutil.TempFile("", "docker-config-")
- if err != nil {
- t.Fatal(err)
- }
- configFile := f.Name()
- f.Write([]byte(`{"log-opts": {"max-size": "1k"}}`))
- f.Close()
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
- flags.String([]string{daemonConfigFileFlag}, "", "")
- flags.BoolVar(&c.EnableSelinuxSupport, []string{"-selinux-enabled"}, true, "")
- flags.StringVar(&c.LogConfig.Type, []string{"-log-driver"}, "json-file", "")
- flags.Var(opts.NewNamedMapOpts("log-opts", c.LogConfig.Config, nil), []string{"-log-opt"}, "")
- flags.Set(daemonConfigFileFlag, configFile)
- 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.Debug {
- t.Fatalf("expected debug mode, got false")
- }
- if loadedConfig.LogLevel != "info" {
- t.Fatalf("expected info log level, got %v", loadedConfig.LogLevel)
- }
- if !loadedConfig.EnableSelinuxSupport {
- t.Fatalf("expected enabled selinux support, got disabled")
- }
- if loadedConfig.LogConfig.Type != "json-file" {
- t.Fatalf("expected LogConfig type json-file, got %v", loadedConfig.LogConfig.Type)
- }
- if maxSize := loadedConfig.LogConfig.Config["max-size"]; maxSize != "1k" {
- t.Fatalf("expected log max-size `1k`, got %s", maxSize)
- }
- }
- func TestLoadDaemonConfigWithNetwork(t *testing.T) {
- c := &daemon.Config{}
- common := &cliflags.CommonFlags{}
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
- flags.String([]string{"-bip"}, "", "")
- flags.String([]string{"-ip"}, "", "")
- f, err := ioutil.TempFile("", "docker-config-")
- if err != nil {
- t.Fatal(err)
- }
- configFile := f.Name()
- f.Write([]byte(`{"bip": "127.0.0.2", "ip": "127.0.0.1"}`))
- f.Close()
- 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.IP != "127.0.0.2" {
- t.Fatalf("expected IP 127.0.0.2, got %v", loadedConfig.IP)
- }
- if loadedConfig.DefaultIP.String() != "127.0.0.1" {
- t.Fatalf("expected DefaultIP 127.0.0.1, got %s", loadedConfig.DefaultIP)
- }
- }
- func TestLoadDaemonConfigWithMapOptions(t *testing.T) {
- c := &daemon.Config{}
- common := &cliflags.CommonFlags{}
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
- flags.Var(opts.NewNamedMapOpts("cluster-store-opts", c.ClusterOpts, nil), []string{"-cluster-store-opt"}, "")
- flags.Var(opts.NewNamedMapOpts("log-opts", c.LogConfig.Config, nil), []string{"-log-opt"}, "")
- f, err := ioutil.TempFile("", "docker-config-")
- if err != nil {
- t.Fatal(err)
- }
- configFile := f.Name()
- f.Write([]byte(`{
- "cluster-store-opts": {"kv.cacertfile": "/var/lib/docker/discovery_certs/ca.pem"},
- "log-opts": {"tag": "test"}
- }`))
- 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.ClusterOpts == nil {
- t.Fatal("expected cluster options, got nil")
- }
- expectedPath := "/var/lib/docker/discovery_certs/ca.pem"
- if caPath := loadedConfig.ClusterOpts["kv.cacertfile"]; caPath != expectedPath {
- t.Fatalf("expected %s, got %s", expectedPath, caPath)
- }
- if loadedConfig.LogConfig.Config == nil {
- t.Fatal("expected log config options, got nil")
- }
- if tag := loadedConfig.LogConfig.Config["tag"]; tag != "test" {
- t.Fatalf("expected log tag `test`, got %s", tag)
- }
- }
- func TestLoadDaemonConfigWithTrueDefaultValues(t *testing.T) {
- c := &daemon.Config{}
- common := &cliflags.CommonFlags{}
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
- flags.BoolVar(&c.EnableUserlandProxy, []string{"-userland-proxy"}, true, "")
- f, err := ioutil.TempFile("", "docker-config-")
- if err != nil {
- t.Fatal(err)
- }
- if err := flags.ParseFlags([]string{}, false); err != nil {
- t.Fatal(err)
- }
- configFile := f.Name()
- f.Write([]byte(`{
- "userland-proxy": false
- }`))
- 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.EnableUserlandProxy {
- t.Fatal("expected userland proxy to be disabled, got enabled")
- }
- // make sure reloading doesn't generate configuration
- // conflicts after normalizing boolean values.
- err = daemon.ReloadConfiguration(configFile, flags, func(reloadedConfig *daemon.Config) {
- if reloadedConfig.EnableUserlandProxy {
- t.Fatal("expected userland proxy to be disabled, got enabled")
- }
- })
- if err != nil {
- t.Fatal(err)
- }
- }
- func TestLoadDaemonConfigWithTrueDefaultValuesLeaveDefaults(t *testing.T) {
- c := &daemon.Config{}
- common := &cliflags.CommonFlags{}
- flags := mflag.NewFlagSet("test", mflag.ContinueOnError)
- flags.BoolVar(&c.EnableUserlandProxy, []string{"-userland-proxy"}, true, "")
- f, err := ioutil.TempFile("", "docker-config-")
- if err != nil {
- t.Fatal(err)
- }
- if err := flags.ParseFlags([]string{}, false); err != nil {
- t.Fatal(err)
- }
- configFile := f.Name()
- f.Write([]byte(`{}`))
- 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.EnableUserlandProxy {
- t.Fatal("expected userland proxy to be enabled, got disabled")
- }
- }
- func TestLoadDaemonConfigWithLegacyRegistryOptions(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(`{"disable-legacy-registry": true}`))
- 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.V2Only {
- t.Fatal("expected disable-legacy-registry to be true, got false")
- }
- }
|