Class: Buildbox::Runner
- Inherits:
-
Object
- Object
- Buildbox::Runner
- Includes:
- Celluloid, Celluloid::Logger
- Defined in:
- lib/buildbox/runner.rb
Class Method Summary collapse
Instance Method Summary collapse
- #build_directory ⇒ Object
-
#initialize(build) ⇒ Runner
constructor
A new instance of Runner.
- #start ⇒ Object
Constructor Details
#initialize(build) ⇒ Runner
Returns a new instance of Runner.
16 17 18 |
# File 'lib/buildbox/runner.rb', line 16 def initialize(build) @build = build end |
Class Method Details
.start(build) ⇒ Object
10 11 12 13 14 |
# File 'lib/buildbox/runner.rb', line 10 def self.start(build) runner = new(build) runner.start runner end |
Instance Method Details
#build_directory ⇒ Object
20 21 22 |
# File 'lib/buildbox/runner.rb', line 20 def build_directory @build_directory ||= Buildbox.home_path.join(@build.namespace) end |
#start ⇒ Object
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'lib/buildbox/runner.rb', line 24 def start info "Starting to build #{@build.namespace}/#{@build.id} starting..." FileUtils.mkdir_p(build_directory) File.open(script_path, 'w+') { |file| file.write(@build.script) } File.chmod(0777, script_path) command = Command.new(script_path, :environment => @build.env, :directory => build_directory) @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 |