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.
11
12
13
|
# File 'lib/assert/runner.rb', line 11
def initialize(config)
@config = config
end
|
Instance Attribute Details
#config ⇒ Object
Returns the value of attribute config.
9
10
11
|
# File 'lib/assert/runner.rb', line 9
def config
@config
end
|
Instance Method Details
#after_load ⇒ Object
86
|
# File 'lib/assert/runner.rb', line 86
def after_load; end
|
#after_test(test) ⇒ Object
90
|
# File 'lib/assert/runner.rb', line 90
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
85
|
# File 'lib/assert/runner.rb', line 85
def before_load(test_files); end
|
#before_test(test) ⇒ Object
88
|
# File 'lib/assert/runner.rb', line 88
def before_test(test); end
|
#on_finish ⇒ Object
91
|
# File 'lib/assert/runner.rb', line 91
def on_finish; end
|
#on_info(test) ⇒ Object
92
|
# File 'lib/assert/runner.rb', line 92
def on_info(test); end
|
#on_interrupt(err) ⇒ Object
93
|
# File 'lib/assert/runner.rb', line 93
def on_interrupt(err); end
|
#on_result(result) ⇒ Object
89
|
# File 'lib/assert/runner.rb', line 89
def on_result(result); end
|
#on_start ⇒ Object
87
|
# File 'lib/assert/runner.rb', line 87
def on_start; end
|
#run ⇒ Object
17
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
|
# File 'lib/assert/runner.rb', line 17
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
15
|
# File 'lib/assert/runner.rb', line 15
def runner; self; end
|