Explorar o código

Merge pull request #272 from docker/fix_port_convert_panic

Trying to fix defensively a panic @nebuk89 encountered on ACI,
Guillaume Tardif %!s(int64=5) %!d(string=hai) anos
pai
achega
e904ac86ad
Modificáronse 2 ficheiros con 21 adicións e 1 borrados
  1. 1 1
      azure/convert/ports.go
  2. 20 0
      azure/convert/ports_test.go

+ 1 - 1
azure/convert/ports.go

@@ -37,7 +37,7 @@ func ToPorts(ipAddr *containerinstance.IPAddress, ports []containerinstance.Cont
 			protocol = string(port.Protocol)
 		}
 		ip := ""
-		if ipAddr != nil {
+		if ipAddr != nil && ipAddr.IP != nil {
 			ip = *ipAddr.IP
 		}
 

+ 20 - 0
azure/convert/ports_test.go

@@ -72,6 +72,26 @@ func TestPortConvert(t *testing.T) {
 				},
 			},
 		},
+		{
+			name: "with nil ip value",
+			ip: &containerinstance.IPAddress{
+				IP: nil,
+			},
+			ports: []containerinstance.ContainerPort{
+				{
+					Protocol: "tcp",
+					Port:     to.Int32Ptr(80),
+				},
+			},
+			expected: []containers.Port{
+				{
+					HostPort:      80,
+					ContainerPort: 80,
+					HostIP:        "",
+					Protocol:      "tcp",
+				},
+			},
+		},
 		{
 			name: "skip nil ports",
 			ip:   nil,