| ... | ... |
@@ -11,41 +11,6 @@ import ( |
| 11 | 11 |
"github.com/spf13/pflag" |
| 12 | 12 |
) |
| 13 | 13 |
|
| 14 |
-func TestDaemonConfigurationMerge(t *testing.T) {
|
|
| 15 |
- f, err := ioutil.TempFile("", "docker-config-")
|
|
| 16 |
- if err != nil {
|
|
| 17 |
- t.Fatal(err) |
|
| 18 |
- } |
|
| 19 |
- |
|
| 20 |
- configFile := f.Name() |
|
| 21 |
- f.Write([]byte(`{"debug": true}`))
|
|
| 22 |
- f.Close() |
|
| 23 |
- |
|
| 24 |
- c := &Config{
|
|
| 25 |
- CommonConfig: CommonConfig{
|
|
| 26 |
- AutoRestart: true, |
|
| 27 |
- LogConfig: LogConfig{
|
|
| 28 |
- Type: "syslog", |
|
| 29 |
- Config: map[string]string{"tag": "test"},
|
|
| 30 |
- }, |
|
| 31 |
- }, |
|
| 32 |
- } |
|
| 33 |
- |
|
| 34 |
- cc, err := MergeDaemonConfigurations(c, nil, configFile) |
|
| 35 |
- if err != nil {
|
|
| 36 |
- t.Fatal(err) |
|
| 37 |
- } |
|
| 38 |
- if !cc.Debug {
|
|
| 39 |
- t.Fatalf("expected %v, got %v\n", true, cc.Debug)
|
|
| 40 |
- } |
|
| 41 |
- if !cc.AutoRestart {
|
|
| 42 |
- t.Fatalf("expected %v, got %v\n", true, cc.AutoRestart)
|
|
| 43 |
- } |
|
| 44 |
- if cc.LogConfig.Type != "syslog" {
|
|
| 45 |
- t.Fatalf("expected syslog config, got %q\n", cc.LogConfig)
|
|
| 46 |
- } |
|
| 47 |
-} |
|
| 48 |
- |
|
| 49 | 14 |
func TestDaemonConfigurationNotFound(t *testing.T) {
|
| 50 | 15 |
_, err := MergeDaemonConfigurations(&Config{}, nil, "/tmp/foo-bar-baz-docker")
|
| 51 | 16 |
if err == nil || !os.IsNotExist(err) {
|
| 52 | 17 |
new file mode 100644 |
| ... | ... |
@@ -0,0 +1,80 @@ |
| 0 |
+// +build !windows |
|
| 1 |
+ |
|
| 2 |
+package daemon |
|
| 3 |
+ |
|
| 4 |
+import ( |
|
| 5 |
+ "io/ioutil" |
|
| 6 |
+ "testing" |
|
| 7 |
+) |
|
| 8 |
+ |
|
| 9 |
+func TestDaemonConfigurationMerge(t *testing.T) {
|
|
| 10 |
+ f, err := ioutil.TempFile("", "docker-config-")
|
|
| 11 |
+ if err != nil {
|
|
| 12 |
+ t.Fatal(err) |
|
| 13 |
+ } |
|
| 14 |
+ |
|
| 15 |
+ configFile := f.Name() |
|
| 16 |
+ |
|
| 17 |
+ f.Write([]byte(` |
|
| 18 |
+ {
|
|
| 19 |
+ "debug": true, |
|
| 20 |
+ "default-ulimits": {
|
|
| 21 |
+ "nofile": {
|
|
| 22 |
+ "Name": "nofile", |
|
| 23 |
+ "Hard": 2048, |
|
| 24 |
+ "Soft": 1024 |
|
| 25 |
+ } |
|
| 26 |
+ }, |
|
| 27 |
+ "log-opts": {
|
|
| 28 |
+ "tag": "test_tag" |
|
| 29 |
+ } |
|
| 30 |
+ }`)) |
|
| 31 |
+ |
|
| 32 |
+ f.Close() |
|
| 33 |
+ |
|
| 34 |
+ c := &Config{
|
|
| 35 |
+ CommonConfig: CommonConfig{
|
|
| 36 |
+ AutoRestart: true, |
|
| 37 |
+ LogConfig: LogConfig{
|
|
| 38 |
+ Type: "syslog", |
|
| 39 |
+ Config: map[string]string{"tag": "test"},
|
|
| 40 |
+ }, |
|
| 41 |
+ }, |
|
| 42 |
+ } |
|
| 43 |
+ |
|
| 44 |
+ cc, err := MergeDaemonConfigurations(c, nil, configFile) |
|
| 45 |
+ if err != nil {
|
|
| 46 |
+ t.Fatal(err) |
|
| 47 |
+ } |
|
| 48 |
+ if !cc.Debug {
|
|
| 49 |
+ t.Fatalf("expected %v, got %v\n", true, cc.Debug)
|
|
| 50 |
+ } |
|
| 51 |
+ if !cc.AutoRestart {
|
|
| 52 |
+ t.Fatalf("expected %v, got %v\n", true, cc.AutoRestart)
|
|
| 53 |
+ } |
|
| 54 |
+ if cc.LogConfig.Type != "syslog" {
|
|
| 55 |
+ t.Fatalf("expected syslog config, got %q\n", cc.LogConfig)
|
|
| 56 |
+ } |
|
| 57 |
+ |
|
| 58 |
+ if configValue, OK := cc.LogConfig.Config["tag"]; !OK {
|
|
| 59 |
+ t.Fatal("expected syslog config attributes, got nil\n")
|
|
| 60 |
+ } else {
|
|
| 61 |
+ if configValue != "test_tag" {
|
|
| 62 |
+ t.Fatalf("expected syslog config attributes 'tag=test_tag', got 'tag=%s'\n", configValue)
|
|
| 63 |
+ } |
|
| 64 |
+ } |
|
| 65 |
+ |
|
| 66 |
+ if cc.Ulimits == nil {
|
|
| 67 |
+ t.Fatal("expected default ulimit config, got nil\n")
|
|
| 68 |
+ } else {
|
|
| 69 |
+ if _, OK := cc.Ulimits["nofile"]; OK {
|
|
| 70 |
+ if cc.Ulimits["nofile"].Name != "nofile" || |
|
| 71 |
+ cc.Ulimits["nofile"].Hard != 2048 || |
|
| 72 |
+ cc.Ulimits["nofile"].Soft != 1024 {
|
|
| 73 |
+ t.Fatalf("expected default ulimit name, hard and soft are nofile, 2048, 1024, got %s, %d, %d\n", cc.Ulimits["nofile"].Name, cc.Ulimits["nofile"].Hard, cc.Ulimits["nofile"].Soft)
|
|
| 74 |
+ } |
|
| 75 |
+ } else {
|
|
| 76 |
+ t.Fatal("expected default ulimit name nofile, got nil\n")
|
|
| 77 |
+ } |
|
| 78 |
+ } |
|
| 79 |
+} |
| 0 | 80 |
new file mode 100644 |
| ... | ... |
@@ -0,0 +1,59 @@ |
| 0 |
+// +build windows |
|
| 1 |
+ |
|
| 2 |
+package daemon |
|
| 3 |
+ |
|
| 4 |
+import ( |
|
| 5 |
+ "io/ioutil" |
|
| 6 |
+ "testing" |
|
| 7 |
+) |
|
| 8 |
+ |
|
| 9 |
+func TestDaemonConfigurationMerge(t *testing.T) {
|
|
| 10 |
+ f, err := ioutil.TempFile("", "docker-config-")
|
|
| 11 |
+ if err != nil {
|
|
| 12 |
+ t.Fatal(err) |
|
| 13 |
+ } |
|
| 14 |
+ |
|
| 15 |
+ configFile := f.Name() |
|
| 16 |
+ |
|
| 17 |
+ f.Write([]byte(` |
|
| 18 |
+ {
|
|
| 19 |
+ "debug": true, |
|
| 20 |
+ "log-opts": {
|
|
| 21 |
+ "tag": "test_tag" |
|
| 22 |
+ } |
|
| 23 |
+ }`)) |
|
| 24 |
+ |
|
| 25 |
+ f.Close() |
|
| 26 |
+ |
|
| 27 |
+ c := &Config{
|
|
| 28 |
+ CommonConfig: CommonConfig{
|
|
| 29 |
+ AutoRestart: true, |
|
| 30 |
+ LogConfig: LogConfig{
|
|
| 31 |
+ Type: "syslog", |
|
| 32 |
+ Config: map[string]string{"tag": "test"},
|
|
| 33 |
+ }, |
|
| 34 |
+ }, |
|
| 35 |
+ } |
|
| 36 |
+ |
|
| 37 |
+ cc, err := MergeDaemonConfigurations(c, nil, configFile) |
|
| 38 |
+ if err != nil {
|
|
| 39 |
+ t.Fatal(err) |
|
| 40 |
+ } |
|
| 41 |
+ if !cc.Debug {
|
|
| 42 |
+ t.Fatalf("expected %v, got %v\n", true, cc.Debug)
|
|
| 43 |
+ } |
|
| 44 |
+ if !cc.AutoRestart {
|
|
| 45 |
+ t.Fatalf("expected %v, got %v\n", true, cc.AutoRestart)
|
|
| 46 |
+ } |
|
| 47 |
+ if cc.LogConfig.Type != "syslog" {
|
|
| 48 |
+ t.Fatalf("expected syslog config, got %q\n", cc.LogConfig)
|
|
| 49 |
+ } |
|
| 50 |
+ |
|
| 51 |
+ if configValue, OK := cc.LogConfig.Config["tag"]; !OK {
|
|
| 52 |
+ t.Fatal("expected syslog config attributes, got nil\n")
|
|
| 53 |
+ } else {
|
|
| 54 |
+ if configValue != "test_tag" {
|
|
| 55 |
+ t.Fatalf("expected syslog config attributes 'tag=test_tag', got 'tag=%s'\n", configValue)
|
|
| 56 |
+ } |
|
| 57 |
+ } |
|
| 58 |
+} |