aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport
diff options
context:
space:
mode:
Diffstat (limited to 'activesupport')
-rw-r--r--activesupport/CHANGELOG2
-rw-r--r--activesupport/lib/active_support/inflector.rb2
-rw-r--r--activesupport/test/inflector_test.rb6
3 files changed, 9 insertions, 1 deletions
diff --git a/activesupport/CHANGELOG b/activesupport/CHANGELOG
index f796774f0f..7b98b2dbed 100644
--- a/activesupport/CHANGELOG
+++ b/activesupport/CHANGELOG
@@ -1,5 +1,7 @@
*SVN*
+* Normalize classify's argument to a String so that it plays nice with Symbols. [Marcel Molina Jr.]
+
* Strip out leading schema name in classify. References #5139. [schoenm@earthlink.net]
* Remove Enumerable#first_match since break(value) handles the use case well enough. [Nicholas Seckar]
diff --git a/activesupport/lib/active_support/inflector.rb b/activesupport/lib/active_support/inflector.rb
index 54b9e064ac..a578ecb95e 100644
--- a/activesupport/lib/active_support/inflector.rb
+++ b/activesupport/lib/active_support/inflector.rb
@@ -147,7 +147,7 @@ module Inflector
def classify(table_name)
# strip out any leading schema name
- camelize(singularize(table_name.sub(/.*\./, '')))
+ camelize(singularize(table_name.to_s.sub(/.*\./, '')))
end
def foreign_key(class_name, separate_class_name_and_id_with_underscore = true)
diff --git a/activesupport/test/inflector_test.rb b/activesupport/test/inflector_test.rb
index c0a2b76a5a..e1676281ad 100644
--- a/activesupport/test/inflector_test.rb
+++ b/activesupport/test/inflector_test.rb
@@ -278,6 +278,12 @@ class InflectorTest < Test::Unit::TestCase
assert_equal(class_name, Inflector.classify(table_name))
end
end
+
+ def test_classify_with_symbol
+ assert_nothing_raised do
+ assert_equal 'FooBar', Inflector.classify(:foo_bar)
+ end
+ end
def test_humanize
UnderscoreToHuman.each do |underscore, human|