mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
allow spaces and other characters in attribute names [#4725 state:resolved]
* define the dynamically defined methods with 'define_method' instead of def * wrap some string injected method names in quotes Signed-off-by: Santiago Pastorino <santiago@wyeworks.com>
This commit is contained in:
parent
d65e3b481e
commit
bca070ef2d
2 changed files with 34 additions and 4 deletions
|
@ -230,8 +230,8 @@ module ActiveModel
|
|||
def alias_attribute(new_name, old_name)
|
||||
attribute_method_matchers.each do |matcher|
|
||||
module_eval <<-STR, __FILE__, __LINE__ + 1
|
||||
def #{matcher.method_name(new_name)}(*args)
|
||||
send(:#{matcher.method_name(old_name)}, *args)
|
||||
define_method(:'#{matcher.method_name(new_name)}') do |*args|
|
||||
send(:'#{matcher.method_name(old_name)}', *args)
|
||||
end
|
||||
STR
|
||||
end
|
||||
|
@ -277,8 +277,8 @@ module ActiveModel
|
|||
if method_defined?(:'#{method_name}')
|
||||
undef :'#{method_name}'
|
||||
end
|
||||
def #{method_name}(*args)
|
||||
send(:#{matcher.method_missing_target}, '#{attr_name}', *args)
|
||||
define_method(:'#{method_name}') do |*args|
|
||||
send(:'#{matcher.method_missing_target}', '#{attr_name}', *args)
|
||||
end
|
||||
STR
|
||||
end
|
||||
|
|
|
@ -21,6 +21,21 @@ class ModelWithAttributes2
|
|||
attribute_method_suffix '_test'
|
||||
end
|
||||
|
||||
class ModelWithAttributesWithSpaces
|
||||
include ActiveModel::AttributeMethods
|
||||
|
||||
attribute_method_suffix ''
|
||||
|
||||
def attributes
|
||||
{ :'foo bar' => 'value of foo bar'}
|
||||
end
|
||||
|
||||
private
|
||||
def attribute(name)
|
||||
attributes[name.to_sym]
|
||||
end
|
||||
end
|
||||
|
||||
class AttributeMethodsTest < ActiveModel::TestCase
|
||||
test 'unrelated classes should not share attribute method matchers' do
|
||||
assert_not_equal ModelWithAttributes.send(:attribute_method_matchers),
|
||||
|
@ -35,6 +50,21 @@ class AttributeMethodsTest < ActiveModel::TestCase
|
|||
assert_equal "value of foo", ModelWithAttributes.new.foo
|
||||
end
|
||||
|
||||
test '#define_attribute_methods generates attribute methods with spaces in their names' do
|
||||
ModelWithAttributesWithSpaces.define_attribute_methods([:'foo bar'])
|
||||
|
||||
assert ModelWithAttributesWithSpaces.attribute_methods_generated?
|
||||
assert_respond_to ModelWithAttributesWithSpaces.new, :'foo bar'
|
||||
assert_equal "value of foo bar", ModelWithAttributesWithSpaces.new.send(:'foo bar')
|
||||
end
|
||||
|
||||
test '#alias_attribute works with attributes with spaces in their names' do
|
||||
ModelWithAttributesWithSpaces.define_attribute_methods([:'foo bar'])
|
||||
ModelWithAttributesWithSpaces.alias_attribute(:'foo_bar', :'foo bar')
|
||||
|
||||
assert_equal "value of foo bar", ModelWithAttributesWithSpaces.new.foo_bar
|
||||
end
|
||||
|
||||
test '#undefine_attribute_methods removes attribute methods' do
|
||||
ModelWithAttributes.define_attribute_methods([:foo])
|
||||
ModelWithAttributes.undefine_attribute_methods
|
||||
|
|
Loading…
Reference in a new issue