Project

General

Profile

Actions

Misc #17591

closed

Test frameworks and REPLs do not show deprecation warnings by default

Added by Eregon (Benoit Daloze) about 3 years ago. Updated 11 months ago.

Status:
Closed
Assignee:
-
[ruby-core:102301]

Description

Various people in #16345 said that:

The issue can be mitigated if all test frameworks enable all deprecation warnings.
The developer's practice can be supported by tools, such as test frameworks enable deprecation warnings automatically.

And this was used as a base to disable deprecation warnings by default in Ruby 2.7.2.

However, it seems no test frameworks or REPLs actually show deprecation warnings by default!
So Ruby developers will typically never see deprecation warnings for keyword arguments, and it will just break when they try Ruby 3.0.

I think only MSpec does Warning[:deprecated] = true, whether or not -w is passed, which seems the right thing to do.

Currently, RSpec enables Warning[:deprecated] = true only for rspec -w.

Same for test/unit 3.3.4 shipped with 2.7.2.

IRB in 2.7.2 does not show deprecated warnings.
Same for pry.

I think ruby-core needs to have a clear message here, like:

All test frameworks and REPLs should include this snippet and run it before running tests: Warning[:deprecated] = true if Warning.respond_to?(:[]=).
This is important so that developers see warnings in development, and that they see the warnings before updating to the next Ruby version.
Developers can choose to disable deprecation warnings explicitly if they want with Warning[:deprecated] = false.

And I think it would be good that ruby-core makes a PR or an issue to the main test frameworks/REPLs to show examples.

P.S.: if someone wants to disable all warnings with -W0 or $VERBOSE = nil, it will indeed disable them all, including deprecation warnings, so there is no need to check $VERBOSE for setting Warning[:deprecated] = true.


Related issues 2 (0 open2 closed)

Related to Ruby master - Feature #16345: Don't emit deprecation warnings by default.ClosedActions
Related to Ruby master - Feature #17000: 2.7.2 turns off deprecation warnings by defaultClosednagachika (Tomoyuki Chikanaga)Actions
Actions

Also available in: Atom PDF

Like0
Like0Like0Like0Like0Like0Like0Like0Like0Like0Like0Like0Like0Like0Like0Like0Like0