diff options
| author | Santiago Pastorino <santiago@wyeworks.com> | 2011-03-16 19:17:47 -0300 | 
|---|---|---|
| committer | Santiago Pastorino <santiago@wyeworks.com> | 2011-03-16 21:01:04 -0300 | 
| commit | cb44e99de46e924bdceab9294fbaea9732e9dba6 (patch) | |
| tree | 51c3adb0c524a9baa3bb3768ff17278e36ee0a29 | |
| parent | 0eae62525696b57fe7fc4bbb0bf9c0bc7ee4e480 (diff) | |
| download | rails-cb44e99de46e924bdceab9294fbaea9732e9dba6.tar.gz rails-cb44e99de46e924bdceab9294fbaea9732e9dba6.tar.bz2 rails-cb44e99de46e924bdceab9294fbaea9732e9dba6.zip | |
Add test for define_attribute_method using as name an invalid identifier
| -rw-r--r-- | activemodel/test/cases/attribute_methods_test.rb | 29 | 
1 files changed, 26 insertions, 3 deletions
| diff --git a/activemodel/test/cases/attribute_methods_test.rb b/activemodel/test/cases/attribute_methods_test.rb index b001adb35a..4cfec66015 100644 --- a/activemodel/test/cases/attribute_methods_test.rb +++ b/activemodel/test/cases/attribute_methods_test.rb @@ -36,6 +36,21 @@ private    end  end +class ModelWithWeirdNamesAttributes +  include ActiveModel::AttributeMethods + +  attribute_method_suffix '' + +  def attributes +    { :'a?b' => 'value of a?b' } +  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), @@ -49,6 +64,14 @@ class AttributeMethodsTest < ActiveModel::TestCase      assert_equal "value of foo", ModelWithAttributes.new.foo    end +  test '#define_attribute_method generates attribute method with invalid identifier characters' do +    ModelWithWeirdNamesAttributes.define_attribute_method(:'a?b') +    ModelWithWeirdNamesAttributes.define_attribute_method(:'a?b') + +    assert_respond_to ModelWithWeirdNamesAttributes.new, :'a?b' +    assert_equal "value of a?b", ModelWithWeirdNamesAttributes.new.send('a?b') +  end +    test '#define_attribute_methods generates attribute methods' do      ModelWithAttributes.define_attribute_methods([:foo]) @@ -58,15 +81,15 @@ class AttributeMethodsTest < ActiveModel::TestCase    test '#define_attribute_methods generates attribute methods with spaces in their names' do      ModelWithAttributesWithSpaces.define_attribute_methods([:'foo bar']) -   +      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 | 
