|
1 | 1 | package task |
2 | 2 |
|
3 | 3 | import ( |
| 4 | + "fmt" |
| 5 | + "io/ioutil" |
| 6 | + "path/filepath" |
4 | 7 | "testing" |
5 | 8 | ) |
6 | 9 |
|
@@ -85,6 +88,7 @@ func TestCreateContainerDefinition(t *testing.T) { |
85 | 88 | ExtraHosts: []string{ |
86 | 89 | "host1:192.168.1.100", |
87 | 90 | }, |
| 91 | + Hostname: "example.com", |
88 | 92 | LogDriver: "syslog", |
89 | 93 | LogOpt: map[string]string{ |
90 | 94 | "syslog-address": "tcp://192.168.0.42:123", |
@@ -300,3 +304,119 @@ func TestCreateContainerDefinition(t *testing.T) { |
300 | 304 | } |
301 | 305 |
|
302 | 306 | } |
| 307 | + |
| 308 | +func TestReadEnvFileEnvFormat(t *testing.T) { |
| 309 | + |
| 310 | + f, _ := ioutil.TempFile("", "TestReadEnvFileEnvFormat.env") |
| 311 | + f.WriteString(` |
| 312 | +PARAM1=VALUE1_env |
| 313 | +PARAM2=VALUE2_env |
| 314 | + `) |
| 315 | + defer f.Close() |
| 316 | + |
| 317 | + actual, err := readEnvFile(f.Name()) |
| 318 | + if err != nil { |
| 319 | + t.Fatalf("cannot open file.") |
| 320 | + } |
| 321 | + |
| 322 | + if 2 != len(actual) { |
| 323 | + t.Fatalf("len: expect = %v, but actual = %v", 2, len(actual)) |
| 324 | + } |
| 325 | + |
| 326 | + if val, ok := actual["PARAM1"]; ok { |
| 327 | + if "VALUE1_env" != val { |
| 328 | + t.Errorf("actual[PARAM1]: expect = %v, but actual = %v", "VALUE1_env", val) |
| 329 | + } |
| 330 | + } else { |
| 331 | + t.Errorf("actual[PARAM1]: not found") |
| 332 | + } |
| 333 | + |
| 334 | +} |
| 335 | + |
| 336 | +func TestReadEnvFileYamlFormat(t *testing.T) { |
| 337 | + |
| 338 | + f, _ := ioutil.TempFile("", "TestReadEnvFileYamlFormat.env") |
| 339 | + f.WriteString(` |
| 340 | +PARAM1: VALUE1_env |
| 341 | +PARAM2: VALUE2_env |
| 342 | + `) |
| 343 | + defer f.Close() |
| 344 | + |
| 345 | + actual, err := readEnvFile(f.Name()) |
| 346 | + if err != nil { |
| 347 | + t.Fatalf("cannot open file.") |
| 348 | + } |
| 349 | + |
| 350 | + if 2 != len(actual) { |
| 351 | + t.Fatalf("len: expect = %v, but actual = %v", 2, len(actual)) |
| 352 | + } |
| 353 | + |
| 354 | + if val, ok := actual["PARAM1"]; ok { |
| 355 | + if "VALUE1_env" != val { |
| 356 | + t.Errorf("actual[PARAM1]: expect = %v, but actual = %v", "VALUE1_env", val) |
| 357 | + } |
| 358 | + } else { |
| 359 | + t.Errorf("actual[PARAM1]: not found") |
| 360 | + } |
| 361 | + |
| 362 | +} |
| 363 | + |
| 364 | +func TestCreateTaskDefinition(t *testing.T) { |
| 365 | + |
| 366 | + f, _ := ioutil.TempFile("", "TestCreateTaskDefinition.env") |
| 367 | + f.WriteString(` |
| 368 | +PARAM2: VALUE2_env |
| 369 | +PARAM3: VALUE3_env |
| 370 | + `) |
| 371 | + defer f.Close() |
| 372 | + |
| 373 | + yaml := fmt.Sprintf(` |
| 374 | +nginx: |
| 375 | + image: nginx:latest |
| 376 | + ports: |
| 377 | + - 80:80 |
| 378 | + env_file: |
| 379 | + - %s |
| 380 | + environment: |
| 381 | + PARAM1: un_override_value |
| 382 | + PARAM2: override_value |
| 383 | + memory: 1024 |
| 384 | + cpu_units: 1024 |
| 385 | + essential: true |
| 386 | +`, f.Name()) |
| 387 | + |
| 388 | + taskdef, err := CreateTaskDefinition("test-web", yaml, filepath.Dir(f.Name())) |
| 389 | + if err != nil { |
| 390 | + t.Fatal(err) |
| 391 | + } |
| 392 | + |
| 393 | + if "test-web" != taskdef.Name { |
| 394 | + t.Errorf("Name: expect = %v, but actual = %v", "test-web", taskdef.Name) |
| 395 | + } |
| 396 | + |
| 397 | + if con, ok := taskdef.ContainerDefinitions["nginx"]; ok { |
| 398 | + if "nginx" != con.Name { |
| 399 | + t.Errorf("Name: expect = %v, but actual = %v", "nginx", con.Name) |
| 400 | + } |
| 401 | + |
| 402 | + value1, _ := con.Environment["PARAM1"] |
| 403 | + value2, _ := con.Environment["PARAM2"] |
| 404 | + value3, _ := con.Environment["PARAM3"] |
| 405 | + |
| 406 | + if "un_override_value" != value1 { |
| 407 | + t.Errorf("con.Environment[%v]: expect = %v, but actual = %v", "PARAM1", "un_override_value", value1) |
| 408 | + } |
| 409 | + |
| 410 | + if "override_value" != value2 { |
| 411 | + t.Errorf("con.Environment[%v]: expect = %v, but actual = %v", "PARAM2", "override_value", value2) |
| 412 | + } |
| 413 | + |
| 414 | + if "VALUE3_env" != value3 { |
| 415 | + t.Errorf("con.Environment[%v]: expect = %v, but actual = %v", "PARAM3", "override_value", value3) |
| 416 | + } |
| 417 | + |
| 418 | + } else { |
| 419 | + t.Errorf("ContainerDefinitions[nginx]: not found") |
| 420 | + } |
| 421 | + |
| 422 | +} |
0 commit comments