summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAsh Wilson <smashwilson@gmail.com>2015-03-09 12:17:39 -0400
committerAsh Wilson <smashwilson@gmail.com>2015-03-09 12:17:39 -0400
commit19664a96dbf08c29a75e1f9b2c87d66225f4a4f4 (patch)
tree5fa874067cf6b9e6781f4789a53669e1c90e7df4
parent608ddbea29ed7b5ba85efdf465e844b2a32494c4 (diff)
downloadansible-modules-core-19664a96dbf08c29a75e1f9b2c87d66225f4a4f4.tar.gz
Expect module env vars to override Dockerfile ones.
-rw-r--r--cloud/docker/docker.py15
1 files changed, 12 insertions, 3 deletions
diff --git a/cloud/docker/docker.py b/cloud/docker/docker.py
index ff8391ae..b382a388 100644
--- a/cloud/docker/docker.py
+++ b/cloud/docker/docker.py
@@ -842,11 +842,20 @@ class DockerManager(object):
# actual_env is likely to include environment variables injected by
# the Dockerfile.
- expected_env = set(image['ContainerConfig']['Env'] or [])
+ expected_env = {}
+
+ for image_env in image['ContainerConfig']['Env'] or []:
+ name, value = image_env.split('=', 1)
+ expected_env[name] = value
+
if self.env:
for name, value in self.env.iteritems():
- expected_env.add("{}={}".format(name, value))
- actual_env = set(container['Config']['Env'] or [])
+ expected_env[name] = value
+
+ actual_env = {}
+ for container_env in container['Config']['Env'] or []:
+ name, value = container_env.split('=', 1)
+ actual_env[name] = value
if actual_env != expected_env:
# Don't include the environment difference in the output.