dchelimsky-rspec 1.1.12 → 1.1.99.1
Sign up to get free protection for your applications and to get access to all the features.
- data/History.txt +35 -0
- data/License.txt +1 -1
- data/Manifest.txt +22 -73
- data/README.txt +2 -2
- data/Rakefile +32 -7
- data/TODO.txt +9 -4
- data/bin/spec +1 -1
- data/cucumber.yml +2 -0
- data/examples/failing/spec_helper.rb +1 -1
- data/examples/passing/filtered_formatter.rb +18 -0
- data/examples/passing/filtered_formatter_example.rb +31 -0
- data/examples/passing/spec_helper.rb +1 -1
- data/examples/ruby1.9.compatibility/access_to_constants_spec.rb +17 -18
- data/features/before_and_after_blocks/before_and_after_blocks.feature +4 -4
- data/features/example_groups/autogenerated_docstrings.feature +2 -2
- data/features/example_groups/example_group_with_should_methods.feature +1 -1
- data/features/example_groups/nested_groups.feature +1 -1
- data/features/interop/examples_and_tests_together.feature +1 -1
- data/features/interop/test_but_not_test_unit.feature +1 -1
- data/features/interop/test_case_with_should_methods.feature +1 -1
- data/features/mock_framework_integration/use_flexmock.feature +22 -4
- data/features/mock_framework_integration/use_mocha.feature +27 -0
- data/features/mock_framework_integration/use_rr.feature +27 -0
- data/features/step_definitions/running_rspec.rb +5 -3
- data/features/support/env.rb +1 -1
- data/features-pending/cli/conditional_exclusion.feature +39 -0
- data/lib/{adapters → spec/adapters}/mock_frameworks/flexmock.rb +1 -0
- data/lib/{adapters → spec/adapters}/mock_frameworks/mocha.rb +1 -0
- data/lib/{adapters → spec/adapters}/mock_frameworks/rr.rb +1 -0
- data/lib/{adapters → spec/adapters}/mock_frameworks/rspec.rb +0 -1
- data/lib/spec/autorun.rb +3 -0
- data/lib/spec/example/before_and_after_hooks.rb +5 -20
- data/lib/spec/example/example_description.rb +15 -0
- data/lib/spec/example/example_group.rb +0 -15
- data/lib/spec/example/example_group_factory.rb +34 -46
- data/lib/spec/example/example_group_hierarchy.rb +53 -0
- data/lib/spec/example/example_group_methods.rb +96 -211
- data/lib/spec/example/example_methods.rb +62 -81
- data/lib/spec/example/module_reopening_fix.rb +23 -1
- data/lib/spec/example/predicate_matchers.rb +47 -0
- data/lib/spec/example/subject.rb +91 -0
- data/lib/spec/example.rb +4 -0
- data/lib/spec/expectations/extensions.rb +0 -1
- data/lib/spec/expectations/handler.rb +6 -1
- data/lib/spec/expectations.rb +1 -1
- data/lib/spec/interop/test/unit/testcase.rb +5 -22
- data/lib/spec/interop/test.rb +1 -0
- data/lib/spec/matchers/be.rb +2 -7
- data/lib/spec/matchers/be_close.rb +20 -5
- data/lib/spec/matchers/change.rb +5 -3
- data/lib/spec/matchers/eql.rb +24 -6
- data/lib/spec/matchers/equal.rb +24 -6
- data/lib/spec/matchers/exist.rb +21 -5
- data/lib/spec/matchers/generated_descriptions.rb +2 -2
- data/lib/spec/matchers/has.rb +28 -11
- data/lib/spec/matchers/match.rb +25 -7
- data/lib/spec/matchers/match_array.rb +1 -1
- data/lib/spec/matchers/method_missing.rb +2 -2
- data/lib/spec/matchers/operator_matcher.rb +12 -5
- data/lib/spec/matchers/raise_error.rb +1 -1
- data/lib/spec/matchers/respond_to.rb +1 -1
- data/lib/spec/matchers/satisfy.rb +5 -5
- data/lib/spec/matchers/throw_symbol.rb +1 -3
- data/lib/spec/mocks/argument_expectation.rb +1 -1
- data/lib/spec/mocks/argument_matchers.rb +233 -0
- data/lib/spec/mocks/error_generator.rb +2 -6
- data/lib/spec/mocks/message_expectation.rb +3 -11
- data/lib/spec/mocks/mock.rb +1 -1
- data/lib/spec/mocks/proxy.rb +5 -1
- data/lib/spec/runner/configuration.rb +3 -3
- data/lib/spec/runner/drb_command_line.rb +2 -1
- data/lib/spec/runner/example_group_runner.rb +2 -1
- data/lib/spec/runner/formatter/base_text_formatter.rb +28 -17
- data/lib/spec/runner/formatter/failing_example_groups_formatter.rb +3 -5
- data/lib/spec/runner/formatter/html_formatter.rb +2 -3
- data/lib/spec/runner/formatter/nested_text_formatter.rb +7 -25
- data/lib/spec/runner/formatter/progress_bar_formatter.rb +1 -1
- data/lib/spec/runner/formatter/specdoc_formatter.rb +1 -7
- data/lib/spec/runner/heckle_runner_unsupported.rb +1 -1
- data/lib/spec/runner/option_parser.rb +16 -19
- data/lib/spec/runner/options.rb +28 -26
- data/lib/spec/runner/reporter.rb +8 -9
- data/lib/spec/runner.rb +6 -28
- data/lib/spec/test/unit.rb +10 -0
- data/lib/spec/version.rb +2 -2
- data/{features/support → resources}/helpers/cmdline.rb +2 -2
- data/resources/rake/verify_rcov.rake +1 -1
- data/resources/spec/example_group_with_should_methods.rb +1 -1
- data/resources/spec/simple_spec.rb +1 -1
- data/resources/test/spec_and_test_together.rb +2 -3
- data/resources/test/spec_including_test_but_not_unit.rb +1 -1
- data/resources/test/test_case_with_should_methods.rb +2 -3
- data/rspec.gemspec +5 -5
- data/spec/spec/dsl/main_spec.rb +3 -3
- data/spec/spec/example/example_group_class_definition_spec.rb +11 -14
- data/spec/spec/example/example_group_factory_spec.rb +31 -44
- data/spec/spec/example/example_group_methods_spec.rb +86 -52
- data/spec/spec/example/example_group_spec.rb +16 -75
- data/spec/spec/example/example_matcher_spec.rb +10 -10
- data/spec/spec/example/example_methods_spec.rb +101 -241
- data/spec/spec/example/nested_example_group_spec.rb +2 -2
- data/spec/spec/example/pending_module_spec.rb +1 -1
- data/spec/spec/example/shared_example_group_spec.rb +2 -2
- data/spec/spec/interop/test/unit/resources/spec_that_fails.rb +2 -2
- data/spec/spec/interop/test/unit/resources/spec_that_passes.rb +2 -2
- data/spec/spec/interop/test/unit/resources/spec_with_errors.rb +2 -2
- data/spec/spec/interop/test/unit/resources/spec_with_options_hash.rb +2 -2
- data/spec/spec/interop/test/unit/resources/test_case_that_fails.rb +2 -2
- data/spec/spec/interop/test/unit/resources/test_case_that_passes.rb +2 -2
- data/spec/spec/interop/test/unit/resources/test_case_with_errors.rb +2 -2
- data/spec/spec/interop/test/unit/resources/testsuite_adapter_spec_with_test_unit.rb +2 -2
- data/spec/spec/matchers/change_spec.rb +8 -0
- data/spec/spec/matchers/exist_spec.rb +8 -4
- data/spec/spec/matchers/handler_spec.rb +8 -1
- data/spec/spec/matchers/matcher_methods_spec.rb +1 -1
- data/spec/spec/mocks/{bug_report_496.rb → bug_report_496_spec.rb} +0 -0
- data/spec/spec/mocks/failing_argument_matchers_spec.rb +95 -0
- data/spec/spec/mocks/nil_expectation_warning_spec.rb +1 -1
- data/spec/spec/mocks/passing_argument_matchers_spec.rb +145 -0
- data/spec/spec/runner/configuration_spec.rb +12 -12
- data/spec/spec/runner/formatter/base_text_formatter_spec.rb +72 -1
- data/spec/spec/runner/formatter/failing_example_groups_formatter_spec.rb +8 -8
- data/spec/spec/runner/formatter/failing_examples_formatter_spec.rb +4 -4
- data/spec/spec/runner/formatter/html_formatted-1.8.6.html +8 -8
- data/spec/spec/runner/formatter/html_formatted-1.8.7.html +38 -26
- data/spec/spec/runner/formatter/html_formatted-1.9.1.html +61 -53
- data/spec/spec/runner/formatter/html_formatter_spec.rb +100 -48
- data/spec/spec/runner/formatter/nested_text_formatter_spec.rb +20 -34
- data/spec/spec/runner/formatter/profile_formatter_spec.rb +1 -1
- data/spec/spec/runner/formatter/progress_bar_formatter_spec.rb +8 -6
- data/spec/spec/runner/formatter/specdoc_formatter_spec.rb +6 -6
- data/spec/spec/runner/formatter/text_mate_formatted-1.8.6.html +20 -20
- data/spec/spec/runner/formatter/text_mate_formatted-1.8.7.html +38 -26
- data/spec/spec/runner/formatter/{spec_mate_formatter_spec.rb → text_mate_formatter_spec.rb} +10 -8
- data/spec/spec/runner/heckle_runner_spec.rb +1 -1
- data/spec/spec/runner/option_parser_spec.rb +15 -13
- data/spec/spec/runner/options_spec.rb +34 -0
- data/spec/spec/runner/reporter_spec.rb +65 -61
- data/spec/spec/runner/spec_drb.opts +1 -0
- data/spec/spec/runner_spec.rb +7 -5
- data/spec/spec_helper.rb +23 -0
- metadata +25 -76
- data/examples/passing/legacy_spec.rb +0 -11
- data/features/support/helpers/story_helper.rb +0 -13
- data/lib/spec/expectations/extensions/string_and_symbol.rb +0 -17
- data/resources/spec/spec_with_flexmock.rb +0 -19
- data/spec/spec/spec_spec.rb +0 -21
@@ -6,18 +6,18 @@ module Spec
|
|
6
6
|
@block = block
|
7
7
|
end
|
8
8
|
|
9
|
-
def matches?(
|
9
|
+
def matches?(actual, &block)
|
10
10
|
@block = block if block
|
11
|
-
@
|
12
|
-
@block.call(
|
11
|
+
@actual = actual
|
12
|
+
@block.call(actual)
|
13
13
|
end
|
14
14
|
|
15
15
|
def failure_message
|
16
|
-
"expected #{@
|
16
|
+
"expected #{@actual} to satisfy block"
|
17
17
|
end
|
18
18
|
|
19
19
|
def negative_failure_message
|
20
|
-
"expected #{@
|
20
|
+
"expected #{@actual} not to satisfy block"
|
21
21
|
end
|
22
22
|
end
|
23
23
|
|
@@ -35,9 +35,7 @@ module Spec
|
|
35
35
|
if @expected_arg.nil?
|
36
36
|
return @caught_symbol == @expected_symbol
|
37
37
|
else
|
38
|
-
|
39
|
-
# puts [@caught_arg, @expected_arg].inspect
|
40
|
-
return @caught_symbol == @expected_symbol && @caught_arg == @expected_arg
|
38
|
+
return (@caught_symbol == @expected_symbol) & (@caught_arg == @expected_arg)
|
41
39
|
end
|
42
40
|
end
|
43
41
|
end
|
@@ -0,0 +1,233 @@
|
|
1
|
+
module Spec
|
2
|
+
module Mocks
|
3
|
+
|
4
|
+
# ArgumentMatchers are messages that you can include in message
|
5
|
+
# expectations to match arguments against a broader check than simple
|
6
|
+
# equality.
|
7
|
+
#
|
8
|
+
# With the exception of any_args() and no_args(), the matchers
|
9
|
+
# are all positional - they match against the arg in the given position.
|
10
|
+
module ArgumentMatchers
|
11
|
+
|
12
|
+
class AnyArgsMatcher
|
13
|
+
def description
|
14
|
+
"any args"
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
class AnyArgMatcher
|
19
|
+
def initialize(ignore)
|
20
|
+
end
|
21
|
+
|
22
|
+
def ==(other)
|
23
|
+
true
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
class NoArgsMatcher
|
28
|
+
def description
|
29
|
+
"no args"
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
class RegexpMatcher
|
34
|
+
def initialize(regexp)
|
35
|
+
@regexp = regexp
|
36
|
+
end
|
37
|
+
|
38
|
+
def ==(value)
|
39
|
+
return value =~ @regexp unless value.is_a?(Regexp)
|
40
|
+
value == @regexp
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
class BooleanMatcher
|
45
|
+
def initialize(ignore)
|
46
|
+
end
|
47
|
+
|
48
|
+
def ==(value)
|
49
|
+
TrueClass === value || FalseClass === value
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
class HashIncludingMatcher
|
54
|
+
def initialize(expected)
|
55
|
+
@expected = expected
|
56
|
+
end
|
57
|
+
|
58
|
+
def ==(actual)
|
59
|
+
@expected.each do | key, value |
|
60
|
+
return false unless actual.has_key?(key) && value == actual[key]
|
61
|
+
end
|
62
|
+
true
|
63
|
+
rescue NoMethodError => ex
|
64
|
+
return false
|
65
|
+
end
|
66
|
+
|
67
|
+
def description
|
68
|
+
"hash_including(#{@expected.inspect.sub(/^\{/,"").sub(/\}$/,"")})"
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
class HashNotIncludingMatcher
|
73
|
+
def initialize(expected)
|
74
|
+
@expected = expected
|
75
|
+
end
|
76
|
+
|
77
|
+
def ==(actual)
|
78
|
+
@expected.each do | key, value |
|
79
|
+
return false if actual.has_key?(key) && value == actual[key]
|
80
|
+
end
|
81
|
+
true
|
82
|
+
rescue NoMethodError => ex
|
83
|
+
return false
|
84
|
+
end
|
85
|
+
|
86
|
+
def description
|
87
|
+
"hash_not_including(#{@expected.inspect.sub(/^\{/,"").sub(/\}$/,"")})"
|
88
|
+
end
|
89
|
+
end
|
90
|
+
|
91
|
+
class DuckTypeMatcher
|
92
|
+
def initialize(*methods_to_respond_to)
|
93
|
+
@methods_to_respond_to = methods_to_respond_to
|
94
|
+
end
|
95
|
+
|
96
|
+
def ==(value)
|
97
|
+
@methods_to_respond_to.all? { |sym| value.respond_to?(sym) }
|
98
|
+
end
|
99
|
+
end
|
100
|
+
|
101
|
+
class MatcherMatcher
|
102
|
+
def initialize(matcher)
|
103
|
+
@matcher = matcher
|
104
|
+
end
|
105
|
+
|
106
|
+
def ==(value)
|
107
|
+
@matcher.matches?(value)
|
108
|
+
end
|
109
|
+
end
|
110
|
+
|
111
|
+
class EqualityProxy
|
112
|
+
def initialize(given)
|
113
|
+
@given = given
|
114
|
+
end
|
115
|
+
|
116
|
+
def ==(expected)
|
117
|
+
@given == expected
|
118
|
+
end
|
119
|
+
end
|
120
|
+
|
121
|
+
class InstanceOf
|
122
|
+
def initialize(klass)
|
123
|
+
@klass = klass
|
124
|
+
end
|
125
|
+
|
126
|
+
def ==(actual)
|
127
|
+
actual.instance_of?(@klass)
|
128
|
+
end
|
129
|
+
end
|
130
|
+
|
131
|
+
class KindOf
|
132
|
+
def initialize(klass)
|
133
|
+
@klass = klass
|
134
|
+
end
|
135
|
+
|
136
|
+
def ==(actual)
|
137
|
+
actual.kind_of?(@klass)
|
138
|
+
end
|
139
|
+
end
|
140
|
+
|
141
|
+
# :call-seq:
|
142
|
+
# object.should_receive(:message).with(any_args())
|
143
|
+
#
|
144
|
+
# Passes if object receives :message with any args at all. This is
|
145
|
+
# really a more explicit variation of object.should_receive(:message)
|
146
|
+
def any_args
|
147
|
+
AnyArgsMatcher.new
|
148
|
+
end
|
149
|
+
|
150
|
+
# :call-seq:
|
151
|
+
# object.should_receive(:message).with(anything())
|
152
|
+
#
|
153
|
+
# Passes as long as there is an argument.
|
154
|
+
def anything
|
155
|
+
AnyArgMatcher.new(nil)
|
156
|
+
end
|
157
|
+
|
158
|
+
# :call-seq:
|
159
|
+
# object.should_receive(:message).with(no_args)
|
160
|
+
#
|
161
|
+
# Passes if no arguments are passed along with the message
|
162
|
+
def no_args
|
163
|
+
NoArgsMatcher.new
|
164
|
+
end
|
165
|
+
|
166
|
+
# :call-seq:
|
167
|
+
# object.should_receive(:message).with(duck_type(:hello))
|
168
|
+
# object.should_receive(:message).with(duck_type(:hello, :goodbye))
|
169
|
+
#
|
170
|
+
# Passes if the argument responds to the specified messages.
|
171
|
+
#
|
172
|
+
# == Examples
|
173
|
+
#
|
174
|
+
# array = []
|
175
|
+
# display = mock('display')
|
176
|
+
# display.should_receive(:present_names).with(duck_type(:length, :each))
|
177
|
+
# => passes
|
178
|
+
def duck_type(*args)
|
179
|
+
DuckTypeMatcher.new(*args)
|
180
|
+
end
|
181
|
+
|
182
|
+
# :call-seq:
|
183
|
+
# object.should_receive(:message).with(boolean())
|
184
|
+
#
|
185
|
+
# Passes if the argument is boolean.
|
186
|
+
def boolean
|
187
|
+
BooleanMatcher.new(nil)
|
188
|
+
end
|
189
|
+
|
190
|
+
# :call-seq:
|
191
|
+
# object.should_receive(:message).with(hash_including(:key => val))
|
192
|
+
# object.should_receive(:message).with(hash_including(:key))
|
193
|
+
# object.should_receive(:message).with(hash_including(:key, :key2 => val2))
|
194
|
+
# Passes if the argument is a hash that includes the specified key(s) or key/value
|
195
|
+
# pairs. If the hash includes other keys, it will still pass.
|
196
|
+
def hash_including(*args)
|
197
|
+
HashIncludingMatcher.new(anythingize_lonely_keys(*args))
|
198
|
+
end
|
199
|
+
|
200
|
+
# :call-seq:
|
201
|
+
# object.should_receive(:message).with(hash_not_including(:key => val))
|
202
|
+
# object.should_receive(:message).with(hash_not_including(:key))
|
203
|
+
# object.should_receive(:message).with(hash_not_including(:key, :key2 => :val2))
|
204
|
+
#
|
205
|
+
# Passes if the argument is a hash that doesn't include the specified key(s) or key/value
|
206
|
+
def hash_not_including(*args)
|
207
|
+
HashNotIncludingMatcher.new(anythingize_lonely_keys(*args))
|
208
|
+
end
|
209
|
+
|
210
|
+
# Passes if arg.instance_of?(klass)
|
211
|
+
def instance_of(klass)
|
212
|
+
InstanceOf.new(klass)
|
213
|
+
end
|
214
|
+
|
215
|
+
alias_method :an_instance_of, :instance_of
|
216
|
+
|
217
|
+
# Passes if arg.kind_of?(klass)
|
218
|
+
def kind_of(klass)
|
219
|
+
KindOf.new(klass)
|
220
|
+
end
|
221
|
+
|
222
|
+
alias_method :a_kind_of, :kind_of
|
223
|
+
|
224
|
+
private
|
225
|
+
|
226
|
+
def anythingize_lonely_keys(*args)
|
227
|
+
hash = args.last.class == Hash ? args.delete_at(-1) : {}
|
228
|
+
args.each { | arg | hash[arg] = anything }
|
229
|
+
hash
|
230
|
+
end
|
231
|
+
end
|
232
|
+
end
|
233
|
+
end
|
@@ -57,15 +57,11 @@ module Spec
|
|
57
57
|
end
|
58
58
|
|
59
59
|
def format_args(*args)
|
60
|
-
|
61
|
-
return "(any args)" if args == [:any_args]
|
62
|
-
"(" + arg_list(*args) + ")"
|
60
|
+
args.empty? ? "(no args)" : "(" + arg_list(*args) + ")"
|
63
61
|
end
|
64
62
|
|
65
63
|
def arg_list(*args)
|
66
|
-
args.collect
|
67
|
-
arg.respond_to?(:description) ? arg.description : arg.inspect
|
68
|
-
end.join(", ")
|
64
|
+
args.collect {|arg| arg.respond_to?(:description) ? arg.description : arg.inspect}.join(", ")
|
69
65
|
end
|
70
66
|
|
71
67
|
def count_message(count)
|
@@ -56,8 +56,6 @@ module Spec
|
|
56
56
|
@expected_received_count < values.size
|
57
57
|
end
|
58
58
|
@return_block = block_given? ? return_block : lambda { value }
|
59
|
-
# Ruby 1.9 - see where this is used below
|
60
|
-
@ignore_args = !block_given?
|
61
59
|
end
|
62
60
|
|
63
61
|
# :call-seq:
|
@@ -157,9 +155,7 @@ module Spec
|
|
157
155
|
end
|
158
156
|
|
159
157
|
def invoke_consecutive_return_block(args, block)
|
160
|
-
|
161
|
-
value = @return_block.call(*args)
|
162
|
-
|
158
|
+
value = invoke_return_block(args, block)
|
163
159
|
index = [@actual_received_count, value.size-1].min
|
164
160
|
value[index]
|
165
161
|
end
|
@@ -169,13 +165,9 @@ module Spec
|
|
169
165
|
# Ruby 1.9 - when we set @return_block to return values
|
170
166
|
# regardless of arguments, any arguments will result in
|
171
167
|
# a "wrong number of arguments" error
|
172
|
-
|
173
|
-
@return_block.call()
|
174
|
-
else
|
175
|
-
@return_block.call(*args)
|
176
|
-
end
|
168
|
+
@return_block.arity > 0 ? @return_block.call(*args) : @return_block.call()
|
177
169
|
end
|
178
|
-
|
170
|
+
|
179
171
|
def clone_args_to_yield(args)
|
180
172
|
@args_to_yield = args.clone
|
181
173
|
@args_to_yield_were_cloned = true
|
data/lib/spec/mocks/mock.rb
CHANGED
@@ -22,7 +22,7 @@ module Spec
|
|
22
22
|
end
|
23
23
|
|
24
24
|
def method_missing(sym, *args, &block)
|
25
|
-
__mock_proxy.
|
25
|
+
__mock_proxy.record_message_received(sym, args, block)
|
26
26
|
begin
|
27
27
|
return self if __mock_proxy.null_object?
|
28
28
|
super(sym, *args, &block)
|
data/lib/spec/mocks/proxy.rb
CHANGED
@@ -82,6 +82,10 @@ module Spec
|
|
82
82
|
def has_negative_expectation?(sym)
|
83
83
|
@expectations.detect {|expectation| expectation.negative_expectation_for?(sym)}
|
84
84
|
end
|
85
|
+
|
86
|
+
def record_message_received(sym, args, block)
|
87
|
+
@messages_received << [sym, args, block]
|
88
|
+
end
|
85
89
|
|
86
90
|
def message_received(sym, *args, &block)
|
87
91
|
expectation = find_matching_expectation(sym, *args)
|
@@ -118,7 +122,7 @@ module Spec
|
|
118
122
|
end
|
119
123
|
|
120
124
|
def warn_if_nil_class(sym)
|
121
|
-
if proxy_for_nil_class?
|
125
|
+
if proxy_for_nil_class? & @@warn_about_expectations_on_nil
|
122
126
|
Kernel.warn("An expectation of :#{sym} was set on nil. Called from #{caller[2]}. Use allow_message_expectations_on_nil to disable warnings.")
|
123
127
|
end
|
124
128
|
end
|
@@ -143,14 +143,14 @@ module Spec
|
|
143
143
|
[get_type_from_options(options)].flatten.each do |required_example_group|
|
144
144
|
required_example_group = required_example_group.to_sym if required_example_group
|
145
145
|
modules.each do |mod|
|
146
|
-
Spec::Example::ExampleGroupFactory
|
146
|
+
Spec::Example::ExampleGroupFactory[required_example_group].__send__(action, mod)
|
147
147
|
end
|
148
148
|
end
|
149
149
|
end
|
150
150
|
|
151
151
|
def add_callback(sym, *args, &proc)
|
152
152
|
scope, options = Spec::Example.scope_and_options(*args)
|
153
|
-
example_group = Spec::Example::ExampleGroupFactory
|
153
|
+
example_group = Spec::Example::ExampleGroupFactory[get_type_from_options(options)]
|
154
154
|
example_group.__send__(sym, scope, &proc)
|
155
155
|
end
|
156
156
|
|
@@ -159,7 +159,7 @@ module Spec
|
|
159
159
|
end
|
160
160
|
|
161
161
|
def mock_framework_path(framework_name)
|
162
|
-
File.expand_path(File.join(File.dirname(__FILE__), "
|
162
|
+
File.expand_path(File.join(File.dirname(__FILE__), "/../adapters/mock_frameworks/#{framework_name}"))
|
163
163
|
end
|
164
164
|
end
|
165
165
|
end
|
@@ -8,7 +8,8 @@ module Spec
|
|
8
8
|
# CommandLine - making it possible for clients to use both interchangeably.
|
9
9
|
def self.run(options)
|
10
10
|
begin
|
11
|
-
|
11
|
+
# See http://redmine.ruby-lang.org/issues/show/496 as to why we specify localhost:0
|
12
|
+
DRb.start_service("druby://localhost:0")
|
12
13
|
spec_server = DRbObject.new_with_uri("druby://127.0.0.1:8989")
|
13
14
|
spec_server.run(options.argv, options.error_stream, options.output_stream)
|
14
15
|
rescue DRb::DRbConnError => e
|
@@ -1,4 +1,5 @@
|
|
1
1
|
require 'spec/runner/formatter/base_formatter'
|
2
|
+
require 'fileutils'
|
2
3
|
|
3
4
|
module Spec
|
4
5
|
module Runner
|
@@ -23,27 +24,31 @@ module Spec
|
|
23
24
|
end
|
24
25
|
|
25
26
|
def example_pending(example, message, pending_caller)
|
26
|
-
@pending_examples << [example.
|
27
|
+
@pending_examples << ["#{@example_group.description} #{example.description}", message, pending_caller]
|
27
28
|
end
|
28
29
|
|
29
30
|
def dump_failure(counter, failure)
|
30
31
|
@output.puts
|
31
32
|
@output.puts "#{counter.to_s})"
|
32
|
-
@output.puts
|
33
|
+
@output.puts colorize_failure("#{failure.header}\n#{failure.exception.message}", failure)
|
33
34
|
@output.puts format_backtrace(failure.exception.backtrace)
|
34
35
|
@output.flush
|
35
36
|
end
|
36
37
|
|
37
|
-
def
|
38
|
-
|
39
|
-
red(s)
|
40
|
-
elsif(failure.pending_fixed?)
|
41
|
-
blue(s)
|
42
|
-
else
|
43
|
-
magenta(s)
|
44
|
-
end
|
38
|
+
def colorize_failure(message, failure)
|
39
|
+
failure.pending_fixed? ? blue(message) : red(message)
|
45
40
|
end
|
46
|
-
|
41
|
+
|
42
|
+
def colourise(message, failure)
|
43
|
+
Kernel.warn <<-NOTICE
|
44
|
+
DEPRECATED: BaseTextFormatter#colourise is deprecated and will be
|
45
|
+
removed from a future version of RSpec.
|
46
|
+
|
47
|
+
Please use colorize_failure instead.
|
48
|
+
NOTICE
|
49
|
+
colorize_failure(message, failure)
|
50
|
+
end
|
51
|
+
|
47
52
|
def dump_summary(duration, example_count, failure_count, pending_count)
|
48
53
|
return if dry_run?
|
49
54
|
@output.puts
|
@@ -78,9 +83,7 @@ module Spec
|
|
78
83
|
end
|
79
84
|
|
80
85
|
def close
|
81
|
-
if IO === @output
|
82
|
-
@output.close
|
83
|
-
end
|
86
|
+
@output.close if (IO === @output) & (@output != $stdout)
|
84
87
|
end
|
85
88
|
|
86
89
|
def format_backtrace(backtrace)
|
@@ -103,7 +106,7 @@ module Spec
|
|
103
106
|
end
|
104
107
|
|
105
108
|
def colour(text, colour_code)
|
106
|
-
return text unless colour?
|
109
|
+
return text unless ENV['RSPEC_COLOR'] || (colour? & output_to_tty?)
|
107
110
|
"#{colour_code}#{text}\e[0m"
|
108
111
|
end
|
109
112
|
|
@@ -117,10 +120,18 @@ module Spec
|
|
117
120
|
|
118
121
|
def green(text); colour(text, "\e[32m"); end
|
119
122
|
def red(text); colour(text, "\e[31m"); end
|
120
|
-
def magenta(text); colour(text, "\e[35m"); end
|
121
123
|
def yellow(text); colour(text, "\e[33m"); end
|
122
124
|
def blue(text); colour(text, "\e[34m"); end
|
123
|
-
|
125
|
+
|
126
|
+
def magenta(text)
|
127
|
+
Kernel.warn <<-NOTICE
|
128
|
+
DEPRECATED: BaseTextFormatter#magenta is deprecated and will be
|
129
|
+
removed from a future version of RSpec.
|
130
|
+
|
131
|
+
Please use red instead (it is red/green/refactor after all).
|
132
|
+
NOTICE
|
133
|
+
red(text)
|
134
|
+
end
|
124
135
|
end
|
125
136
|
end
|
126
137
|
end
|
@@ -6,21 +6,19 @@ module Spec
|
|
6
6
|
class FailingExampleGroupsFormatter < BaseTextFormatter
|
7
7
|
def example_failed(example, counter, failure)
|
8
8
|
if @example_group
|
9
|
-
|
10
|
-
description =~ /(.*) \(druby.*\)$/ ? $1 : description
|
11
|
-
end
|
12
|
-
@output.puts ::Spec::Example::ExampleGroupMethods.description_text(*description_parts)
|
9
|
+
@output.puts @example_group.filtered_description(/(.*) \(druby.*\)$/)
|
13
10
|
|
14
11
|
@output.flush
|
15
12
|
@example_group = nil
|
16
13
|
end
|
17
14
|
end
|
18
|
-
|
15
|
+
|
19
16
|
def dump_failure(counter, failure)
|
20
17
|
end
|
21
18
|
|
22
19
|
def dump_summary(duration, example_count, failure_count, pending_count)
|
23
20
|
end
|
21
|
+
|
24
22
|
end
|
25
23
|
end
|
26
24
|
end
|
@@ -38,7 +38,6 @@ module Spec
|
|
38
38
|
def add_example_group(example_group)
|
39
39
|
super
|
40
40
|
@example_group_red = false
|
41
|
-
@example_group_red = false
|
42
41
|
@example_group_number += 1
|
43
42
|
unless example_group_number == 1
|
44
43
|
@output.puts " </dl>"
|
@@ -214,7 +213,7 @@ EOF
|
|
214
213
|
def global_styles
|
215
214
|
<<-EOF
|
216
215
|
#rspec-header {
|
217
|
-
background: #65C400; color: #fff; height:
|
216
|
+
background: #65C400; color: #fff; height: 4em;
|
218
217
|
}
|
219
218
|
|
220
219
|
.rspec-report h1 {
|
@@ -222,7 +221,7 @@ EOF
|
|
222
221
|
padding: 10px;
|
223
222
|
font-family: "Lucida Grande", Helvetica, sans-serif;
|
224
223
|
font-size: 1.8em;
|
225
|
-
|
224
|
+
position: absolute;
|
226
225
|
}
|
227
226
|
|
228
227
|
#summary {
|
@@ -4,33 +4,25 @@ module Spec
|
|
4
4
|
module Runner
|
5
5
|
module Formatter
|
6
6
|
class NestedTextFormatter < BaseTextFormatter
|
7
|
-
attr_reader :previous_nested_example_groups
|
8
7
|
def initialize(options, where)
|
9
8
|
super
|
10
|
-
@
|
9
|
+
@last_nested_descriptions = []
|
11
10
|
end
|
12
11
|
|
13
12
|
def add_example_group(example_group)
|
14
13
|
super
|
15
14
|
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
output.puts "#{' ' * i}#{nested_example_group.description_args.join}"
|
15
|
+
example_group.nested_descriptions.each_with_index do |nested_description, i|
|
16
|
+
unless nested_description == @last_nested_descriptions[i]
|
17
|
+
output.puts "#{' ' * i}#{nested_description}"
|
20
18
|
end
|
21
19
|
end
|
22
20
|
|
23
|
-
@
|
21
|
+
@last_nested_descriptions = example_group.nested_descriptions
|
24
22
|
end
|
25
23
|
|
26
24
|
def example_failed(example, counter, failure)
|
27
|
-
|
28
|
-
"#{current_indentation}#{example.description} (FAILED - #{counter})"
|
29
|
-
else
|
30
|
-
"#{current_indentation}#{example.description} (ERROR - #{counter})"
|
31
|
-
end
|
32
|
-
|
33
|
-
output.puts(failure.expectation_not_met? ? red(message) : magenta(message))
|
25
|
+
output.puts(red("#{current_indentation}#{example.description} (FAILED - #{counter})"))
|
34
26
|
output.flush
|
35
27
|
end
|
36
28
|
|
@@ -47,17 +39,7 @@ module Spec
|
|
47
39
|
end
|
48
40
|
|
49
41
|
def current_indentation
|
50
|
-
' ' *
|
51
|
-
end
|
52
|
-
|
53
|
-
def described_example_group_chain
|
54
|
-
example_group_chain = []
|
55
|
-
example_group.__send__(:example_group_hierarchy).each do |example_group_class|
|
56
|
-
unless example_group_class.description_args.empty?
|
57
|
-
example_group_chain << example_group_class
|
58
|
-
end
|
59
|
-
end
|
60
|
-
example_group_chain
|
42
|
+
' ' * @last_nested_descriptions.length
|
61
43
|
end
|
62
44
|
end
|
63
45
|
end
|
@@ -12,13 +12,7 @@ module Spec
|
|
12
12
|
end
|
13
13
|
|
14
14
|
def example_failed(example, counter, failure)
|
15
|
-
|
16
|
-
"- #{example.description} (FAILED - #{counter})"
|
17
|
-
else
|
18
|
-
"- #{example.description} (ERROR - #{counter})"
|
19
|
-
end
|
20
|
-
|
21
|
-
output.puts(failure.expectation_not_met? ? red(message) : magenta(message))
|
15
|
+
output.puts(red("- #{example.description} (FAILED - #{counter})"))
|
22
16
|
output.flush
|
23
17
|
end
|
24
18
|
|