rspec-core 3.8.2 → 3.10.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data.tar.gz.sig +0 -0
- data/Changelog.md +76 -1
- data/README.md +4 -4
- data/lib/rspec/core.rb +1 -0
- data/lib/rspec/core/bisect/fork_runner.rb +6 -2
- data/lib/rspec/core/bisect/server.rb +1 -1
- data/lib/rspec/core/configuration.rb +88 -24
- data/lib/rspec/core/did_you_mean.rb +46 -0
- data/lib/rspec/core/drb.rb +7 -0
- data/lib/rspec/core/example.rb +10 -3
- data/lib/rspec/core/example_group.rb +27 -15
- data/lib/rspec/core/filter_manager.rb +1 -1
- data/lib/rspec/core/formatters.rb +4 -0
- data/lib/rspec/core/formatters/documentation_formatter.rb +35 -3
- data/lib/rspec/core/formatters/exception_presenter.rb +22 -9
- data/lib/rspec/core/formatters/failure_list_formatter.rb +23 -0
- data/lib/rspec/core/hooks.rb +43 -21
- data/lib/rspec/core/invocations.rb +1 -1
- data/lib/rspec/core/memoized_helpers.rb +11 -11
- data/lib/rspec/core/metadata.rb +1 -1
- data/lib/rspec/core/option_parser.rb +15 -3
- data/lib/rspec/core/rake_task.rb +22 -2
- data/lib/rspec/core/reporter.rb +8 -0
- data/lib/rspec/core/runner.rb +16 -3
- data/lib/rspec/core/shared_example_group.rb +4 -2
- data/lib/rspec/core/version.rb +1 -1
- data/lib/rspec/core/world.rb +3 -1
- metadata +14 -12
- metadata.gz.sig +0 -0
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 0117b5c68702f84872a6b528a286040ebad81a5201912cf75add518b16391fd8
|
4
|
+
data.tar.gz: 6a744e765c464099b304f42223079af2133ee5e278ffa3f3f3c5118f0ccdae54
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: d659433a8e529d32ef874d0e6c6d100a5482f1dbb1bcc00a65daccbdfd23fd16307f6938b01fada58609ea828f7215992574dd7fda7f1c2873763f9abbf77574
|
7
|
+
data.tar.gz: bdec2aae3e9a5a0c34ccba2bb97a3f4480fa8400f605bb0625b609ebb90a3abf77bfcdbe247f0137d00a2d69f26c3e9ee1565a7a653afe3d14376b3eb97f6ac4
|
checksums.yaml.gz.sig
CHANGED
Binary file
|
data.tar.gz.sig
CHANGED
Binary file
|
data/Changelog.md
CHANGED
@@ -1,3 +1,77 @@
|
|
1
|
+
### 3.10.0 / 2020-10-30
|
2
|
+
[Full Changelog](http://github.com/rspec/rspec-core/compare/v3.9.3...v3.10.0)
|
3
|
+
|
4
|
+
Enhancements:
|
5
|
+
|
6
|
+
* Memoize `RSpec::Core::Formatters::ExceptionPresenter#exception_lines` to improve performance
|
7
|
+
with slow exception messages. (Maxime Lapointe, #2743)
|
8
|
+
* Add configuration for an error exit code (to disambiguate errored builds from failed builds
|
9
|
+
by exit status). (Dana Sherson, #2749)
|
10
|
+
|
11
|
+
# 3.9.3 / 2020-09-30
|
12
|
+
[Full Changelog](http://github.com/rspec/rspec-core/compare/v3.9.2...v3.9.3)
|
13
|
+
|
14
|
+
Bug Fixes:
|
15
|
+
|
16
|
+
* Declare `ruby2_keywords` on `method_missing` for other gems. (Jon Rowe, #2731)
|
17
|
+
* Ensure custom error codes are returned from bisect runs. (Jon Rowe, #2732)
|
18
|
+
* Ensure `RSpec::Core::Configuration` predicate config methods return booleans.
|
19
|
+
(Marc-André Lafortune, #2736)
|
20
|
+
* Prevent `rspec --bisect` from generating zombie processes while executing
|
21
|
+
bisect runs. (Benoit Tigeot, Jon Rowe, #2739)
|
22
|
+
* Predicates for pending examples, (in `RSpec::Core::Example`, `#pending?`, `#skipped?` and
|
23
|
+
`#pending_fixed?`) now return boolean values rather than truthy values.
|
24
|
+
(Marc-André Lafortune, #2756, #2758)
|
25
|
+
* Exceptions which have a message which cannot be cast to a string will no longer
|
26
|
+
cause a crash. (Jon Rowe, #2761)
|
27
|
+
|
28
|
+
### 3.9.2 / 2020-05-02
|
29
|
+
[Full Changelog](http://github.com/rspec/rspec-core/compare/v3.9.1...v3.9.2)
|
30
|
+
|
31
|
+
Bug Fixes:
|
32
|
+
|
33
|
+
* Emit a warning when `around` hook is used with `:context` scope
|
34
|
+
(Phil Pirozhkov, #2687)
|
35
|
+
* Prevent invalid implementations of `Exception#cause` from being treated as a
|
36
|
+
valid cause (and causing strange errors) in `RSpec::Core::Formatters::ExceptionPresenter`.
|
37
|
+
(Jon Rowe, #2703)
|
38
|
+
* Correctly detect patterns when `rspec_opts` is an array in `RSpec::Core::RakeTask`.
|
39
|
+
(Marc-André Lafortune, #2704)
|
40
|
+
* Make `RSpec.clear_examples` reset example counts for example groups. This fixes
|
41
|
+
an issue with re-running specs not matching ids. (Agis Anastasopoulos, #2723)
|
42
|
+
|
43
|
+
### 3.9.1 / 2019-12-28
|
44
|
+
[Full Changelog](http://github.com/rspec/rspec-core/compare/v3.9.0...v3.9.1)
|
45
|
+
|
46
|
+
Bug Fixes:
|
47
|
+
|
48
|
+
* Prevent bisect command from blocking when number of specs exceeds file
|
49
|
+
descriptor limit on OSX or Linux. (Benoit Tigeot, #2669)
|
50
|
+
* Prevent warnings being issued on Ruby 2.7.0. (Jon Rowe, #2680)
|
51
|
+
|
52
|
+
### 3.9.0 / 2019-10-07
|
53
|
+
[Full Changelog](http://github.com/rspec/rspec-core/compare/v3.8.2...v3.9.0)
|
54
|
+
|
55
|
+
Enhancements:
|
56
|
+
|
57
|
+
* Improve the handling of errors during loading support files, if a file
|
58
|
+
errors before loading specs, RSpec will now skip loading the specs.
|
59
|
+
(David Rodríguez, #2568)
|
60
|
+
* Add support for --example-matches to run examples by regular expression.
|
61
|
+
(Sam Joseph, Matt Rider, @okothkongo1, #2586)
|
62
|
+
* Add `did_you_mean` suggestions for file names encountering a `LoadError`
|
63
|
+
outside of examples. (@obromios, #2601)
|
64
|
+
* Add a minimalist quick fix style formatter, only outputs failures as
|
65
|
+
`file:line:message`. (Romain Tartière, #2614)
|
66
|
+
* Convert string number values to integer when used for `RSpec::Configuration#fail_fast`
|
67
|
+
(Viktor Fonic, #2634)
|
68
|
+
* Issue warning when invalid values are used for `RSpec::Configuration#fail_fast`
|
69
|
+
(Viktor Fonic, #2634)
|
70
|
+
* Add support for running the Rake task in a clean environment.
|
71
|
+
(Jon Rowe, #2632)
|
72
|
+
* Indent messages by there example group / example in the documentation formatter.
|
73
|
+
(Samuel Williams, #2649)
|
74
|
+
|
1
75
|
### 3.8.2 / 2019-06-29
|
2
76
|
[Full Changelog](http://github.com/rspec/rspec-core/compare/v3.8.1...v3.8.2)
|
3
77
|
|
@@ -8,7 +82,7 @@ Bug Fixes:
|
|
8
82
|
(Myron Marston, #2635).
|
9
83
|
|
10
84
|
### 3.8.1 / 2019-06-13
|
11
|
-
[Full Changelog](http://github.com/rspec/rspec-core/compare/v3.8.0...
|
85
|
+
[Full Changelog](http://github.com/rspec/rspec-core/compare/v3.8.0...v3.8.1)
|
12
86
|
|
13
87
|
Bug Fixes:
|
14
88
|
|
@@ -2097,6 +2171,7 @@ Bug fixes
|
|
2097
2171
|
[Full Changelog](http://github.com/rspec/rspec-core/compare/v2.2.0...v2.2.1)
|
2098
2172
|
|
2099
2173
|
Bug fixes
|
2174
|
+
|
2100
2175
|
* alias_method instead of override Kernel#method_missing (John Wilger)
|
2101
2176
|
* changed --autotest to --tty in generated command (MIKAMI Yoshiyuki)
|
2102
2177
|
* revert change to debugger (had introduced conflict with Rails)
|
data/README.md
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
# rspec-core [![Build Status](https://secure.travis-ci.org/rspec/rspec-core.svg?branch=
|
1
|
+
# rspec-core [![Build Status](https://secure.travis-ci.org/rspec/rspec-core.svg?branch=main)](http://travis-ci.org/rspec/rspec-core) [![Code Climate](https://codeclimate.com/github/rspec/rspec-core.svg)](https://codeclimate.com/github/rspec/rspec-core)
|
2
2
|
|
3
3
|
rspec-core provides the structure for writing executable examples of how your
|
4
4
|
code should behave, and an `rspec` command with tools to constrain which
|
@@ -10,12 +10,12 @@ examples get run and tailor the output.
|
|
10
10
|
gem install rspec-core # for rspec-core only
|
11
11
|
rspec --help
|
12
12
|
|
13
|
-
Want to run against the `
|
13
|
+
Want to run against the `main` branch? You'll need to include the dependent
|
14
14
|
RSpec repos as well. Add the following to your `Gemfile`:
|
15
15
|
|
16
16
|
```ruby
|
17
17
|
%w[rspec rspec-core rspec-expectations rspec-mocks rspec-support].each do |lib|
|
18
|
-
gem lib, :git => "https://github.com/rspec/#{lib}.git", :branch => '
|
18
|
+
gem lib, :git => "https://github.com/rspec/#{lib}.git", :branch => 'main'
|
19
19
|
end
|
20
20
|
```
|
21
21
|
|
@@ -53,7 +53,7 @@ context of an _instance_ of that class.
|
|
53
53
|
|
54
54
|
## Nested Groups
|
55
55
|
|
56
|
-
You can also declare nested
|
56
|
+
You can also declare nested groups using the `describe` or `context`
|
57
57
|
methods:
|
58
58
|
|
59
59
|
```ruby
|
data/lib/rspec/core.rb
CHANGED
@@ -139,6 +139,7 @@ module RSpec
|
|
139
139
|
module Core
|
140
140
|
autoload :ExampleStatusPersister, "rspec/core/example_status_persister"
|
141
141
|
autoload :Profiler, "rspec/core/profiler"
|
142
|
+
autoload :DidYouMean, "rspec/core/did_you_mean"
|
142
143
|
|
143
144
|
# @private
|
144
145
|
# This avoids issues with reporting time caused by examples that
|
@@ -6,7 +6,7 @@ module RSpec
|
|
6
6
|
module Core
|
7
7
|
module Bisect
|
8
8
|
# A Bisect runner that runs requested subsets of the suite by forking
|
9
|
-
# sub-processes. The
|
9
|
+
# sub-processes. The main process bootstraps RSpec and the application
|
10
10
|
# environment (including preloading files specified via `--require`) so
|
11
11
|
# that the individual spec runs do not have to re-pay that cost. Each
|
12
12
|
# spec run happens in a forked process, ensuring that the spec files are
|
@@ -92,7 +92,11 @@ module RSpec
|
|
92
92
|
|
93
93
|
def dispatch_specs(run_descriptor)
|
94
94
|
pid = fork { run_specs(run_descriptor) }
|
95
|
-
Process.waitpid
|
95
|
+
# We don't use Process.waitpid here as it was causing bisects to
|
96
|
+
# block due to the file descriptor limit on OSX / Linux. We need
|
97
|
+
# to detach the process to avoid having zombie processes
|
98
|
+
# consuming slots in the kernel process table during bisect runs.
|
99
|
+
Process.detach(pid)
|
96
100
|
end
|
97
101
|
|
98
102
|
private
|
@@ -33,7 +33,7 @@ module RSpec
|
|
33
33
|
|
34
34
|
def start
|
35
35
|
# Only allow remote DRb requests from this machine.
|
36
|
-
DRb.install_acl ACL.new(%w[ deny all allow localhost allow 127.0.0.1 ])
|
36
|
+
DRb.install_acl ACL.new(%w[ deny all allow localhost allow 127.0.0.1 allow ::1 ])
|
37
37
|
|
38
38
|
# We pass `nil` as the first arg to allow it to pick a DRb port.
|
39
39
|
@drb = DRb.start_service(nil, self)
|
@@ -67,15 +67,17 @@ module RSpec
|
|
67
67
|
end
|
68
68
|
|
69
69
|
# @private
|
70
|
-
def self.
|
70
|
+
def self.define_alias(name, alias_name)
|
71
71
|
alias_method alias_name, name
|
72
72
|
alias_method "#{alias_name}=", "#{name}="
|
73
|
-
|
73
|
+
define_predicate alias_name
|
74
74
|
end
|
75
75
|
|
76
76
|
# @private
|
77
|
-
def self.
|
78
|
-
|
77
|
+
def self.define_predicate(name)
|
78
|
+
define_method "#{name}?" do
|
79
|
+
!!send(name)
|
80
|
+
end
|
79
81
|
end
|
80
82
|
|
81
83
|
# @private
|
@@ -88,7 +90,7 @@ module RSpec
|
|
88
90
|
add_read_only_setting name
|
89
91
|
|
90
92
|
Array(opts[:alias_with]).each do |alias_name|
|
91
|
-
|
93
|
+
define_alias(name, alias_name)
|
92
94
|
end
|
93
95
|
end
|
94
96
|
|
@@ -98,7 +100,7 @@ module RSpec
|
|
98
100
|
def self.add_read_only_setting(name, opts={})
|
99
101
|
raise "Use the instance add_setting method if you want to set a default" if opts.key?(:default)
|
100
102
|
define_reader name
|
101
|
-
|
103
|
+
define_predicate name
|
102
104
|
end
|
103
105
|
|
104
106
|
# @macro [attach] add_setting
|
@@ -202,10 +204,33 @@ module RSpec
|
|
202
204
|
only_failures? && !example_status_persistence_file_path
|
203
205
|
end
|
204
206
|
|
205
|
-
# @macro
|
207
|
+
# @macro define_reader
|
206
208
|
# If specified, indicates the number of failures required before cleaning
|
207
|
-
# up and exit (default: `nil`).
|
208
|
-
|
209
|
+
# up and exit (default: `nil`). Can also be `true` to fail and exit on first
|
210
|
+
# failure
|
211
|
+
define_reader :fail_fast
|
212
|
+
|
213
|
+
# @see fail_fast
|
214
|
+
def fail_fast=(value)
|
215
|
+
case value
|
216
|
+
when true, 'true'
|
217
|
+
@fail_fast = true
|
218
|
+
when false, 'false', 0
|
219
|
+
@fail_fast = false
|
220
|
+
when nil
|
221
|
+
@fail_fast = nil
|
222
|
+
else
|
223
|
+
@fail_fast = value.to_i
|
224
|
+
|
225
|
+
if value.to_i == 0
|
226
|
+
# TODO: in RSpec 4, consider raising an error here.
|
227
|
+
RSpec.warning "Cannot set `RSpec.configuration.fail_fast`" \
|
228
|
+
" to `#{value.inspect}`. Only `true`, `false`, `nil` and integers" \
|
229
|
+
" are valid values."
|
230
|
+
@fail_fast = true
|
231
|
+
end
|
232
|
+
end
|
233
|
+
end
|
209
234
|
|
210
235
|
# @macro add_setting
|
211
236
|
# Prints the formatter output of your suite without running any
|
@@ -217,6 +242,11 @@ module RSpec
|
|
217
242
|
# @return [Integer]
|
218
243
|
add_setting :failure_exit_code
|
219
244
|
|
245
|
+
# @macro add_setting
|
246
|
+
# The exit code to return if there are any errors outside examples (default: failure_exit_code)
|
247
|
+
# @return [Integer]
|
248
|
+
add_setting :error_exit_code
|
249
|
+
|
220
250
|
# @macro add_setting
|
221
251
|
# Whether or not to fail when there are no RSpec examples (default: false).
|
222
252
|
# @return [Boolean]
|
@@ -289,7 +319,8 @@ module RSpec
|
|
289
319
|
# Report the times for the slowest examples (default: `false`).
|
290
320
|
# Use this to specify the number of examples to include in the profile.
|
291
321
|
# @return [Boolean]
|
292
|
-
|
322
|
+
attr_writer :profile_examples
|
323
|
+
define_predicate :profile_examples
|
293
324
|
|
294
325
|
# @macro add_setting
|
295
326
|
# Run all examples if none match the configured filters
|
@@ -497,6 +528,7 @@ module RSpec
|
|
497
528
|
@pattern = '**{,/*/**}/*_spec.rb'
|
498
529
|
@exclude_pattern = ''
|
499
530
|
@failure_exit_code = 1
|
531
|
+
@error_exit_code = nil # so it can be overridden by failure exit code
|
500
532
|
@fail_if_no_examples = false
|
501
533
|
@spec_files_loaded = false
|
502
534
|
|
@@ -1106,7 +1138,7 @@ module RSpec
|
|
1106
1138
|
#
|
1107
1139
|
# # This lets you do this:
|
1108
1140
|
#
|
1109
|
-
# describe Thing do
|
1141
|
+
# RSpec.describe Thing do
|
1110
1142
|
# pending "does something" do
|
1111
1143
|
# thing = Thing.new
|
1112
1144
|
# end
|
@@ -1114,7 +1146,7 @@ module RSpec
|
|
1114
1146
|
#
|
1115
1147
|
# # ... which is the equivalent of
|
1116
1148
|
#
|
1117
|
-
# describe Thing do
|
1149
|
+
# RSpec.describe Thing do
|
1118
1150
|
# it "does something", :pending => true do
|
1119
1151
|
# thing = Thing.new
|
1120
1152
|
# end
|
@@ -1167,7 +1199,7 @@ module RSpec
|
|
1167
1199
|
#
|
1168
1200
|
# # allows the user to include a shared example group like:
|
1169
1201
|
#
|
1170
|
-
# describe Entity do
|
1202
|
+
# RSpec.describe Entity do
|
1171
1203
|
# it_has_behavior 'sortability' do
|
1172
1204
|
# let(:sortable) { Entity.new }
|
1173
1205
|
# end
|
@@ -1327,6 +1359,12 @@ module RSpec
|
|
1327
1359
|
# end
|
1328
1360
|
# end
|
1329
1361
|
#
|
1362
|
+
# module PreferencesHelpers
|
1363
|
+
# def preferences(user, preferences = {})
|
1364
|
+
# # ...
|
1365
|
+
# end
|
1366
|
+
# end
|
1367
|
+
#
|
1330
1368
|
# module UserHelpers
|
1331
1369
|
# def users(username)
|
1332
1370
|
# # ...
|
@@ -1335,12 +1373,17 @@ module RSpec
|
|
1335
1373
|
#
|
1336
1374
|
# RSpec.configure do |config|
|
1337
1375
|
# config.include(UserHelpers) # included in all groups
|
1376
|
+
#
|
1377
|
+
# # included in examples with `:preferences` metadata
|
1378
|
+
# config.include(PreferenceHelpers, :preferences)
|
1379
|
+
#
|
1380
|
+
# # included in examples with `:type => :request` metadata
|
1338
1381
|
# config.include(AuthenticationHelpers, :type => :request)
|
1339
1382
|
# end
|
1340
1383
|
#
|
1341
|
-
# describe "edit profile", :type => :request do
|
1384
|
+
# describe "edit profile", :preferences, :type => :request do
|
1342
1385
|
# it "can be viewed by owning user" do
|
1343
|
-
# login_as users(:jdoe)
|
1386
|
+
# login_as preferences(users(:jdoe), :lang => 'es')
|
1344
1387
|
# get "/profiles/jdoe"
|
1345
1388
|
# assert_select ".username", :text => 'jdoe'
|
1346
1389
|
# end
|
@@ -1368,17 +1411,21 @@ module RSpec
|
|
1368
1411
|
#
|
1369
1412
|
# @example
|
1370
1413
|
#
|
1371
|
-
# RSpec.shared_context "example
|
1414
|
+
# RSpec.shared_context "example admin user" do
|
1372
1415
|
# let(:admin_user) { create_user(:admin) }
|
1416
|
+
# end
|
1417
|
+
#
|
1418
|
+
# RSpec.shared_context "example guest user" do
|
1373
1419
|
# let(:guest_user) { create_user(:guest) }
|
1374
1420
|
# end
|
1375
1421
|
#
|
1376
1422
|
# RSpec.configure do |config|
|
1377
|
-
# config.include_context "example
|
1423
|
+
# config.include_context "example guest user", :type => :request
|
1424
|
+
# config.include_context "example admin user", :admin, :type => :request
|
1378
1425
|
# end
|
1379
1426
|
#
|
1380
1427
|
# RSpec.describe "The admin page", :type => :request do
|
1381
|
-
# it "can be viewed by admins" do
|
1428
|
+
# it "can be viewed by admins", :admin do
|
1382
1429
|
# login_with admin_user
|
1383
1430
|
# get "/admin"
|
1384
1431
|
# expect(response).to be_ok
|
@@ -1420,12 +1467,20 @@ module RSpec
|
|
1420
1467
|
# end
|
1421
1468
|
# end
|
1422
1469
|
#
|
1470
|
+
# module PermissionHelpers
|
1471
|
+
# def define_permissions
|
1472
|
+
# # ...
|
1473
|
+
# end
|
1474
|
+
# end
|
1475
|
+
#
|
1423
1476
|
# RSpec.configure do |config|
|
1424
1477
|
# config.extend(UiHelpers, :type => :request)
|
1478
|
+
# config.extend(PermissionHelpers, :with_permissions, :type => :request)
|
1425
1479
|
# end
|
1426
1480
|
#
|
1427
|
-
# describe "edit profile", :type => :request do
|
1481
|
+
# describe "edit profile", :with_permissions, :type => :request do
|
1428
1482
|
# run_in_browser
|
1483
|
+
# define_permissions
|
1429
1484
|
#
|
1430
1485
|
# it "does stuff in the client" do
|
1431
1486
|
# # ...
|
@@ -1718,7 +1773,7 @@ module RSpec
|
|
1718
1773
|
# rspec.expose_current_running_example_as :example
|
1719
1774
|
# end
|
1720
1775
|
#
|
1721
|
-
# describe MyClass do
|
1776
|
+
# RSpec.describe MyClass do
|
1722
1777
|
# before do
|
1723
1778
|
# # `example` can be used here because of the above config.
|
1724
1779
|
# do_something if example.metadata[:type] == "foo"
|
@@ -1883,7 +1938,8 @@ module RSpec
|
|
1883
1938
|
#
|
1884
1939
|
# This method differs from {Hooks#before} in only one way: it supports
|
1885
1940
|
# the `:suite` scope. Hooks with the `:suite` scope will be run once before
|
1886
|
-
# the first example of the entire suite is executed.
|
1941
|
+
# the first example of the entire suite is executed. Conditions passed along
|
1942
|
+
# with `:suite` are effectively ignored.
|
1887
1943
|
#
|
1888
1944
|
# @see #prepend_before
|
1889
1945
|
# @see #after
|
@@ -1912,7 +1968,8 @@ module RSpec
|
|
1912
1968
|
#
|
1913
1969
|
# This method differs from {Hooks#prepend_before} in only one way: it supports
|
1914
1970
|
# the `:suite` scope. Hooks with the `:suite` scope will be run once before
|
1915
|
-
# the first example of the entire suite is executed.
|
1971
|
+
# the first example of the entire suite is executed. Conditions passed along
|
1972
|
+
# with `:suite` are effectively ignored.
|
1916
1973
|
#
|
1917
1974
|
# @see #before
|
1918
1975
|
# @see #after
|
@@ -1936,7 +1993,8 @@ module RSpec
|
|
1936
1993
|
#
|
1937
1994
|
# This method differs from {Hooks#after} in only one way: it supports
|
1938
1995
|
# the `:suite` scope. Hooks with the `:suite` scope will be run once after
|
1939
|
-
# the last example of the entire suite is executed.
|
1996
|
+
# the last example of the entire suite is executed. Conditions passed along
|
1997
|
+
# with `:suite` are effectively ignored.
|
1940
1998
|
#
|
1941
1999
|
# @see #append_after
|
1942
2000
|
# @see #before
|
@@ -1965,7 +2023,8 @@ module RSpec
|
|
1965
2023
|
#
|
1966
2024
|
# This method differs from {Hooks#append_after} in only one way: it supports
|
1967
2025
|
# the `:suite` scope. Hooks with the `:suite` scope will be run once after
|
1968
|
-
# the last example of the entire suite is executed.
|
2026
|
+
# the last example of the entire suite is executed. Conditions passed along
|
2027
|
+
# with `:suite` are effectively ignored.
|
1969
2028
|
#
|
1970
2029
|
# @see #append_after
|
1971
2030
|
# @see #before
|
@@ -2051,6 +2110,11 @@ module RSpec
|
|
2051
2110
|
|
2052
2111
|
def load_file_handling_errors(method, file)
|
2053
2112
|
__send__(method, file)
|
2113
|
+
rescue LoadError => ex
|
2114
|
+
relative_file = Metadata.relative_path(file)
|
2115
|
+
suggestions = DidYouMean.new(relative_file).call
|
2116
|
+
reporter.notify_non_example_exception(ex, "An error occurred while loading #{relative_file}.#{suggestions}")
|
2117
|
+
RSpec.world.wants_to_quit = true
|
2054
2118
|
rescue Support::AllExceptionsExceptOnesWeMustNotRescue => ex
|
2055
2119
|
relative_file = Metadata.relative_path(file)
|
2056
2120
|
reporter.notify_non_example_exception(ex, "An error occurred while loading #{relative_file}.")
|
@@ -0,0 +1,46 @@
|
|
1
|
+
module RSpec
|
2
|
+
module Core
|
3
|
+
# @private
|
4
|
+
# Wrapper around Ruby's `DidYouMean::SpellChecker` when available to provide file name suggestions.
|
5
|
+
class DidYouMean
|
6
|
+
attr_reader :relative_file_name
|
7
|
+
|
8
|
+
def initialize(relative_file_name)
|
9
|
+
@relative_file_name = relative_file_name
|
10
|
+
end
|
11
|
+
|
12
|
+
if defined?(::DidYouMean::SpellChecker)
|
13
|
+
# provide probable suggestions
|
14
|
+
def call
|
15
|
+
checker = ::DidYouMean::SpellChecker.new(:dictionary => Dir["spec/**/*.rb"])
|
16
|
+
probables = checker.correct(relative_file_name.sub('./', ''))[0..2]
|
17
|
+
return '' unless probables.any?
|
18
|
+
|
19
|
+
formats probables
|
20
|
+
end
|
21
|
+
else
|
22
|
+
# return a hint if API for ::DidYouMean::SpellChecker not supported
|
23
|
+
def call
|
24
|
+
"\nHint: Install the `did_you_mean` gem in order to provide suggestions for similarly named files."
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
private
|
29
|
+
|
30
|
+
def formats(probables)
|
31
|
+
rspec_format = probables.map { |s, _| "rspec ./#{s}" }
|
32
|
+
red_font(top_and_tail rspec_format)
|
33
|
+
end
|
34
|
+
|
35
|
+
def top_and_tail(rspec_format)
|
36
|
+
spaces = ' ' * 20
|
37
|
+
rspec_format.insert(0, ' - Did you mean?').join("\n#{spaces}") + "\n"
|
38
|
+
end
|
39
|
+
|
40
|
+
def red_font(mytext)
|
41
|
+
colorizer = ::RSpec::Core::Formatters::ConsoleCodes
|
42
|
+
colorizer.wrap mytext, :failure
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|