Skip to content

Commit

Permalink
Fix docker#3281: Unexpected result when using build args with default…
Browse files Browse the repository at this point in the history
… values

Fix the issue when build arg is set to None instead of empty string. Usecase:

cat docker-compose.yml
  .... args:
  - http_proxy
  - https_proxy
  - no_proxy

If http_proxy, https_proxy, no_proxy environment variables are not defined then http_proxy,
https_proxy, no_proxy build args will be set to string None which breaks all downloads

With this change undefined build args will be set to empty string instead of string None

Signed-off-by: Andrey Devyatkin <andrey.a.devyatkin@gmail.com>
  • Loading branch information
Andrey9kin committed May 28, 2016
1 parent c148849 commit a67ba55
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 1 deletion.
2 changes: 1 addition & 1 deletion compose/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -95,4 +95,4 @@ def microseconds_from_time_nano(time_nano):


def build_string_dict(source_dict):
return dict((k, str(v if v else '')) for k, v in source_dict.items())
return dict((k, str(v if v is not None else '')) for k, v in source_dict.items())
28 changes: 28 additions & 0 deletions tests/unit/config/config_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -717,6 +717,34 @@ def test_build_args_allow_empty_properties(self):
assert 'foo' in service['build']['args']
assert service['build']['args']['foo'] == ''

# If build argument is None then it will be converted to the empty
# string. Make sure that int zero kept as it is, i.e. not converted to
# the empty string
def test_build_args_check_zero_preserved(self):
service = config.load(
build_config_details(
{
'version': '2',
'services': {
'web': {
'build': {
'context': '.',
'dockerfile': 'Dockerfile-alt',
'args': {
'foo': 0
}
}
}
}
},
'tests/fixtures/extends',
'filename.yml'
)
).services[0]
assert 'args' in service['build']
assert 'foo' in service['build']['args']
assert service['build']['args']['foo'] == '0'

def test_load_with_multiple_files_mismatched_networks_format(self):
base_file = config.ConfigFile(
'base.yaml',
Expand Down

0 comments on commit a67ba55

Please sign in to comment.