aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport/test/autoloading_fixtures/prepend
diff options
context:
space:
mode:
authorJean Boussier <jean.boussier@gmail.com>2016-12-14 11:47:51 +0100
committerJean Boussier <jean.boussier@gmail.com>2016-12-14 14:25:43 +0100
commit11e05defecde965e0eb1929f1b0f1f992be39a6b (patch)
tree2743c8f2f18edf9aaf4bea170805fe080e216d89 /activesupport/test/autoloading_fixtures/prepend
parente3e663f1dc40a5cfae9ec60e32f5372cd7f9885b (diff)
downloadrails-11e05defecde965e0eb1929f1b0f1f992be39a6b.tar.gz
rails-11e05defecde965e0eb1929f1b0f1f992be39a6b.tar.bz2
rails-11e05defecde965e0eb1929f1b0f1f992be39a6b.zip
Fix constantize edge case involving prepend, autoloading and name conflicts
In the following situation: ```ruby class Bar end module Baz end class Foo prepend Baz end class Foo::Bar end ``` Running `Inflector.constantize('Foo::Bar')` would blow up with a NameError. What is happening is that `constatize` was written before the introduction of prepend, and wrongly assume that `klass.ancestors.first == klass`. So it uses `klass.ancestors.inject` without arguments, as a result a prepended module is used in place of the actual class.
Diffstat (limited to 'activesupport/test/autoloading_fixtures/prepend')
-rw-r--r--activesupport/test/autoloading_fixtures/prepend/sub_class_conflict.rb2
1 files changed, 2 insertions, 0 deletions
diff --git a/activesupport/test/autoloading_fixtures/prepend/sub_class_conflict.rb b/activesupport/test/autoloading_fixtures/prepend/sub_class_conflict.rb
new file mode 100644
index 0000000000..090dda3043
--- /dev/null
+++ b/activesupport/test/autoloading_fixtures/prepend/sub_class_conflict.rb
@@ -0,0 +1,2 @@
+class Prepend::SubClassConflict
+end