module Gitlab module QA module Docker class Engine DOCKER_HOST = ENV['DOCKER_HOST'] || 'http://localhost' PRIVILEGED_COMMANDS = [/^iptables.*/].freeze def hostname URI(DOCKER_HOST).host end def login(username:, password:, registry:) Docker::Command.execute(%(login --username "#{username}" --password "#{password}" #{registry}), mask_secrets: password) end def pull(image, tag) Docker::Command.execute("pull #{image}:#{tag}") end def run(image, tag, *args) Docker::Command.new('run').tap do |command| yield command if block_given? command << "#{image}:#{tag}" command << args if args.any? command.execute! end end def privileged_command?(command) PRIVILEGED_COMMANDS.each do |privileged_regex| return true if command.match(privileged_regex) end false end def exec(name, command) cmd = ['exec'] cmd << '--privileged' if privileged_command?(command) Docker::Command.execute("#{cmd.join(' ')} #{name} bash -c '#{command}'") end def read_file(image, tag, path, &block) cat_file = "run --rm --entrypoint /bin/cat #{image}:#{tag} #{path}" Docker::Command.execute(cat_file, &block) end def attach(name, &block) Docker::Command.execute("attach --sig-proxy=false #{name}", &block) end def restart(name) Docker::Command.execute("restart #{name}") end def stop(name) Docker::Command.execute("stop #{name}") end def remove(name) Docker::Command.execute("rm -f #{name}") end def network_exists?(name) Docker::Command.execute("network inspect #{name}") rescue Docker::Shellout::StatusError false else true end def network_create(name) Docker::Command.execute("network create #{name}") end def port(name, port) Docker::Command.execute("port #{name} #{port}/tcp") end def running?(name) Docker::Command.execute("ps -f name=#{name}").include?(name) end def ps(name = nil) Docker::Command.execute(['ps', name].compact.join(' ')) end end end end end