Sha256: 69d8cf3db7547bfb28c65d5c16b050c3ecd8ab00370fcf7f428f294e42030b16
Contents?: true
Size: 1.72 KB
Versions: 4
Compression:
Stored size: 1.72 KB
Contents
require 'aruba/cucumber' require 'aruba/in_process' require 'geordi/cli' # https://github.com/erikhuda/thor/wiki/Integrating-with-Aruba-In-Process-Runs class InProcessCliRunner # Allow everything fun to be injected from the outside while defaulting to normal implementations. def initialize(argv, stdin = STDIN, stdout = STDOUT, stderr = STDERR, kernel = Kernel) @argv, @stdin, @stdout, @stderr, @kernel = argv, stdin, stdout, stderr, kernel end def execute! exit_code = begin # Thor accesses these streams directly rather than letting them be injected, so we replace them... $stderr = @stderr $stdin = @stdin $stdout = @stdout # Run our normal Thor app the way we know and love. previous_program_name = $PROGRAM_NAME $PROGRAM_NAME = 'geordi' Geordi::CLI.start(@argv) # Thor::Base#start does not have a return value, assume success if no exception is raised. 0 rescue StandardError => e # The ruby interpreter would pipe this to STDERR and exit 1 in the case of an unhandled exception b = e.backtrace @stderr.puts("#{b.shift}: #{e.message} (#{e.class})") @stderr.puts(b.map{|s| "\tfrom #{s}"}.join("\n")) 1 rescue SystemExit => e e.status ensure # add additional cleanup code here $stderr = STDERR $stdin = STDIN $stdout = STDOUT $PROGRAM_NAME = previous_program_name end # Proxy our exit code back to the injected kernel. @kernel.exit(exit_code) end end Aruba.configure do |config| config.main_class = InProcessCliRunner config.command_launcher = :spawn end Before('@same-process') do aruba.config.command_launcher = :in_process end Before do @aruba_timeout_seconds = 5 end
Version data entries
4 entries across 4 versions & 1 rubygems
Version | Path |
---|---|
geordi-2.12.3 | features/support/aruba.rb |
geordi-2.12.2 | features/support/aruba.rb |
geordi-2.12.1 | features/support/aruba.rb |
geordi-2.12.0 | features/support/aruba.rb |