Class: Testjour::CLI::LocalRun

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

Direct Known Subclasses

SlaveRun

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, inherited, #option_parser, options

Constructor Details

#initialize(parser, args) ⇒ LocalRun

Returns a new instance of LocalRun.


17
18
19
20
21
# File 'lib/testjour/commands/local_run.rb', line 17

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

Class Method Details

.commandObject


13
14
15
# File 'lib/testjour/commands/local_run.rb', line 13

def self.command
  "local:run"
end

Instance Method Details

#drb_uriObject


72
73
74
75
76
77
78
# File 'lib/testjour/commands/local_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/local_run.rb', line 80

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

#options_for_cucumberObject


55
56
57
# File 'lib/testjour/commands/local_run.rb', line 55

def options_for_cucumber
  @non_options
end

#queue_serverObject


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

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

#require_filesObject


48
49
50
51
52
53
# File 'lib/testjour/commands/local_run.rb', line 48

def require_files
  cli = Cucumber::CLI.new
  Testjour.logger.debug "Cucumber options: #{options_for_cucumber.inspect}"
  cli.parse_options!(options_for_cucumber)
  cli.send(:require_files)
end

#runObject


23
24
25
26
27
28
29
30
31
32
# File 'lib/testjour/commands/local_run.rb', line 23

def run
  ARGV.clear # Don't pass along args to RSpec
  Testjour.load_cucumber
  
  Testjour::MysqlDatabaseSetup.with_new_database do
    Cucumber::CLI.executor.formatters = Testjour::DRbFormatter.new(queue_server)
    require_files
    work
  end
end

#run_file(file) ⇒ Object


59
60
61
62
63
# File 'lib/testjour/commands/local_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

#workObject


34
35
36
37
38
39
40
41
42
43
44
45
46
# File 'lib/testjour/commands/local_run.rb', line 34

def work
  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