rroonga 1.0.1 → 1.0.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (135) hide show
  1. data/NEWS.ja.rdoc +46 -0
  2. data/NEWS.rdoc +46 -0
  3. data/README.ja.rdoc +2 -2
  4. data/README.rdoc +2 -3
  5. data/Rakefile +148 -11
  6. data/example/bookmark.rb +94 -91
  7. data/ext/groonga/extconf.rb +25 -25
  8. data/ext/groonga/groonga.def +2 -0
  9. data/ext/groonga/mkmf.log +7 -7
  10. data/ext/groonga/rb-grn-column.c +66 -0
  11. data/ext/groonga/rb-grn-context.c +92 -5
  12. data/ext/groonga/rb-grn-database.c +24 -1
  13. data/ext/groonga/rb-grn-exception.c +15 -0
  14. data/ext/groonga/rb-grn-hash.c +2 -2
  15. data/ext/groonga/rb-grn-index-column.c +8 -4
  16. data/ext/groonga/rb-grn-object.c +4 -2
  17. data/ext/groonga/rb-grn-patricia-trie.c +2 -2
  18. data/ext/groonga/rb-grn-snippet.c +1 -0
  19. data/ext/groonga/rb-grn-table-key-support.c +22 -19
  20. data/ext/groonga/rb-grn-table.c +63 -5
  21. data/ext/groonga/rb-grn.h +1 -1
  22. data/ext/groonga/rb-groonga.c +1 -0
  23. data/extconf.rb +1 -1
  24. data/html/developer.html +8 -2
  25. data/html/favicon.ico +0 -0
  26. data/html/favicon.svg +591 -0
  27. data/html/index.html +71 -8
  28. data/html/logo.svg +612 -0
  29. data/html/ranguba.css +92 -7
  30. data/html/readme.svg +256 -0
  31. data/lib/groonga/expression-builder.rb +8 -4
  32. data/lib/groonga/record.rb +77 -7
  33. data/lib/groonga/schema.rb +429 -100
  34. data/rroonga-build.rb +1 -1
  35. data/test/run-test.rb +1 -1
  36. data/test/test-array.rb +4 -0
  37. data/test/test-context.rb +8 -0
  38. data/test/test-database.rb +8 -1
  39. data/test/test-expression-builder.rb +14 -0
  40. data/test/test-fix-size-column.rb +4 -0
  41. data/test/test-hash.rb +10 -4
  42. data/test/test-index-column.rb +11 -0
  43. data/test/test-patricia-trie.rb +7 -1
  44. data/test/test-record.rb +14 -0
  45. data/test/test-remote.rb +3 -2
  46. data/test/test-schema-create-table.rb +32 -2
  47. data/test/test-schema.rb +108 -11
  48. data/test/test-table-select-normalize.rb +7 -3
  49. data/test/test-table-select.rb +12 -0
  50. data/test/test-table.rb +7 -0
  51. data/test/test-variable-size-column.rb +4 -0
  52. data/test-unit/Rakefile +40 -0
  53. data/test-unit/TODO +5 -0
  54. data/test-unit/bin/testrb +5 -0
  55. data/test-unit/html/classic.html +15 -0
  56. data/test-unit/html/index.html +25 -0
  57. data/test-unit/html/index.html.ja +27 -0
  58. data/test-unit/lib/test/unit/assertionfailederror.rb +25 -0
  59. data/test-unit/lib/test/unit/assertions.rb +1230 -0
  60. data/test-unit/lib/test/unit/attribute.rb +125 -0
  61. data/test-unit/lib/test/unit/autorunner.rb +360 -0
  62. data/test-unit/lib/test/unit/collector/descendant.rb +23 -0
  63. data/test-unit/lib/test/unit/collector/dir.rb +108 -0
  64. data/test-unit/lib/test/unit/collector/load.rb +144 -0
  65. data/test-unit/lib/test/unit/collector/objectspace.rb +34 -0
  66. data/test-unit/lib/test/unit/collector.rb +36 -0
  67. data/test-unit/lib/test/unit/color-scheme.rb +102 -0
  68. data/test-unit/lib/test/unit/color.rb +96 -0
  69. data/test-unit/lib/test/unit/diff.rb +724 -0
  70. data/test-unit/lib/test/unit/error.rb +130 -0
  71. data/test-unit/lib/test/unit/exceptionhandler.rb +39 -0
  72. data/test-unit/lib/test/unit/failure.rb +136 -0
  73. data/test-unit/lib/test/unit/fixture.rb +176 -0
  74. data/test-unit/lib/test/unit/notification.rb +129 -0
  75. data/test-unit/lib/test/unit/omission.rb +191 -0
  76. data/test-unit/lib/test/unit/pending.rb +150 -0
  77. data/test-unit/lib/test/unit/priority.rb +180 -0
  78. data/test-unit/lib/test/unit/runner/console.rb +52 -0
  79. data/test-unit/lib/test/unit/runner/emacs.rb +8 -0
  80. data/test-unit/lib/test/unit/runner/tap.rb +8 -0
  81. data/test-unit/lib/test/unit/testcase.rb +476 -0
  82. data/test-unit/lib/test/unit/testresult.rb +89 -0
  83. data/test-unit/lib/test/unit/testsuite.rb +110 -0
  84. data/test-unit/lib/test/unit/ui/console/outputlevel.rb +14 -0
  85. data/test-unit/lib/test/unit/ui/console/testrunner.rb +466 -0
  86. data/test-unit/lib/test/unit/ui/emacs/testrunner.rb +63 -0
  87. data/test-unit/lib/test/unit/ui/tap/testrunner.rb +92 -0
  88. data/test-unit/lib/test/unit/ui/testrunner.rb +28 -0
  89. data/test-unit/lib/test/unit/ui/testrunnermediator.rb +77 -0
  90. data/test-unit/lib/test/unit/ui/testrunnerutilities.rb +41 -0
  91. data/test-unit/lib/test/unit/util/backtracefilter.rb +41 -0
  92. data/test-unit/lib/test/unit/util/method-owner-finder.rb +28 -0
  93. data/test-unit/lib/test/unit/util/observable.rb +90 -0
  94. data/test-unit/lib/test/unit/util/procwrapper.rb +48 -0
  95. data/test-unit/lib/test/unit/version.rb +7 -0
  96. data/test-unit/lib/test/unit.rb +323 -0
  97. data/test-unit/sample/adder.rb +13 -0
  98. data/test-unit/sample/subtracter.rb +12 -0
  99. data/test-unit/sample/test_adder.rb +20 -0
  100. data/test-unit/sample/test_subtracter.rb +20 -0
  101. data/test-unit/sample/test_user.rb +23 -0
  102. data/test-unit/test/collector/test-descendant.rb +133 -0
  103. data/test-unit/test/collector/test-load.rb +442 -0
  104. data/test-unit/test/collector/test_dir.rb +406 -0
  105. data/test-unit/test/collector/test_objectspace.rb +100 -0
  106. data/test-unit/test/run-test.rb +15 -0
  107. data/test-unit/test/test-attribute.rb +86 -0
  108. data/test-unit/test/test-color-scheme.rb +67 -0
  109. data/test-unit/test/test-color.rb +47 -0
  110. data/test-unit/test/test-diff.rb +518 -0
  111. data/test-unit/test/test-emacs-runner.rb +60 -0
  112. data/test-unit/test/test-fixture.rb +287 -0
  113. data/test-unit/test/test-notification.rb +33 -0
  114. data/test-unit/test/test-omission.rb +81 -0
  115. data/test-unit/test/test-pending.rb +70 -0
  116. data/test-unit/test/test-priority.rb +119 -0
  117. data/test-unit/test/test-testcase.rb +544 -0
  118. data/test-unit/test/test_assertions.rb +1151 -0
  119. data/test-unit/test/test_error.rb +26 -0
  120. data/test-unit/test/test_failure.rb +33 -0
  121. data/test-unit/test/test_testresult.rb +113 -0
  122. data/test-unit/test/test_testsuite.rb +129 -0
  123. data/test-unit/test/testunit-test-util.rb +14 -0
  124. data/test-unit/test/ui/test_testrunmediator.rb +20 -0
  125. data/test-unit/test/util/test-method-owner-finder.rb +38 -0
  126. data/test-unit/test/util/test_backtracefilter.rb +41 -0
  127. data/test-unit/test/util/test_observable.rb +102 -0
  128. data/test-unit/test/util/test_procwrapper.rb +36 -0
  129. data/text/{TUTORIAL.ja.rdoc → tutorial.ja.rdoc} +165 -126
  130. metadata +106 -16
  131. data/html/favicon.xcf +0 -0
  132. data/html/logo.xcf +0 -0
  133. data/license/GPL +0 -340
  134. data/license/RUBY +0 -59
  135. data/pkg-config.rb +0 -333
