|
@@ -1,6 +1,8 @@
|
|
|
package ps
|
|
|
|
|
|
import (
|
|
|
+ "reflect"
|
|
|
+ "strings"
|
|
|
"testing"
|
|
|
"time"
|
|
|
|
|
@@ -26,7 +28,7 @@ func TestContainerContextID(t *testing.T) {
|
|
|
{types.Container{Image: ""}, true, "<no image>", imageHeader, ctx.Image},
|
|
|
{types.Container{Command: "sh -c 'ls -la'"}, true, `"sh -c 'ls -la'"`, commandHeader, ctx.Command},
|
|
|
{types.Container{Created: int(unix)}, true, time.Unix(unix, 0).String(), createdAtHeader, ctx.CreatedAt},
|
|
|
- {types.Container{Ports: []types.Port{types.Port{PrivatePort: 8080, PublicPort: 8080, Type: "tcp"}}}, true, "8080/tcp", portsHeader, ctx.Ports},
|
|
|
+ {types.Container{Ports: []types.Port{{PrivatePort: 8080, PublicPort: 8080, Type: "tcp"}}}, true, "8080/tcp", portsHeader, ctx.Ports},
|
|
|
{types.Container{Status: "RUNNING"}, true, "RUNNING", statusHeader, ctx.Status},
|
|
|
{types.Container{SizeRw: 10}, true, "10 B", sizeHeader, ctx.Size},
|
|
|
{types.Container{SizeRw: 10, SizeRootFs: 20}, true, "10 B (virtual 20 B)", sizeHeader, ctx.Size},
|
|
@@ -36,7 +38,26 @@ func TestContainerContextID(t *testing.T) {
|
|
|
for _, c := range cases {
|
|
|
ctx = containerContext{c: c.container, trunc: c.trunc}
|
|
|
v := c.call()
|
|
|
- if v != c.expValue {
|
|
|
+ if strings.Contains(v, ",") {
|
|
|
+ // comma-separated values means probably a map input, which won't
|
|
|
+ // be guaranteed to have the same order as our expected value
|
|
|
+ // We'll create maps and use reflect.DeepEquals to check instead:
|
|
|
+ entriesMap := make(map[string]string)
|
|
|
+ expMap := make(map[string]string)
|
|
|
+ entries := strings.Split(v, ",")
|
|
|
+ expectedEntries := strings.Split(c.expValue, ",")
|
|
|
+ for _, entry := range entries {
|
|
|
+ keyval := strings.Split(entry, "=")
|
|
|
+ entriesMap[keyval[0]] = keyval[1]
|
|
|
+ }
|
|
|
+ for _, expected := range expectedEntries {
|
|
|
+ keyval := strings.Split(expected, "=")
|
|
|
+ expMap[keyval[0]] = keyval[1]
|
|
|
+ }
|
|
|
+ if !reflect.DeepEqual(expMap, entriesMap) {
|
|
|
+ t.Fatalf("Expected entries: %v, got: %v", c.expValue, v)
|
|
|
+ }
|
|
|
+ } else if v != c.expValue {
|
|
|
t.Fatalf("Expected %s, was %s\n", c.expValue, v)
|
|
|
}
|
|
|
|
|
@@ -52,17 +73,16 @@ func TestContainerContextID(t *testing.T) {
|
|
|
sid := ctx.Label("com.docker.swarm.swarm-id")
|
|
|
node := ctx.Label("com.docker.swarm.node_name")
|
|
|
if sid != "33" {
|
|
|
- t.Fatal("Expected 33, was %s\n", sid)
|
|
|
+ t.Fatalf("Expected 33, was %s\n", sid)
|
|
|
}
|
|
|
|
|
|
if node != "ubuntu" {
|
|
|
- t.Fatal("Expected ubuntu, was %s\n", node)
|
|
|
+ t.Fatalf("Expected ubuntu, was %s\n", node)
|
|
|
}
|
|
|
|
|
|
h := ctx.fullHeader()
|
|
|
if h != "SWARM ID\tNODE NAME" {
|
|
|
- t.Fatal("Expected %s, was %s\n", "SWARM ID\tNODE NAME", h)
|
|
|
+ t.Fatalf("Expected %s, was %s\n", "SWARM ID\tNODE NAME", h)
|
|
|
|
|
|
}
|
|
|
-
|
|
|
}
|