ActionsLike0
Bug #19164
closed[3.2.0dev] Freezing an object can prevent removing methods on its class
Description
The following snippet showcase the bug. It passes on 3.1 and older, but fails on 3.2.0
klass = Class.new
klass.prepend(Module.new)
klass.new.freeze
klass.define_method(:bar) {} # works
klass.remove_method(:bar) # raise FrozenError
Bisecting with this script points me to e7b1ff984fde859a7778dec564731eb79392406f, which suggest some part of the codebase might be misusing some user flags.
I have a patch that fix this script but I doubt it's the right fix, I'll be working with @jemmai (Jemma Issroff) and @tenderlovemaking (Aaron Patterson) to find a proper fix.
I'm opening this ticket to make sure it's addressed before the 3.2.0 final release.
Added by Jean byroot Boussier over 2 years ago
ActionsLike0
Module#remove_method: Check frozen on the right object
Previously, the frozen check happened on
RCLASS_ORIGIN(self)
, whichcan return an iclass. The frozen check is supposed to respond to objects
that users can call methods on while iclasses are hidden from users.
Other mutation methods like Module#{define_method,alias_method,public}
don't do this. Check frozen status on the module itself.
Fixes [Bug #19164] and [Bug #19166].
Co-authored-by: Alan Wu XrXr@users.noreply.github.com