source: extensions/gsdl-video/trunk/installed/cmdline/lib/ruby/1.8/test/unit/ui/console/testrunner.rb@ 18425

Last change on this file since 18425 was 18425, checked in by davidb, 15 years ago

Video extension to Greenstone

File size: 3.6 KB
Line 
1#--
2#
3# Author:: Nathaniel Talbott.
4# Copyright:: Copyright (c) 2000-2003 Nathaniel Talbott. All rights reserved.
5# License:: Ruby license.
6
7require 'test/unit/ui/testrunnermediator'
8require 'test/unit/ui/testrunnerutilities'
9
10module Test
11 module Unit
12 module UI
13 module Console
14
15 # Runs a Test::Unit::TestSuite on the console.
16 class TestRunner
17 extend TestRunnerUtilities
18
19 # Creates a new TestRunner for running the passed
20 # suite. If quiet_mode is true, the output while
21 # running is limited to progress dots, errors and
22 # failures, and the final result. io specifies
23 # where runner output should go to; defaults to
24 # STDOUT.
25 def initialize(suite, output_level=NORMAL, io=STDOUT)
26 if (suite.respond_to?(:suite))
27 @suite = suite.suite
28 else
29 @suite = suite
30 end
31 @output_level = output_level
32 @io = io
33 @already_outputted = false
34 @faults = []
35 end
36
37 # Begins the test run.
38 def start
39 setup_mediator
40 attach_to_mediator
41 return start_mediator
42 end
43
44 private
45 def setup_mediator
46 @mediator = create_mediator(@suite)
47 suite_name = @suite.to_s
48 if ( @suite.kind_of?(Module) )
49 suite_name = @suite.name
50 end
51 output("Loaded suite #{suite_name}")
52 end
53
54 def create_mediator(suite)
55 return TestRunnerMediator.new(suite)
56 end
57
58 def attach_to_mediator
59 @mediator.add_listener(TestResult::FAULT, &method(:add_fault))
60 @mediator.add_listener(TestRunnerMediator::STARTED, &method(:started))
61 @mediator.add_listener(TestRunnerMediator::FINISHED, &method(:finished))
62 @mediator.add_listener(TestCase::STARTED, &method(:test_started))
63 @mediator.add_listener(TestCase::FINISHED, &method(:test_finished))
64 end
65
66 def start_mediator
67 return @mediator.run_suite
68 end
69
70 def add_fault(fault)
71 @faults << fault
72 output_single(fault.single_character_display, PROGRESS_ONLY)
73 @already_outputted = true
74 end
75
76 def started(result)
77 @result = result
78 output("Started")
79 end
80
81 def finished(elapsed_time)
82 nl
83 output("Finished in #{elapsed_time} seconds.")
84 @faults.each_with_index do |fault, index|
85 nl
86 output("%3d) %s" % [index + 1, fault.long_display])
87 end
88 nl
89 output(@result)
90 end
91
92 def test_started(name)
93 output_single(name + ": ", VERBOSE)
94 end
95
96 def test_finished(name)
97 output_single(".", PROGRESS_ONLY) unless (@already_outputted)
98 nl(VERBOSE)
99 @already_outputted = false
100 end
101
102 def nl(level=NORMAL)
103 output("", level)
104 end
105
106 def output(something, level=NORMAL)
107 @io.puts(something) if (output?(level))
108 @io.flush
109 end
110
111 def output_single(something, level=NORMAL)
112 @io.write(something) if (output?(level))
113 @io.flush
114 end
115
116 def output?(level)
117 level <= @output_level
118 end
119 end
120 end
121 end
122 end
123end
124
125if __FILE__ == $0
126 Test::Unit::UI::Console::TestRunner.start_command_line_test
127end
Note: See TracBrowser for help on using the repository browser.