Skip to content

Commit

Permalink
Deprecate usage of should_not raise_error
Browse files Browse the repository at this point in the history
  • Loading branch information
andrykonchin committed Dec 5, 2020
1 parent b58e665 commit 95a2dcf
Show file tree
Hide file tree
Showing 3 changed files with 15 additions and 3 deletions.
4 changes: 4 additions & 0 deletions lib/mspec/expectations/should.rb
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,10 @@ def should_not(matcher = NO_MATCHER_GIVEN)
raise "should_not outside example" unless state
MSpec.actions :expectation, state

if RaiseErrorMatcher === matcher
$stderr.puts "\nDeprecation: ->{}.should_not raise_error breaks code style and is deprecated"
end

if NO_MATCHER_GIVEN.equal?(matcher)
SpecNegativeOperatorMatcher.new(self)
else
Expand Down
4 changes: 4 additions & 0 deletions spec/expectations/should.rb
Original file line number Diff line number Diff line change
Expand Up @@ -70,4 +70,8 @@ def finish
it "invokes the MSpec :expectation actions" do
1.should_not == 2
end

it "deprecates using `{}.should_not raise_error`" do
-> { }.should_not raise_error
end
end
10 changes: 7 additions & 3 deletions spec/expectations/should_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
before :all do
path = RbConfig::CONFIG['bindir']
exe = RbConfig::CONFIG['ruby_install_name']
file = File.dirname(__FILE__) + '/should.rb'
file = File.dirname(__FILE__) + '/should.rb 2>&1'
@out = `#{path}/#{exe} #{file}`
end

Expand Down Expand Up @@ -45,17 +45,21 @@
No behavior expectation was found in the example
EOS
end

it 'prints a deprecation message about using `{}.should_not raise_error`' do
@out.should include "Deprecation: ->{}.should_not raise_error breaks code style and is deprecated"
end
end

it "prints status information" do
@out.should include ".FF..FF."
end

it "prints out a summary" do
@out.should include "0 files, 8 examples, 6 expectations, 4 failures, 0 errors"
@out.should include "0 files, 9 examples, 7 expectations, 4 failures, 0 errors"
end

it "records expectations" do
@out.should include "I was called 6 times"
@out.should include "I was called 7 times"
end
end

0 comments on commit 95a2dcf

Please sign in to comment.