require 'celluloid' require 'fileutils' require 'childprocess' module Buildbox class Runner include Celluloid include Celluloid::Logger def initialize(build) @build = build end def start info "Starting to build #{@build.namespace}/#{@build.id} starting..." FileUtils.mkdir_p(directory_path) File.open(script_path, 'w+') { |file| file.write(@build.script) } File.chmod(0777, script_path) command = Command.new(script_path, :environment => @build.env, :directory => directory_path) @build.output = "" @build.process = command.process @build.started_at = Time.now.utc command.start { |chunk| @build.output << chunk } @build.output = command.output @build.exit_status = command.exit_status File.delete(script_path) @build.finished_at = Time.now.utc info "#{@build.namespace} ##{@build.id} finished with exit status #{command.exit_status}" end private def directory_path @directory_path ||= Buildbox.home_path.join(@build.namespace) end def script_path @script_path ||= Buildbox.home_path.join(script_name) end def script_name name = "#{@build.namespace.gsub(/\//, '-')}-#{@build.id}" name << ".bat" if ChildProcess.platform == :windows name end end end