Ensure build_args are passed into docker compose config file
Prior to this commit, the docker compose build method would not properly set build_args if given in a Vagrantfile. This commit fixes that by using the passed in key `extra_args` from the docker build action.
This commit is contained in:
parent
ec963966cd
commit
f1ea4eaac0
|
@ -34,6 +34,12 @@ module VagrantPlugins
|
||||||
@logger.debug("Data directory for composition file `#{@data_directory}`")
|
@logger.debug("Data directory for composition file `#{@data_directory}`")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Updates the docker compose config file with the given arguments
|
||||||
|
#
|
||||||
|
# @param [String] dir - local directory or git repo URL
|
||||||
|
# @param [Hash] opts - valid key: extra_args
|
||||||
|
# @param [Block] block
|
||||||
|
# @return [Nil]
|
||||||
def build(dir, **opts, &block)
|
def build(dir, **opts, &block)
|
||||||
name = machine.name.to_s
|
name = machine.name.to_s
|
||||||
@logger.debug("Applying build for `#{name}` using `#{dir}` directory.")
|
@logger.debug("Applying build for `#{name}` using `#{dir}` directory.")
|
||||||
|
@ -47,26 +53,26 @@ module VagrantPlugins
|
||||||
services[name]["build"]["dockerfile"] = opts[:extra_args][opts[:extra_args].index("--file") + 1]
|
services[name]["build"]["dockerfile"] = opts[:extra_args][opts[:extra_args].index("--file") + 1]
|
||||||
end
|
end
|
||||||
# Extract any build args that can be found
|
# Extract any build args that can be found
|
||||||
case opts[:build_args]
|
case opts[:extra_args]
|
||||||
when Array
|
when Array
|
||||||
if opts[:build_args].include?("--build-arg")
|
if opts[:extra_args].include?("--build-arg")
|
||||||
idx = 0
|
idx = 0
|
||||||
build_args = {}
|
extra_args = {}
|
||||||
while(idx < opts[:build_args].size)
|
while(idx < opts[:extra_args].size)
|
||||||
arg_value = opts[:build_args][idx]
|
arg_value = opts[:extra_args][idx]
|
||||||
idx += 1
|
idx += 1
|
||||||
if arg_value.start_with?("--build-arg")
|
if arg_value.start_with?("--build-arg")
|
||||||
if !arg_value.include?("=")
|
if !arg_value.include?("=")
|
||||||
arg_value = opts[:build_args][idx]
|
arg_value = opts[:extra_args][idx]
|
||||||
idx += 1
|
idx += 1
|
||||||
end
|
end
|
||||||
key, val = arg_value.to_s.split("=", 2).to_s.split("=")
|
key, val = arg_value.to_s.split("=", 2).to_s.split("=")
|
||||||
build_args[key] = val
|
extra_args[key] = val
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
when Hash
|
when Hash
|
||||||
services[name]["build"]["args"] = opts[:build_args]
|
services[name]["build"]["args"] = opts[:extra_args]
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
rescue => error
|
rescue => error
|
||||||
|
|
|
@ -54,6 +54,23 @@ describe VagrantPlugins::DockerProvider::Driver::Compose do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe '#build' do
|
||||||
|
it 'creates a compose config with no extra options' do
|
||||||
|
expect(subject).to receive(:update_composition)
|
||||||
|
subject.build(composition_path)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'creates a compose config when given an array for build-arg' do
|
||||||
|
expect(subject).to receive(:update_composition)
|
||||||
|
subject.build(composition_path, extra_args: ["foo", "bar"])
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'creates a compose config when given a hash for build-arg' do
|
||||||
|
expect(subject).to receive(:update_composition)
|
||||||
|
subject.build(composition_path, extra_args: {"foo"=>"bar"})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
describe '#create' do
|
describe '#create' do
|
||||||
let(:params) { {
|
let(:params) { {
|
||||||
image: 'jimi/hendrix:electric-ladyland',
|
image: 'jimi/hendrix:electric-ladyland',
|
||||||
|
|
Loading…
Reference in New Issue