Sha256: b100c0594e66ef44a55aba42255efba7901006a0178c60067c0ac4b337c8c87d
Contents?: true
Size: 1.22 KB
Versions: 1
Compression:
Stored size: 1.22 KB
Contents
require 'rubygems' require 'celluloid' require 'fileutils' module Buildbox class Runner include Celluloid include Celluloid::Logger attr_reader :build 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) info "Running script: #{script_path}" @build.started_at = Time.now.utc build.output = "" result = Command.run(script_path, :environment => @build.env, :directory => directory_path) do |chunk| build.output << chunk end build.output = result.output build.exit_status = result.exit_status File.delete(script_path) @build.finished_at = Time.now.utc info "#{@build.namespace} ##{@build.id} finished with exit status #{result.exit_status}" end private def directory_path @directory_path ||= Buildbox.root_path.join(@build.namespace) end def script_path @script_path ||= Buildbox.root_path.join("buildbox-#{@build.namespace.gsub(/\//, '-')}-#{@build.id}") end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
buildbox-0.3.2 | lib/buildbox/runner.rb |