Class: Assert::Runner
Instance Attribute Summary collapse
Instance Method Summary
collapse
#all_pass?, #error_result_count, #fail_result_count, #formatted_result_rate, #formatted_run_time, #formatted_suite_result_rate, #formatted_suite_run_time, #formatted_suite_test_rate, #formatted_test_rate, #ignore_result_count, #ocurring_result_types, #pass_result_count, #result_count, #runner_seed, #show_test_profile_info?, #show_test_verbose_info?, #single_test?, #single_test_file_line, #skip_result_count, #suite, #test_count, #tests_to_run?, #tests_to_run_count, #view
Constructor Details
#initialize(config) ⇒ Runner
Returns a new instance of Runner.
12
13
14
|
# File 'lib/assert/runner.rb', line 12
def initialize(config)
@config = config
end
|
Instance Attribute Details
#config ⇒ Object
Returns the value of attribute config.
10
11
12
|
# File 'lib/assert/runner.rb', line 10
def config
@config
end
|
Instance Method Details
#after_load ⇒ Object
87
|
# File 'lib/assert/runner.rb', line 87
def after_load; end
|
#after_test(test) ⇒ Object
91
|
# File 'lib/assert/runner.rb', line 91
def after_test(test); end
|
#before_load(test_files) ⇒ Object
define callback handlers to do special behavior during the test run. These will be called by the test runner
86
|
# File 'lib/assert/runner.rb', line 86
def before_load(test_files); end
|
#before_test(test) ⇒ Object
89
|
# File 'lib/assert/runner.rb', line 89
def before_test(test); end
|
#on_finish ⇒ Object
92
|
# File 'lib/assert/runner.rb', line 92
def on_finish; end
|
#on_info(test) ⇒ Object
93
|
# File 'lib/assert/runner.rb', line 93
def on_info(test); end
|
#on_interrupt(err) ⇒ Object
94
|
# File 'lib/assert/runner.rb', line 94
def on_interrupt(err); end
|
#on_result(result) ⇒ Object
90
|
# File 'lib/assert/runner.rb', line 90
def on_result(result); end
|
#on_start ⇒ Object
88
|
# File 'lib/assert/runner.rb', line 88
def on_start; end
|
#run ⇒ Object
18
19
20
21
22
23
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
# File 'lib/assert/runner.rb', line 18
def run
self.on_start
self.suite.on_start
self.view.on_start
if self.single_test?
self.view.print "Running test: #{self.single_test_file_line}"
elsif self.tests_to_run?
self.view.print "Running tests in random order"
end
if self.tests_to_run?
self.view.puts ", seeded with \"#{self.runner_seed}\""
end
@current_running_test = nil
if Signal.list.keys.include?("INFO")
Signal.trap("INFO") do
self.on_info(@current_running_test)
self.suite.on_info(@current_running_test)
self.view.on_info(@current_running_test)
end
end
begin
self.suite.start_time = Time.now
self.suite.setups.each(&:call)
tests_to_run.tap{ self.suite.clear_tests_to_run }.delete_if do |test|
@current_running_test = test
self.before_test(test)
self.suite.before_test(test)
self.view.before_test(test)
test.run do |result|
self.on_result(result)
self.suite.on_result(result)
self.view.on_result(result)
end
self.after_test(test)
self.suite.after_test(test)
self.view.after_test(test)
true
end
self.suite.teardowns.each(&:call)
self.suite.end_time = Time.now
rescue Interrupt => err
self.on_interrupt(err)
self.suite.on_interrupt(err)
self.view.on_interrupt(err)
raise(err)
end
(self.fail_result_count + self.error_result_count).tap do
self.view.on_finish
self.suite.on_finish
self.on_finish
end
end
|
#runner ⇒ Object
16
|
# File 'lib/assert/runner.rb', line 16
def runner; self; end
|