glib2 0.90.8 → 0.90.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/ChangeLog +44 -0
- data/Rakefile +1 -0
- data/ext/glib2/rbglib.h +1 -1
- data/ext/glib2/rbglib_iochannel.c +15 -6
- data/ext/glib2/rbgobj_signal.c +1 -1
- data/ext/glib2/rbgobject.h +1 -1
- data/lib/gnome2-raketask.rb +4 -2
- data/lib/mkmf-gnome2.rb +47 -23
- data/test/glib-test-init.rb +1 -3
- metadata +20 -121
- data/test-unit/COPYING +0 -56
- data/test-unit/GPL +0 -340
- data/test-unit/History.txt +0 -279
- data/test-unit/Manifest.txt +0 -110
- data/test-unit/PSFL +0 -271
- data/test-unit/README.txt +0 -75
- data/test-unit/Rakefile +0 -53
- data/test-unit/TODO +0 -5
- data/test-unit/bin/testrb +0 -5
- data/test-unit/html/bar.png +0 -0
- data/test-unit/html/bar.svg +0 -153
- data/test-unit/html/developer.png +0 -0
- data/test-unit/html/developer.svg +0 -469
- data/test-unit/html/famfamfam-logo.png +0 -0
- data/test-unit/html/favicon.ico +0 -0
- data/test-unit/html/favicon.png +0 -0
- data/test-unit/html/favicon.svg +0 -82
- data/test-unit/html/heading-mark.png +0 -0
- data/test-unit/html/heading-mark.svg +0 -393
- data/test-unit/html/index.html +0 -285
- data/test-unit/html/index.html.ja +0 -299
- data/test-unit/html/install.png +0 -0
- data/test-unit/html/install.svg +0 -636
- data/test-unit/html/jp.png +0 -0
- data/test-unit/html/kinotan-failure.png +0 -0
- data/test-unit/html/kinotan-pass.png +0 -0
- data/test-unit/html/logo.png +0 -0
- data/test-unit/html/logo.svg +0 -483
- data/test-unit/html/reference.png +0 -0
- data/test-unit/html/rubyforge.png +0 -0
- data/test-unit/html/tango-logo.png +0 -0
- data/test-unit/html/test-unit.css +0 -339
- data/test-unit/html/tutorial.png +0 -0
- data/test-unit/html/tutorial.svg +0 -559
- data/test-unit/html/us.png +0 -0
- data/test-unit/images/color-diff.png +0 -0
- data/test-unit/lib/test/unit.rb +0 -328
- data/test-unit/lib/test/unit/assertionfailederror.rb +0 -25
- data/test-unit/lib/test/unit/assertions.rb +0 -1792
- data/test-unit/lib/test/unit/attribute.rb +0 -125
- data/test-unit/lib/test/unit/autorunner.rb +0 -415
- data/test-unit/lib/test/unit/collector.rb +0 -38
- data/test-unit/lib/test/unit/collector/descendant.rb +0 -23
- data/test-unit/lib/test/unit/collector/dir.rb +0 -108
- data/test-unit/lib/test/unit/collector/load.rb +0 -187
- data/test-unit/lib/test/unit/collector/objectspace.rb +0 -34
- data/test-unit/lib/test/unit/collector/xml.rb +0 -250
- data/test-unit/lib/test/unit/color-scheme.rb +0 -106
- data/test-unit/lib/test/unit/color.rb +0 -96
- data/test-unit/lib/test/unit/diff.rb +0 -740
- data/test-unit/lib/test/unit/error.rb +0 -131
- data/test-unit/lib/test/unit/exceptionhandler.rb +0 -39
- data/test-unit/lib/test/unit/failure.rb +0 -136
- data/test-unit/lib/test/unit/fixture.rb +0 -185
- data/test-unit/lib/test/unit/notification.rb +0 -129
- data/test-unit/lib/test/unit/omission.rb +0 -191
- data/test-unit/lib/test/unit/pending.rb +0 -150
- data/test-unit/lib/test/unit/priority.rb +0 -180
- data/test-unit/lib/test/unit/runner/console.rb +0 -52
- data/test-unit/lib/test/unit/runner/emacs.rb +0 -8
- data/test-unit/lib/test/unit/runner/tap.rb +0 -8
- data/test-unit/lib/test/unit/runner/xml.rb +0 -15
- data/test-unit/lib/test/unit/testcase.rb +0 -515
- data/test-unit/lib/test/unit/testresult.rb +0 -125
- data/test-unit/lib/test/unit/testsuite.rb +0 -134
- data/test-unit/lib/test/unit/ui/console/outputlevel.rb +0 -14
- data/test-unit/lib/test/unit/ui/console/testrunner.rb +0 -467
- data/test-unit/lib/test/unit/ui/emacs/testrunner.rb +0 -63
- data/test-unit/lib/test/unit/ui/tap/testrunner.rb +0 -82
- data/test-unit/lib/test/unit/ui/testrunner.rb +0 -53
- data/test-unit/lib/test/unit/ui/testrunnermediator.rb +0 -86
- data/test-unit/lib/test/unit/ui/testrunnerutilities.rb +0 -41
- data/test-unit/lib/test/unit/ui/xml/testrunner.rb +0 -224
- data/test-unit/lib/test/unit/util/backtracefilter.rb +0 -42
- data/test-unit/lib/test/unit/util/method-owner-finder.rb +0 -28
- data/test-unit/lib/test/unit/util/observable.rb +0 -90
- data/test-unit/lib/test/unit/util/output.rb +0 -31
- data/test-unit/lib/test/unit/util/procwrapper.rb +0 -48
- data/test-unit/lib/test/unit/version.rb +0 -7
- data/test-unit/sample/adder.rb +0 -13
- data/test-unit/sample/subtracter.rb +0 -12
- data/test-unit/sample/test_adder.rb +0 -20
- data/test-unit/sample/test_subtracter.rb +0 -20
- data/test-unit/sample/test_user.rb +0 -23
- data/test-unit/test/collector/test-descendant.rb +0 -133
- data/test-unit/test/collector/test-load.rb +0 -442
- data/test-unit/test/collector/test_dir.rb +0 -406
- data/test-unit/test/collector/test_objectspace.rb +0 -100
- data/test-unit/test/run-test.rb +0 -22
- data/test-unit/test/test-assertions.rb +0 -1849
- data/test-unit/test/test-attribute.rb +0 -86
- data/test-unit/test/test-color-scheme.rb +0 -69
- data/test-unit/test/test-color.rb +0 -47
- data/test-unit/test/test-diff.rb +0 -518
- data/test-unit/test/test-emacs-runner.rb +0 -60
- data/test-unit/test/test-fixture.rb +0 -324
- data/test-unit/test/test-notification.rb +0 -33
- data/test-unit/test/test-omission.rb +0 -81
- data/test-unit/test/test-pending.rb +0 -70
- data/test-unit/test/test-priority.rb +0 -119
- data/test-unit/test/test-testcase.rb +0 -569
- data/test-unit/test/test_error.rb +0 -26
- data/test-unit/test/test_failure.rb +0 -33
- data/test-unit/test/test_testresult.rb +0 -113
- data/test-unit/test/test_testsuite.rb +0 -137
- data/test-unit/test/testunit-test-util.rb +0 -14
- data/test-unit/test/ui/test_tap.rb +0 -33
- data/test-unit/test/ui/test_testrunmediator.rb +0 -20
- data/test-unit/test/util/test-method-owner-finder.rb +0 -38
- data/test-unit/test/util/test-output.rb +0 -11
- data/test-unit/test/util/test_backtracefilter.rb +0 -41
- data/test-unit/test/util/test_observable.rb +0 -102
- data/test-unit/test/util/test_procwrapper.rb +0 -36
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
require 'test/unit/ui/console/testrunner'
|
|
2
|
-
|
|
3
|
-
module Test
|
|
4
|
-
module Unit
|
|
5
|
-
module UI
|
|
6
|
-
module Emacs
|
|
7
|
-
class TestRunner < Console::TestRunner
|
|
8
|
-
private
|
|
9
|
-
def output_setup_end
|
|
10
|
-
end
|
|
11
|
-
|
|
12
|
-
def output_started
|
|
13
|
-
end
|
|
14
|
-
|
|
15
|
-
def format_fault(fault)
|
|
16
|
-
return super unless fault.respond_to?(:label)
|
|
17
|
-
format_method_name = "format_fault_#{fault.label.downcase}"
|
|
18
|
-
if respond_to?(format_method_name, true)
|
|
19
|
-
send(format_method_name, fault)
|
|
20
|
-
else
|
|
21
|
-
super
|
|
22
|
-
end
|
|
23
|
-
end
|
|
24
|
-
|
|
25
|
-
def output_fault_backtrace(fault)
|
|
26
|
-
backtrace = fault.location
|
|
27
|
-
if backtrace.size == 1
|
|
28
|
-
output(fault.test_name +
|
|
29
|
-
backtrace[0].sub(/\A(.+:\d+).*/, ' [\\1]') +
|
|
30
|
-
":")
|
|
31
|
-
else
|
|
32
|
-
output(fault.test_name)
|
|
33
|
-
backtrace.each do |entry|
|
|
34
|
-
output(entry)
|
|
35
|
-
end
|
|
36
|
-
end
|
|
37
|
-
end
|
|
38
|
-
|
|
39
|
-
def format_fault_failure(failure)
|
|
40
|
-
if failure.location.size == 1
|
|
41
|
-
location = failure.location[0]
|
|
42
|
-
location_display = location.sub(/\A(.+:\d+).*/, ' [\\1]')
|
|
43
|
-
else
|
|
44
|
-
location_display = "\n" + failure.location.join("\n")
|
|
45
|
-
end
|
|
46
|
-
result = "#{failure.label}:\n"
|
|
47
|
-
result << "#{failure.test_name}#{location_display}:\n"
|
|
48
|
-
result << failure.message
|
|
49
|
-
result
|
|
50
|
-
end
|
|
51
|
-
|
|
52
|
-
def format_fault_error(error)
|
|
53
|
-
result = "#{error.label}:\n"
|
|
54
|
-
result << "#{error.test_name}:\n"
|
|
55
|
-
result << "#{error.message}\n"
|
|
56
|
-
result << error.backtrace.join("\n")
|
|
57
|
-
result
|
|
58
|
-
end
|
|
59
|
-
end
|
|
60
|
-
end
|
|
61
|
-
end
|
|
62
|
-
end
|
|
63
|
-
end
|
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
#--
|
|
2
|
-
#
|
|
3
|
-
# Author:: Kouhei Sutou.
|
|
4
|
-
# Copyright:: Copyright (c) 2009-2010 Kouhei Sutou <kou@clear-code.com>.
|
|
5
|
-
# License:: Ruby license.
|
|
6
|
-
|
|
7
|
-
require 'test/unit/ui/testrunner'
|
|
8
|
-
require 'test/unit/ui/testrunnermediator'
|
|
9
|
-
|
|
10
|
-
module Test
|
|
11
|
-
module Unit
|
|
12
|
-
module UI
|
|
13
|
-
module Tap
|
|
14
|
-
|
|
15
|
-
# Runs a Test::Unit::TestSuite and outputs result
|
|
16
|
-
# as TAP format.
|
|
17
|
-
class TestRunner < UI::TestRunner
|
|
18
|
-
def initialize(suite, options={})
|
|
19
|
-
super
|
|
20
|
-
@output = @options[:output] || STDOUT
|
|
21
|
-
@n_tests = 0
|
|
22
|
-
@already_outputted = false
|
|
23
|
-
end
|
|
24
|
-
|
|
25
|
-
# Begins the test run.
|
|
26
|
-
def start
|
|
27
|
-
result = super
|
|
28
|
-
def result.passed?
|
|
29
|
-
true # for prove commend :<
|
|
30
|
-
end
|
|
31
|
-
result
|
|
32
|
-
end
|
|
33
|
-
|
|
34
|
-
private
|
|
35
|
-
def attach_to_mediator
|
|
36
|
-
@mediator.add_listener(TestResult::FAULT, &method(:add_fault))
|
|
37
|
-
@mediator.add_listener(TestRunnerMediator::STARTED, &method(:started))
|
|
38
|
-
@mediator.add_listener(TestRunnerMediator::FINISHED, &method(:finished))
|
|
39
|
-
@mediator.add_listener(TestCase::STARTED, &method(:test_started))
|
|
40
|
-
@mediator.add_listener(TestCase::FINISHED, &method(:test_finished))
|
|
41
|
-
end
|
|
42
|
-
|
|
43
|
-
def add_fault(fault)
|
|
44
|
-
puts("not ok #{@n_tests} - #{fault.short_display}")
|
|
45
|
-
fault.long_display.each_line do |line|
|
|
46
|
-
puts("# #{line}")
|
|
47
|
-
end
|
|
48
|
-
@already_outputted = true
|
|
49
|
-
end
|
|
50
|
-
|
|
51
|
-
def started(result)
|
|
52
|
-
@result = result
|
|
53
|
-
puts("1..#{@suite.size}")
|
|
54
|
-
end
|
|
55
|
-
|
|
56
|
-
def finished(elapsed_time)
|
|
57
|
-
puts("# Finished in #{elapsed_time} seconds.")
|
|
58
|
-
@result.to_s.each_line do |line|
|
|
59
|
-
puts("# #{line}")
|
|
60
|
-
end
|
|
61
|
-
end
|
|
62
|
-
|
|
63
|
-
def test_started(name)
|
|
64
|
-
@n_tests += 1
|
|
65
|
-
end
|
|
66
|
-
|
|
67
|
-
def test_finished(name)
|
|
68
|
-
unless @already_outputted
|
|
69
|
-
puts("ok #{@n_tests} - #{name}")
|
|
70
|
-
end
|
|
71
|
-
@already_outputted = false
|
|
72
|
-
end
|
|
73
|
-
|
|
74
|
-
def puts(*args)
|
|
75
|
-
@output.puts(*args)
|
|
76
|
-
@output.flush
|
|
77
|
-
end
|
|
78
|
-
end
|
|
79
|
-
end
|
|
80
|
-
end
|
|
81
|
-
end
|
|
82
|
-
end
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
require 'test/unit/ui/testrunnerutilities'
|
|
2
|
-
|
|
3
|
-
module Test
|
|
4
|
-
module Unit
|
|
5
|
-
module UI
|
|
6
|
-
class TestRunner
|
|
7
|
-
extend TestRunnerUtilities
|
|
8
|
-
|
|
9
|
-
attr_reader :listeners
|
|
10
|
-
def initialize(suite, options={})
|
|
11
|
-
if suite.respond_to?(:suite)
|
|
12
|
-
@suite = suite.suite
|
|
13
|
-
else
|
|
14
|
-
@suite = suite
|
|
15
|
-
end
|
|
16
|
-
@options = options
|
|
17
|
-
@listeners = @options[:listeners] || []
|
|
18
|
-
end
|
|
19
|
-
|
|
20
|
-
# Begins the test run.
|
|
21
|
-
def start
|
|
22
|
-
setup_mediator
|
|
23
|
-
attach_to_mediator
|
|
24
|
-
attach_listeners
|
|
25
|
-
start_mediator
|
|
26
|
-
end
|
|
27
|
-
|
|
28
|
-
private
|
|
29
|
-
def setup_mediator
|
|
30
|
-
@mediator = TestRunnerMediator.new(@suite)
|
|
31
|
-
end
|
|
32
|
-
|
|
33
|
-
def attach_listeners
|
|
34
|
-
@listeners.each do |listener|
|
|
35
|
-
listener.attach_to_mediator(@mediator)
|
|
36
|
-
end
|
|
37
|
-
end
|
|
38
|
-
|
|
39
|
-
def start_mediator
|
|
40
|
-
@mediator.run_suite
|
|
41
|
-
end
|
|
42
|
-
|
|
43
|
-
def diff_target_string?(string)
|
|
44
|
-
Assertions::AssertionMessage.diff_target_string?(string)
|
|
45
|
-
end
|
|
46
|
-
|
|
47
|
-
def prepare_for_diff(from, to)
|
|
48
|
-
Assertions::AssertionMessage.prepare_for_diff(from, to)
|
|
49
|
-
end
|
|
50
|
-
end
|
|
51
|
-
end
|
|
52
|
-
end
|
|
53
|
-
end
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
#--
|
|
2
|
-
#
|
|
3
|
-
# Author:: Nathaniel Talbott.
|
|
4
|
-
# Copyright:: Copyright (c) 2000-2002 Nathaniel Talbott. All rights reserved.
|
|
5
|
-
# License:: Ruby license.
|
|
6
|
-
|
|
7
|
-
require 'test/unit'
|
|
8
|
-
require 'test/unit/util/observable'
|
|
9
|
-
require 'test/unit/testresult'
|
|
10
|
-
|
|
11
|
-
module Test
|
|
12
|
-
module Unit
|
|
13
|
-
module UI
|
|
14
|
-
|
|
15
|
-
# Provides an interface to write any given UI against,
|
|
16
|
-
# hopefully making it easy to write new UIs.
|
|
17
|
-
class TestRunnerMediator
|
|
18
|
-
RESET = name + "::RESET"
|
|
19
|
-
STARTED = name + "::STARTED"
|
|
20
|
-
FINISHED = name + "::FINISHED"
|
|
21
|
-
|
|
22
|
-
include Util::Observable
|
|
23
|
-
|
|
24
|
-
# Creates a new TestRunnerMediator initialized to run
|
|
25
|
-
# the passed suite.
|
|
26
|
-
def initialize(suite)
|
|
27
|
-
@suite = suite
|
|
28
|
-
end
|
|
29
|
-
|
|
30
|
-
# Runs the suite the TestRunnerMediator was created
|
|
31
|
-
# with.
|
|
32
|
-
def run_suite
|
|
33
|
-
Unit.run = true
|
|
34
|
-
|
|
35
|
-
result = create_result
|
|
36
|
-
finished_listener = result.add_listener(TestResult::FINISHED) do |*args|
|
|
37
|
-
notify_listeners(TestResult::FINISHED, *args)
|
|
38
|
-
end
|
|
39
|
-
changed_listener = result.add_listener(TestResult::CHANGED) do |*args|
|
|
40
|
-
notify_listeners(TestResult::CHANGED, *args)
|
|
41
|
-
end
|
|
42
|
-
pass_assertion_listener = result.add_listener(TestResult::PASS_ASSERTION) do |*args|
|
|
43
|
-
notify_listeners(TestResult::PASS_ASSERTION, *args)
|
|
44
|
-
end
|
|
45
|
-
fault_listener = result.add_listener(TestResult::FAULT) do |*args|
|
|
46
|
-
notify_listeners(TestResult::FAULT, *args)
|
|
47
|
-
end
|
|
48
|
-
|
|
49
|
-
start_time = Time.now
|
|
50
|
-
begin
|
|
51
|
-
notify_listeners(RESET, @suite.size)
|
|
52
|
-
notify_listeners(STARTED, result)
|
|
53
|
-
|
|
54
|
-
@suite.run(result) do |channel, value|
|
|
55
|
-
notify_listeners(channel, value)
|
|
56
|
-
end
|
|
57
|
-
ensure
|
|
58
|
-
elapsed_time = Time.now - start_time
|
|
59
|
-
result.remove_listener(TestResult::FAULT, fault_listener)
|
|
60
|
-
result.remove_listener(TestResult::CHANGED, changed_listener)
|
|
61
|
-
result.remove_listener(TestResult::FINISHED, finished_listener)
|
|
62
|
-
result.remove_listener(TestResult::PASS_ASSERTION,
|
|
63
|
-
pass_assertion_listener)
|
|
64
|
-
notify_listeners(FINISHED, elapsed_time)
|
|
65
|
-
end
|
|
66
|
-
|
|
67
|
-
result
|
|
68
|
-
end
|
|
69
|
-
|
|
70
|
-
private
|
|
71
|
-
# A factory method to create the result the mediator
|
|
72
|
-
# should run with. Can be overridden by subclasses if
|
|
73
|
-
# one wants to use a different result.
|
|
74
|
-
def create_result
|
|
75
|
-
TestResult.new
|
|
76
|
-
end
|
|
77
|
-
|
|
78
|
-
def measure_time
|
|
79
|
-
begin_time = Time.now
|
|
80
|
-
yield
|
|
81
|
-
Time.now - begin_time
|
|
82
|
-
end
|
|
83
|
-
end
|
|
84
|
-
end
|
|
85
|
-
end
|
|
86
|
-
end
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
#--
|
|
2
|
-
#
|
|
3
|
-
# Author:: Nathaniel Talbott.
|
|
4
|
-
# Copyright:: Copyright (c) 2000-2002 Nathaniel Talbott. All rights reserved.
|
|
5
|
-
# License:: Ruby license.
|
|
6
|
-
|
|
7
|
-
module Test
|
|
8
|
-
module Unit
|
|
9
|
-
module UI
|
|
10
|
-
|
|
11
|
-
# Provides some utilities common to most, if not all,
|
|
12
|
-
# TestRunners.
|
|
13
|
-
#
|
|
14
|
-
#--
|
|
15
|
-
#
|
|
16
|
-
# Perhaps there ought to be a TestRunner superclass? There
|
|
17
|
-
# seems to be a decent amount of shared code between test
|
|
18
|
-
# runners.
|
|
19
|
-
|
|
20
|
-
module TestRunnerUtilities
|
|
21
|
-
|
|
22
|
-
# Creates a new TestRunner and runs the suite.
|
|
23
|
-
def run(suite, options={})
|
|
24
|
-
return new(suite, options).start
|
|
25
|
-
end
|
|
26
|
-
|
|
27
|
-
# Takes care of the ARGV parsing and suite
|
|
28
|
-
# determination necessary for running one of the
|
|
29
|
-
# TestRunners from the command line.
|
|
30
|
-
def start_command_line_test
|
|
31
|
-
if ARGV.empty?
|
|
32
|
-
puts "You should supply the name of a test suite file to the runner"
|
|
33
|
-
exit
|
|
34
|
-
end
|
|
35
|
-
require ARGV[0].gsub(/.+::/, '')
|
|
36
|
-
new(eval(ARGV[0])).start
|
|
37
|
-
end
|
|
38
|
-
end
|
|
39
|
-
end
|
|
40
|
-
end
|
|
41
|
-
end
|
|
@@ -1,224 +0,0 @@
|
|
|
1
|
-
#--
|
|
2
|
-
#
|
|
3
|
-
# Author:: Kouhei Sutou
|
|
4
|
-
# Copyright::
|
|
5
|
-
# * Copyright (c) 2011 Kouhei Sutou <kou@clear-code.com>
|
|
6
|
-
# License:: Ruby license.
|
|
7
|
-
|
|
8
|
-
require 'erb'
|
|
9
|
-
require 'time'
|
|
10
|
-
require 'test/unit/ui/testrunner'
|
|
11
|
-
require 'test/unit/ui/testrunnermediator'
|
|
12
|
-
|
|
13
|
-
module Test
|
|
14
|
-
module Unit
|
|
15
|
-
module UI
|
|
16
|
-
module XML
|
|
17
|
-
|
|
18
|
-
# Runs a Test::Unit::TestSuite and outputs XML.
|
|
19
|
-
class TestRunner < UI::TestRunner
|
|
20
|
-
include ERB::Util
|
|
21
|
-
|
|
22
|
-
# Creates a new TestRunner for running the passed
|
|
23
|
-
# suite. :output option specifies where runner
|
|
24
|
-
# output should go to; defaults to STDOUT.
|
|
25
|
-
def initialize(suite, options={})
|
|
26
|
-
super
|
|
27
|
-
@output = @options[:output] || STDOUT
|
|
28
|
-
if @options[:output_file_descriptor]
|
|
29
|
-
@output = IO.new(@options[:output_file_descriptor], "w")
|
|
30
|
-
end
|
|
31
|
-
@already_outputted = false
|
|
32
|
-
@indent = 0
|
|
33
|
-
@top_level = true
|
|
34
|
-
@current_test = nil
|
|
35
|
-
@current_test_suite = nil
|
|
36
|
-
@already_outputted = false
|
|
37
|
-
end
|
|
38
|
-
|
|
39
|
-
private
|
|
40
|
-
def attach_to_mediator
|
|
41
|
-
@mediator.add_listener(TestResult::PASS_ASSERTION,
|
|
42
|
-
&method(:result_pass_assertion))
|
|
43
|
-
@mediator.add_listener(TestResult::FAULT,
|
|
44
|
-
&method(:result_fault))
|
|
45
|
-
@mediator.add_listener(TestRunnerMediator::STARTED,
|
|
46
|
-
&method(:started))
|
|
47
|
-
@mediator.add_listener(TestRunnerMediator::FINISHED,
|
|
48
|
-
&method(:finished))
|
|
49
|
-
@mediator.add_listener(TestCase::STARTED_OBJECT,
|
|
50
|
-
&method(:test_started))
|
|
51
|
-
@mediator.add_listener(TestCase::FINISHED_OBJECT,
|
|
52
|
-
&method(:test_finished))
|
|
53
|
-
@mediator.add_listener(TestSuite::STARTED_OBJECT,
|
|
54
|
-
&method(:test_suite_started))
|
|
55
|
-
@mediator.add_listener(TestSuite::FINISHED_OBJECT,
|
|
56
|
-
&method(:test_suite_finished))
|
|
57
|
-
end
|
|
58
|
-
|
|
59
|
-
def result_pass_assertion(result)
|
|
60
|
-
open_tag("pass-assertion") do
|
|
61
|
-
output_test(@current_test)
|
|
62
|
-
end
|
|
63
|
-
end
|
|
64
|
-
|
|
65
|
-
def result_fault(fault)
|
|
66
|
-
open_tag("test-result") do
|
|
67
|
-
open_tag("result") do
|
|
68
|
-
output_test_suite(@current_test_suite)
|
|
69
|
-
output_test(@current_test)
|
|
70
|
-
open_tag("backtrace") do
|
|
71
|
-
fault.location.each do |entry|
|
|
72
|
-
file, line, info = entry.split(/:/, 3)
|
|
73
|
-
open_tag("entry") do
|
|
74
|
-
add_content("file", file)
|
|
75
|
-
add_content("line", line)
|
|
76
|
-
add_content("info", info)
|
|
77
|
-
end
|
|
78
|
-
end
|
|
79
|
-
end
|
|
80
|
-
if fault.respond_to?(:expected)
|
|
81
|
-
add_content("expected", fault.expected)
|
|
82
|
-
end
|
|
83
|
-
if fault.respond_to?(:actual)
|
|
84
|
-
add_content("actual", fault.actual)
|
|
85
|
-
end
|
|
86
|
-
add_content("detail", fault.message)
|
|
87
|
-
add_content("status", fault.label.downcase)
|
|
88
|
-
end
|
|
89
|
-
end
|
|
90
|
-
@already_outputted = true if fault.critical?
|
|
91
|
-
end
|
|
92
|
-
|
|
93
|
-
def started(result)
|
|
94
|
-
@result = result
|
|
95
|
-
output_started
|
|
96
|
-
end
|
|
97
|
-
|
|
98
|
-
def output_started
|
|
99
|
-
open_tag("stream")
|
|
100
|
-
end
|
|
101
|
-
|
|
102
|
-
def finished(elapsed_time)
|
|
103
|
-
add_content("success", @result.passed?)
|
|
104
|
-
close_tag("stream")
|
|
105
|
-
end
|
|
106
|
-
|
|
107
|
-
def test_started(test)
|
|
108
|
-
@already_outputted = false
|
|
109
|
-
@current_test = test
|
|
110
|
-
open_tag("start-test") do
|
|
111
|
-
output_test(test)
|
|
112
|
-
end
|
|
113
|
-
end
|
|
114
|
-
|
|
115
|
-
def test_finished(test)
|
|
116
|
-
unless @already_outputted
|
|
117
|
-
open_tag("test-result") do
|
|
118
|
-
output_test(test)
|
|
119
|
-
open_tag("result") do
|
|
120
|
-
output_test_suite(@current_test_suite)
|
|
121
|
-
output_test(test)
|
|
122
|
-
add_content("status", "success")
|
|
123
|
-
end
|
|
124
|
-
end
|
|
125
|
-
end
|
|
126
|
-
|
|
127
|
-
open_tag("complete-test") do
|
|
128
|
-
output_test(test)
|
|
129
|
-
add_content("success", test.passed?)
|
|
130
|
-
end
|
|
131
|
-
@current_test = nil
|
|
132
|
-
end
|
|
133
|
-
|
|
134
|
-
def test_suite_started(suite)
|
|
135
|
-
@current_test_suite = suite
|
|
136
|
-
if suite.test_case.nil?
|
|
137
|
-
open_tag("ready-test-suite") do
|
|
138
|
-
add_content("n-tests", suite.size)
|
|
139
|
-
end
|
|
140
|
-
open_tag("start-test-suite") do
|
|
141
|
-
output_test_suite(suite)
|
|
142
|
-
end
|
|
143
|
-
else
|
|
144
|
-
open_tag("ready-test-case") do
|
|
145
|
-
output_test_suite(suite)
|
|
146
|
-
add_content("n-tests", suite.size)
|
|
147
|
-
end
|
|
148
|
-
open_tag("start-test-case") do
|
|
149
|
-
output_test_suite(suite)
|
|
150
|
-
end
|
|
151
|
-
end
|
|
152
|
-
end
|
|
153
|
-
|
|
154
|
-
def test_suite_finished(suite)
|
|
155
|
-
if suite.test_case.nil?
|
|
156
|
-
open_tag("complete-test-suite") do
|
|
157
|
-
output_test_suite(suite)
|
|
158
|
-
add_content("success", suite.passed?)
|
|
159
|
-
end
|
|
160
|
-
else
|
|
161
|
-
open_tag("complete-test-case") do
|
|
162
|
-
output_test_suite(suite)
|
|
163
|
-
add_content("success", suite.passed?)
|
|
164
|
-
end
|
|
165
|
-
end
|
|
166
|
-
@current_test_suite = nil
|
|
167
|
-
end
|
|
168
|
-
|
|
169
|
-
def indent
|
|
170
|
-
" " * @indent
|
|
171
|
-
end
|
|
172
|
-
|
|
173
|
-
def open_tag(name)
|
|
174
|
-
@output.puts("#{indent}<#{name}>")
|
|
175
|
-
@indent += 2
|
|
176
|
-
if block_given?
|
|
177
|
-
yield
|
|
178
|
-
close_tag(name)
|
|
179
|
-
end
|
|
180
|
-
end
|
|
181
|
-
|
|
182
|
-
def add_content(name, content)
|
|
183
|
-
return if content.nil?
|
|
184
|
-
case content
|
|
185
|
-
when Time
|
|
186
|
-
content = content.iso8601
|
|
187
|
-
end
|
|
188
|
-
@output.puts("#{indent}<#{name}>#{h(content)}</#{name}>")
|
|
189
|
-
end
|
|
190
|
-
|
|
191
|
-
def close_tag(name)
|
|
192
|
-
@indent -= 2
|
|
193
|
-
@output.puts("#{indent}</#{name}>")
|
|
194
|
-
end
|
|
195
|
-
|
|
196
|
-
def output_test(test)
|
|
197
|
-
open_tag("test") do
|
|
198
|
-
add_content("name", test.method_name)
|
|
199
|
-
add_content("start-time", test.start_time)
|
|
200
|
-
add_content("elapsed", test.elapsed_time)
|
|
201
|
-
end
|
|
202
|
-
end
|
|
203
|
-
|
|
204
|
-
def output_test_suite(test_suite)
|
|
205
|
-
test_case = test_suite.test_case
|
|
206
|
-
if test_case.nil?
|
|
207
|
-
open_tag("test-suite") do
|
|
208
|
-
add_content("name", test_suite.name)
|
|
209
|
-
add_content("start-time", test_suite.start_time)
|
|
210
|
-
add_content("elapsed", test_suite.elapsed_time)
|
|
211
|
-
end
|
|
212
|
-
else
|
|
213
|
-
open_tag("test-case") do
|
|
214
|
-
add_content("name", test_suite.name)
|
|
215
|
-
add_content("start-time", test_suite.start_time)
|
|
216
|
-
add_content("elapsed", test_suite.elapsed_time)
|
|
217
|
-
end
|
|
218
|
-
end
|
|
219
|
-
end
|
|
220
|
-
end
|
|
221
|
-
end
|
|
222
|
-
end
|
|
223
|
-
end
|
|
224
|
-
end
|