summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNobuyoshi Nakada <[email protected]>2024-11-19 12:43:38 +0900
committerNobuyoshi Nakada <[email protected]>2024-11-19 12:43:38 +0900
commit9c777f282f8482400d4b0c7993d520c18cb1b652 (patch)
tree087709ecbc982385e5492a170df770ee684842e7
parent727b2a29990022fc96eddb4c63271f0eac60d926 (diff)
[Bug #20900] Warn deprecated constant when removing
Notes
Notes: Merged: https://github.com/ruby/ruby/pull/12114
-rw-r--r--spec/ruby/core/module/deprecate_constant_spec.rb9
-rw-r--r--test/ruby/test_module.rb5
-rw-r--r--variable.c1
3 files changed, 12 insertions, 3 deletions
diff --git a/spec/ruby/core/module/deprecate_constant_spec.rb b/spec/ruby/core/module/deprecate_constant_spec.rb
index aabef934c4..ec0de6782f 100644
--- a/spec/ruby/core/module/deprecate_constant_spec.rb
+++ b/spec/ruby/core/module/deprecate_constant_spec.rb
@@ -44,6 +44,15 @@ describe "Module#deprecate_constant" do
end
end
+ ruby_bug '#20900', ''...'3.4' do
+ describe "when removing the deprecated module" do
+ it "warns with a message" do
+ @module.deprecate_constant :PUBLIC1
+ -> { @module.module_eval {remove_const :PUBLIC1} }.should complain(/warning: constant .+::PUBLIC1 is deprecated/)
+ end
+ end
+ end
+
it "accepts multiple symbols and strings as constant names" do
@module.deprecate_constant "PUBLIC1", :PUBLIC2
diff --git a/test/ruby/test_module.rb b/test/ruby/test_module.rb
index 370b7351c2..3228bb5c61 100644
--- a/test/ruby/test_module.rb
+++ b/test/ruby/test_module.rb
@@ -2148,9 +2148,8 @@ class TestModule < Test::Unit::TestCase
Warning[:deprecated] = false
Class.new(c)::FOO
end
- assert_warn('') do
- Warning[:deprecated] = false
- c.class_eval "FOO"
+ assert_warn(/deprecated/) do
+ c.class_eval {remove_const "FOO"}
end
end
diff --git a/variable.c b/variable.c
index 61c188bede..e4a24f44a0 100644
--- a/variable.c
+++ b/variable.c
@@ -3280,6 +3280,7 @@ rb_const_remove(VALUE mod, ID id)
undefined_constant(mod, ID2SYM(id));
}
+ rb_const_warn_if_deprecated(ce, mod, id);
rb_clear_constant_cache_for_id(id);
val = ce->value;