Class: Testjour::CLI::SlaveRun

Inherits:
BaseCommand show all
Defined in:
lib/testjour/commands/slave_run.rb

Instance Attribute Summary

Attributes inherited from BaseCommand

#non_options, #options

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from BaseCommand

detailed_help, help, #option_parser, options

Constructor Details

#initialize(parser, args) ⇒ SlaveRun

Returns a new instance of SlaveRun.



18
19
20
21
22
# File 'lib/testjour/commands/slave_run.rb', line 18

def initialize(parser, args)
  Testjour.logger.debug "Runner command #{self.class}..."
  super
  @queue = @non_options.first
end

Class Method Details

.commandObject



14
15
16
# File 'lib/testjour/commands/slave_run.rb', line 14

def self.command
  "slave:run"
end

Instance Method Details

#drb_uriObject



72
73
74
75
76
77
78
# File 'lib/testjour/commands/slave_run.rb', line 72

def drb_uri
  uri = URI.parse(@queue)
  uri.scheme = "druby"
  uri.path = ""
  uri.user = nil
  uri.to_s
end

#feature_parserObject



80
81
82
# File 'lib/testjour/commands/slave_run.rb', line 80

def feature_parser
  @feature_parser ||= Cucumber::TreetopParser::FeatureParser.new
end

#queue_serverObject



65
66
67
68
69
70
# File 'lib/testjour/commands/slave_run.rb', line 65

def queue_server
  @queue_server ||= begin
    DRb.start_service
    DRbObject.new(nil, drb_uri)
  end
end

#require_filesObject



53
54
55
56
57
# File 'lib/testjour/commands/slave_run.rb', line 53

def require_files
  cli = Cucumber::CLI.new
  cli.parse_options!(@non_options)
  cli.send(:require_files)
end

#runObject



24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
# File 'lib/testjour/commands/slave_run.rb', line 24

def run
  retryable :tries => 2, :on => RsyncFailed do
    Testjour::Rsync.copy_to_current_directory_from(@queue)
  end
  
  ARGV.clear # Don't pass along args to RSpec
  Testjour.load_cucumber
  
  ENV["RAILS_ENV"] = "test"
  require File.expand_path("config/environment")
  
  Testjour::MysqlDatabaseSetup.with_new_database do
    Cucumber::CLI.executor.formatters = Testjour::DRbFormatter.new(queue_server)
    require_files

    begin
      loop do
        begin
          run_file(queue_server.take_work)
        rescue Testjour::QueueServer::NoWorkUnitsAvailableError
          # If no work, ignore and keep looping
        end
      end
    rescue DRb::DRbConnError
      Testjour.logger.debug "DRb connection error. (This is normal.) Exiting runner."
    end
  end
end

#run_file(file) ⇒ Object



59
60
61
62
63
# File 'lib/testjour/commands/slave_run.rb', line 59

def run_file(file)
  Testjour.logger.debug "Running feature file: #{file}"
  features = feature_parser.parse_feature(File.expand_path(file))
  Cucumber::CLI.executor.visit_features(features)
end