daemon_unix_test.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. // +build !windows
  2. package main
  3. import (
  4. "testing"
  5. "github.com/docker/docker/daemon/config"
  6. "github.com/gotestyourself/gotestyourself/assert"
  7. is "github.com/gotestyourself/gotestyourself/assert/cmp"
  8. "github.com/gotestyourself/gotestyourself/fs"
  9. )
  10. func TestLoadDaemonCliConfigWithDaemonFlags(t *testing.T) {
  11. content := `{"log-opts": {"max-size": "1k"}}`
  12. tempFile := fs.NewFile(t, "config", fs.WithContent(content))
  13. defer tempFile.Remove()
  14. opts := defaultOptions(tempFile.Path())
  15. opts.Debug = true
  16. opts.LogLevel = "info"
  17. assert.Check(t, opts.flags.Set("selinux-enabled", "true"))
  18. loadedConfig, err := loadDaemonCliConfig(opts)
  19. assert.NilError(t, err)
  20. assert.Assert(t, loadedConfig != nil)
  21. assert.Check(t, loadedConfig.Debug)
  22. assert.Check(t, is.Equal("info", loadedConfig.LogLevel))
  23. assert.Check(t, loadedConfig.EnableSelinuxSupport)
  24. assert.Check(t, is.Equal("json-file", loadedConfig.LogConfig.Type))
  25. assert.Check(t, is.Equal("1k", loadedConfig.LogConfig.Config["max-size"]))
  26. }
  27. func TestLoadDaemonConfigWithNetwork(t *testing.T) {
  28. content := `{"bip": "127.0.0.2", "ip": "127.0.0.1"}`
  29. tempFile := fs.NewFile(t, "config", fs.WithContent(content))
  30. defer tempFile.Remove()
  31. opts := defaultOptions(tempFile.Path())
  32. loadedConfig, err := loadDaemonCliConfig(opts)
  33. assert.NilError(t, err)
  34. assert.Assert(t, loadedConfig != nil)
  35. assert.Check(t, is.Equal("127.0.0.2", loadedConfig.IP))
  36. assert.Check(t, is.Equal("127.0.0.1", loadedConfig.DefaultIP.String()))
  37. }
  38. func TestLoadDaemonConfigWithMapOptions(t *testing.T) {
  39. content := `{
  40. "cluster-store-opts": {"kv.cacertfile": "/var/lib/docker/discovery_certs/ca.pem"},
  41. "log-opts": {"tag": "test"}
  42. }`
  43. tempFile := fs.NewFile(t, "config", fs.WithContent(content))
  44. defer tempFile.Remove()
  45. opts := defaultOptions(tempFile.Path())
  46. loadedConfig, err := loadDaemonCliConfig(opts)
  47. assert.NilError(t, err)
  48. assert.Assert(t, loadedConfig != nil)
  49. assert.Check(t, loadedConfig.ClusterOpts != nil)
  50. expectedPath := "/var/lib/docker/discovery_certs/ca.pem"
  51. assert.Check(t, is.Equal(expectedPath, loadedConfig.ClusterOpts["kv.cacertfile"]))
  52. assert.Check(t, loadedConfig.LogConfig.Config != nil)
  53. assert.Check(t, is.Equal("test", loadedConfig.LogConfig.Config["tag"]))
  54. }
  55. func TestLoadDaemonConfigWithTrueDefaultValues(t *testing.T) {
  56. content := `{ "userland-proxy": false }`
  57. tempFile := fs.NewFile(t, "config", fs.WithContent(content))
  58. defer tempFile.Remove()
  59. opts := defaultOptions(tempFile.Path())
  60. loadedConfig, err := loadDaemonCliConfig(opts)
  61. assert.NilError(t, err)
  62. assert.Assert(t, loadedConfig != nil)
  63. assert.Check(t, !loadedConfig.EnableUserlandProxy)
  64. // make sure reloading doesn't generate configuration
  65. // conflicts after normalizing boolean values.
  66. reload := func(reloadedConfig *config.Config) {
  67. assert.Check(t, !reloadedConfig.EnableUserlandProxy)
  68. }
  69. assert.Check(t, config.Reload(opts.configFile, opts.flags, reload))
  70. }
  71. func TestLoadDaemonConfigWithTrueDefaultValuesLeaveDefaults(t *testing.T) {
  72. tempFile := fs.NewFile(t, "config", fs.WithContent(`{}`))
  73. defer tempFile.Remove()
  74. opts := defaultOptions(tempFile.Path())
  75. loadedConfig, err := loadDaemonCliConfig(opts)
  76. assert.NilError(t, err)
  77. assert.Assert(t, loadedConfig != nil)
  78. assert.Check(t, loadedConfig.EnableUserlandProxy)
  79. }