Sha256: eec14b03ebd839533b187bab43be202edd0d6d72cc4a3dd0ff15db66d0a8fa0b
Contents?: true
Size: 1.54 KB
Versions: 10
Compression:
Stored size: 1.54 KB
Contents
require File.expand_path(File.join(File.dirname(__FILE__), 'runner.rb')) module Testbot::Runner class Job attr_reader :root, :project, :requester_mac def initialize(runner, id, requester_mac, project, root, type, ruby_interpreter, files) @runner, @id, @requester_mac, @project, @root, @type, @ruby_interpreter, @files = runner, id, requester_mac, project, root, type, ruby_interpreter, files end def jruby? @ruby_interpreter == 'jruby' end def run(instance) puts "Running job #{@id} from #{@requester_mac}... " test_env_number = (instance == 0) ? '' : instance + 1 result = "\n#{`hostname`.chomp}:#{Dir.pwd}\n" base_environment = "export RAILS_ENV=test; export TEST_ENV_NUMBER=#{test_env_number}; cd #{@project};" adapter = Adapter.find(@type) run_time = measure_run_time do result += run_and_return_result("#{base_environment} #{adapter.command(@project, ruby_cmd, @files)}") end Server.put("/jobs/#{@id}", :body => { :result => result, :success => success?, :time => run_time }) puts "Job #{@id} finished." end private def measure_run_time start_time = Time.now yield (Time.now - start_time) * 100 end def run_and_return_result(command) `#{command} 2>&1` end def success? $?.exitstatus == 0 end def ruby_cmd if @ruby_interpreter == 'jruby' && @runner.config.jruby_opts 'jruby ' + @runner.config.jruby_opts else @ruby_interpreter end end end end
Version data entries
10 entries across 10 versions & 1 rubygems