mirror of https://github.com/docker/docker-py.git
Merge pull request #846 from docker/838-update
Support for build arguments
This commit is contained in:
commit
523e6d48a7
|
@ -1,6 +1,7 @@
|
|||
import logging
|
||||
import os
|
||||
import re
|
||||
import json
|
||||
|
||||
from .. import constants
|
||||
from .. import errors
|
||||
|
@ -16,7 +17,7 @@ class BuildApiMixin(object):
|
|||
nocache=False, rm=False, stream=False, timeout=None,
|
||||
custom_context=False, encoding=None, pull=False,
|
||||
forcerm=False, dockerfile=None, container_limits=None,
|
||||
decode=False):
|
||||
decode=False, buildargs=None):
|
||||
remote = context = headers = None
|
||||
container_limits = container_limits or {}
|
||||
if path is None and fileobj is None:
|
||||
|
@ -71,6 +72,14 @@ class BuildApiMixin(object):
|
|||
}
|
||||
params.update(container_limits)
|
||||
|
||||
if buildargs:
|
||||
if utils.version_gte(self._version, '1.21'):
|
||||
params.update({'buildargs': json.dumps(buildargs)})
|
||||
else:
|
||||
raise errors.InvalidVersion(
|
||||
'buildargs was only introduced in API version 1.21'
|
||||
)
|
||||
|
||||
if context is not None:
|
||||
headers = {'Content-Type': 'application/tar'}
|
||||
if encoding:
|
||||
|
|
|
@ -96,3 +96,21 @@ class BuildTest(api_test.BaseTestCase):
|
|||
list(filter(None, logs.split('\n'))),
|
||||
['not-ignored'],
|
||||
)
|
||||
|
||||
@requires_api_version('1.21')
|
||||
def test_build_with_buildargs(self):
|
||||
script = io.BytesIO('\n'.join([
|
||||
'FROM scratch',
|
||||
'ARG test',
|
||||
'USER $test'
|
||||
]).encode('ascii'))
|
||||
|
||||
stream = self.client.build(
|
||||
fileobj=script, tag='buildargs', buildargs={'test': 'OK'}
|
||||
)
|
||||
self.tmp_imgs.append('buildargs')
|
||||
for chunk in stream:
|
||||
pass
|
||||
|
||||
info = self.client.inspect_image('buildargs')
|
||||
self.assertEqual(info['Config']['User'], 'OK')
|
||||
|
|
Loading…
Reference in New Issue