@@ -0,0 +1,130 @@
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/util/backtracefilter'
8
+
9
+ module Test
10
+ module Unit
11
+
12
+ # Encapsulates an error in a test. Created by
13
+ # Test::Unit::TestCase when it rescues an exception thrown
14
+ # during the processing of a test.
15
+ class Error
16
+ include Util::BacktraceFilter
17
+
18
+ attr_reader(:test_name, :exception)
19
+
20
+ SINGLE_CHARACTER = 'E'
21
+ LABEL = "Error"
22
+
23
+ # Creates a new Error with the given test_name and
24
+ # exception.
25
+ def initialize(test_name, exception)
26
+ @test_name = test_name
27
+ @exception = exception
28
+ end
29
+
30
+ # Returns a single character representation of an error.
31
+ def single_character_display
32
+ SINGLE_CHARACTER
33
+ end
34
+
35
+ def label
36
+ LABEL
37
+ end
38
+
39
+ # Returns the message associated with the error.
40
+ def message
41
+ "#{@exception.class.name}: #{@exception.message}"
42
+ end
43
+
44
+ # Returns a brief version of the error description.
45
+ def short_display
46
+ "#@test_name: #{message.split("\n")[0]}"
47
+ end
48
+
49
+ # Returns a verbose version of the error description.
50
+ def long_display
51
+ backtrace_display = backtrace.join("\n ")
52
+ "#{label}:\n#@test_name:\n#{message}\n #{backtrace_display}"
53
+ end
54
+
55
+ def backtrace
56
+ filter_backtrace(@exception.backtrace)
57
+ end
58
+
59
+ # Overridden to return long_display.
60
+ def to_s
61
+ long_display
62
+ end
63
+
64
+ def critical?
65
+ true
66
+ end
67
+ end
68
+
69
+ module ErrorHandler
70
+ class << self
71
+ def included(base)
72
+ base.exception_handler(:handle_all_exception)
73
+ end
74
+ end
75
+
76
+ NOT_PASS_THROUGH_EXCEPTIONS = []
77
+ PASS_THROUGH_EXCEPTIONS = [NoMemoryError, SignalException, Interrupt,
78
+ SystemExit]
79
+ private
80
+ def handle_all_exception(exception)
81
+ case exception
82
+ when *NOT_PASS_THROUGH_EXCEPTIONS
83
+ when *PASS_THROUGH_EXCEPTIONS
84
+ return false
85
+ end
86
+
87
+ problem_occurred
88
+ add_error(exception)
89
+ true
90
+ end
91
+
92
+ def add_error(exception)
93
+ current_result.add_error(Error.new(name, exception))
94
+ end
95
+ end
96
+
97
+ module TestResultErrorSupport
98
+ attr_reader :errors
99
+
100
+ # Records a Test::Unit::Error.
101
+ def add_error(error)
102
+ @errors << error
103
+ notify_fault(error)
104
+ notify_changed
105
+ end
106
+
107
+ # Returns the number of errors this TestResult has
108
+ # recorded.
109
+ def error_count
110
+ @errors.size
111
+ end
112
+
113
+ def error_occurred?
114
+ not @errors.empty?
115
+ end
116
+
117
+ private
118
+ def initialize_containers
119
+ super
120
+ @errors = []
121
+ @summary_generators << :error_summary
122
+ @problem_checkers << :error_occurred?
123
+ end
124
+
125
+ def error_summary
126
+ "#{error_count} errors"
127
+ end
128
+ end
129
+ end
130
+ end
@@ -0,0 +1,39 @@
1
+ module Test
2
+ module Unit
3
+ module ExceptionHandler
4
+ @@exception_handlers = []
5
+ class << self
6
+ def exception_handlers
7
+ @@exception_handlers
8
+ end
9
+
10
+ def included(base)
11
+ base.extend(ClassMethods)
12
+
13
+ observer = Proc.new do |test_case, _, _, value, method_name|
14
+ if value
15
+ @@exception_handlers.unshift(method_name)
16
+ else
17
+ @@exception_handlers -= [method_name]
18
+ end
19
+ end
20
+ base.register_attribute_observer(:exception_handler, &observer)
21
+ end
22
+ end
23
+
24
+ module ClassMethods
25
+ def exception_handlers
26
+ ExceptionHandler.exception_handlers
27
+ end
28
+
29
+ def exception_handler(*method_names)
30
+ attribute(:exception_handler, true, *method_names)
31
+ end
32
+
33
+ def unregister_exception_handler(*method_names)
34
+ attribute(:exception_handler, false, *method_names)
35
+ end
36
+ end
37
+ end
38
+ end
39
+ end
@@ -0,0 +1,136 @@
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
+
10
+ # Encapsulates a test failure. Created by Test::Unit::TestCase
11
+ # when an assertion fails.
12
+ class Failure
13
+ attr_reader :test_name, :location, :message
14
+ attr_reader :expected, :actual, :user_message
15
+ attr_reader :inspected_expected, :inspected_actual
16
+
17
+ SINGLE_CHARACTER = 'F'
18
+ LABEL = "Failure"
19
+
20
+ # Creates a new Failure with the given location and
21
+ # message.
22
+ def initialize(test_name, location, message, options={})
23
+ @test_name = test_name
24
+ @location = location
25
+ @message = message
26
+ @expected = options[:expected]
27
+ @actual = options[:actual]
28
+ @inspected_expected = options[:inspected_expected]
29
+ @inspected_actual = options[:inspected_actual]
30
+ @user_message = options[:user_message]
31
+ end
32
+
33
+ # Returns a single character representation of a failure.
34
+ def single_character_display
35
+ SINGLE_CHARACTER
36
+ end
37
+
38
+ def label
39
+ LABEL
40
+ end
41
+
42
+ # Returns a brief version of the error description.
43
+ def short_display
44
+ "#@test_name: #{@message.split("\n")[0]}"
45
+ end
46
+
47
+ # Returns a verbose version of the error description.
48
+ def long_display
49
+ if location.size == 1
50
+ location_display = location[0].sub(/\A(.+:\d+).*/, ' [\\1]')
51
+ else
52
+ location_display = "\n [#{location.join("\n ")}]"
53
+ end
54
+ "#{label}:\n#@test_name#{location_display}:\n#@message"
55
+ end
56
+
57
+ # Overridden to return long_display.
58
+ def to_s
59
+ long_display
60
+ end
61
+
62
+ def critical?
63
+ true
64
+ end
65
+
66
+ def diff
67
+ @diff ||= compute_diff
68
+ end
69
+
70
+ private
71
+ def compute_diff
72
+ Assertions::AssertionMessage.delayed_diff(@expected, @actual).inspect
73
+ end
74
+ end
75
+
76
+ module FailureHandler
77
+ class << self
78
+ def included(base)
79
+ base.exception_handler(:handle_assertion_failed_error)
80
+ end
81
+ end
82
+
83
+ private
84
+ def handle_assertion_failed_error(exception)
85
+ return false unless exception.is_a?(AssertionFailedError)
86
+ problem_occurred
87
+ add_failure(exception.message, exception.backtrace,
88
+ :expected => exception.expected,
89
+ :actual => exception.actual,
90
+ :inspected_expected => exception.inspected_expected,
91
+ :inspected_actual => exception.inspected_actual,
92
+ :user_message => exception.user_message)
93
+ true
94
+ end
95
+
96
+ def add_failure(message, backtrace, options={})
97
+ failure = Failure.new(name, filter_backtrace(backtrace), message,
98
+ options)
99
+ current_result.add_failure(failure)
100
+ end
101
+ end
102
+
103
+ module TestResultFailureSupport
104
+ attr_reader :failures
105
+
106
+ # Records a Test::Unit::Failure.
107
+ def add_failure(failure)
108
+ @failures << failure
109
+ notify_fault(failure)
110
+ notify_changed
111
+ end
112
+
113
+ # Returns the number of failures this TestResult has
114
+ # recorded.
115
+ def failure_count
116
+ @failures.size
117
+ end
118
+
119
+ def failure_occurred?
120
+ not @failures.empty?
121
+ end
122
+
123
+ private
124
+ def initialize_containers
125
+ super
126
+ @failures = []
127
+ @summary_generators << :failure_summary
128
+ @problem_checkers << :failure_occurred?
129
+ end
130
+
131
+ def failure_summary
132
+ "#{failure_count} failures"
133
+ end
134
+ end
135
+ end
136
+ end
@@ -0,0 +1,176 @@
1
+ module Test
2
+ module Unit
3
+ module Fixture
4
+ class << self
5
+ def included(base)
6
+ base.extend(ClassMethods)
7
+
8
+ [:setup, :teardown].each do |fixture|
9
+ observer = Proc.new do |test_case, _, _, value, method_name|
10
+ if value.nil?
11
+ test_case.send("unregister_#{fixture}_method", method_name)
12
+ else
13
+ test_case.send("register_#{fixture}_method", method_name,
14
+ value)
15
+ end
16
+ end
17
+ base.register_attribute_observer(fixture, &observer)
18
+ end
19
+ end
20
+ end
21
+
22
+ module ClassMethods
23
+ def setup(*method_names)
24
+ register_fixture(:setup, *method_names)
25
+ end
26
+
27
+ def unregister_setup(*method_names)
28
+ unregister_fixture(:setup, *method_names)
29
+ end
30
+
31
+ def teardown(*method_names)
32
+ register_fixture(:teardown, *method_names)
33
+ end
34
+
35
+ def unregister_teardown(*method_names)
36
+ unregister_fixture(:teardown, *method_names)
37
+ end
38
+
39
+ def register_setup_method(method_name, options)
40
+ register_fixture_method(:setup, method_name, options, :after, :append)
41
+ end
42
+
43
+ def unregister_setup_method(method_name)
44
+ unregister_fixture_method(:setup, method_name)
45
+ end
46
+
47
+ def register_teardown_method(method_name, options)
48
+ register_fixture_method(:teardown, method_name, options,
49
+ :before, :prepend)
50
+ end
51
+
52
+ def unregister_teardown_method(method_name)
53
+ unregister_fixture_method(:teardown, method_name)
54
+ end
55
+
56
+ def before_setup_methods
57
+ collect_fixture_methods(:setup, :before)
58
+ end
59
+
60
+ def after_setup_methods
61
+ collect_fixture_methods(:setup, :after)
62
+ end
63
+
64
+ def before_teardown_methods
65
+ collect_fixture_methods(:teardown, :before)
66
+ end
67
+
68
+ def after_teardown_methods
69
+ collect_fixture_methods(:teardown, :after)
70
+ end
71
+
72
+ private
73
+ def register_fixture(fixture, *method_names)
74
+ options = {}
75
+ options = method_names.pop if method_names.last.is_a?(Hash)
76
+ attribute(fixture, options, *method_names)
77
+ end
78
+
79
+ def unregister_fixture(fixture, *method_names)
80
+ attribute(fixture, nil, *method_names)
81
+ end
82
+
83
+ def valid_register_fixture_options?(options)
84
+ return true if options.empty?
85
+ return false if options.size > 1
86
+
87
+ key = options.keys.first
88
+ [:before, :after].include?(key) and
89
+ [:prepend, :append].include?(options[key])
90
+ end
91
+
92
+ def add_fixture_method_name(how, variable_name, method_name)
93
+ methods = instance_eval("#{variable_name} ||= []")
94
+
95
+ if how == :prepend
96
+ methods = [method_name] | methods
97
+ else
98
+ methods = methods | [method_name]
99
+ end
100
+ instance_variable_set(variable_name, methods)
101
+ end
102
+
103
+ def registered_methods_variable_name(fixture, order)
104
+ "@#{order}_#{fixture}_methods"
105
+ end
106
+
107
+ def unregistered_methods_variable_name(fixture)
108
+ "@unregistered_#{fixture}_methods"
109
+ end
110
+
111
+ def register_fixture_method(fixture, method_name, options,
112
+ default_order, default_how)
113
+ unless valid_register_fixture_options?(options)
114
+ message = "must be {:before => :prepend}, " +
115
+ "{:before => :append}, {:after => :prepend} or " +
116
+ "{:after => :append}: #{options.inspect}"
117
+ raise ArgumentError, message
118
+ end
119
+
120
+ if options.empty?
121
+ order, how = default_order, default_how
122
+ else
123
+ order, how = options.to_a.first
124
+ end
125
+ variable_name = registered_methods_variable_name(fixture, order)
126
+ add_fixture_method_name(how, variable_name, method_name)
127
+ end
128
+
129
+ def unregister_fixture_method(fixture, method_name)
130
+ variable_name = unregistered_methods_variable_name(fixture)
131
+ add_fixture_method_name(:append, variable_name, method_name)
132
+ end
133
+
134
+ def collect_fixture_methods(fixture, order)
135
+ methods_variable = registered_methods_variable_name(fixture, order)
136
+ unregistered_methods_variable =
137
+ unregistered_methods_variable_name(fixture)
138
+
139
+ base_index = ancestors.index(Fixture)
140
+ interested_ancestors = ancestors[0, base_index].reverse
141
+ interested_ancestors.inject([]) do |result, ancestor|
142
+ if ancestor.is_a?(Class)
143
+ ancestor.class_eval do
144
+ methods = instance_eval("#{methods_variable} ||= []")
145
+ unregistered_methods =
146
+ instance_eval("#{unregistered_methods_variable} ||= []")
147
+ (result | methods) - unregistered_methods
148
+ end
149
+ else
150
+ result
151
+ end
152
+ end
153
+ end
154
+ end
155
+
156
+ private
157
+ def run_fixture(fixture)
158
+ [
159
+ self.class.send("before_#{fixture}_methods"),
160
+ fixture,
161
+ self.class.send("after_#{fixture}_methods")
162
+ ].flatten.each do |method_name|
163
+ send(method_name) if respond_to?(method_name, true)
164
+ end
165
+ end
166
+
167
+ def run_setup
168
+ run_fixture(:setup)
169
+ end
170
+
171
+ def run_teardown
172
+ run_fixture(:teardown)
173
+ end
174
+ end
175
+ end
176
+ end
@@ -0,0 +1,129 @@
1
+ require 'test/unit/util/backtracefilter'
2
+
3
+ module Test
4
+ module Unit
5
+ class Notification
6
+ include Util::BacktraceFilter
7
+ attr_reader :test_name, :location, :message
8
+
9
+ SINGLE_CHARACTER = 'N'
10
+ LABEL = "Notification"
11
+
12
+ # Creates a new Notification with the given location and
13
+ # message.
14
+ def initialize(test_name, location, message)
15
+ @test_name = test_name
16
+ @location = location
17
+ @message = message
18
+ end
19
+
20
+ # Returns a single character representation of a notification.
21
+ def single_character_display
22
+ SINGLE_CHARACTER
23
+ end
24
+
25
+ def label
26
+ LABEL
27
+ end
28
+
29
+ # Returns a brief version of the error description.
30
+ def short_display
31
+ "#{@test_name}: #{@message.split("\n")[0]}"
32
+ end
33
+
34
+ # Returns a verbose version of the error description.
35
+ def long_display
36
+ backtrace = filter_backtrace(location).join("\n")
37
+ "#{label}: #{@message}\n#{@test_name}\n#{backtrace}"
38
+ end
39
+
40
+ # Overridden to return long_display.
41
+ def to_s
42
+ long_display
43
+ end
44
+
45
+ def critical?
46
+ false
47
+ end
48
+ end
49
+
50
+ class NotifiedError < StandardError
51
+ end
52
+
53
+
54
+ module TestCaseNotificationSupport
55
+ class << self
56
+ def included(base)
57
+ base.class_eval do
58
+ include NotificationHandler
59
+ end
60
+ end
61
+ end
62
+
63
+ # Notify some information.
64
+ #
65
+ # Example:
66
+ # def test_notification
67
+ # notify("I'm here!")
68
+ # # Reached here
69
+ # notify("Special!") if special_case?
70
+ # # Reached here too
71
+ # end
72
+ def notify(message, &block)
73
+ notification = Notification.new(name, filter_backtrace(caller), message)
74
+ add_notification(notification)
75
+ end
76
+
77
+ private
78
+ def add_notification(notification)
79
+ current_result.add_notification(notification)
80
+ end
81
+ end
82
+
83
+ module NotificationHandler
84
+ class << self
85
+ def included(base)
86
+ base.exception_handler(:handle_notified_error)
87
+ end
88
+ end
89
+
90
+ private
91
+ def handle_notified_error(exception)
92
+ return false unless exception.is_a?(NotifiedError)
93
+ notification = Notification.new(name,
94
+ filter_backtrace(exception.backtrace),
95
+ exception.message)
96
+ add_notification(notification)
97
+ true
98
+ end
99
+ end
100
+
101
+ module TestResultNotificationSupport
102
+ attr_reader :notifications
103
+
104
+ # Records a Test::Unit::Notification.
105
+ def add_notification(notification)
106
+ @notifications << notification
107
+ notify_fault(notification)
108
+ notify_changed
109
+ end
110
+
111
+ # Returns the number of notifications this TestResult has
112
+ # recorded.
113
+ def notification_count
114
+ @notifications.size
115
+ end
116
+
117
+ private
118
+ def initialize_containers
119
+ super
120
+ @notifications = []
121
+ @summary_generators << :notification_summary
122
+ end
123
+
124
+ def notification_summary
125
+ "#{notification_count} notifications"
126
+ end
127
+ end
128
+ end
129
+ end