Adam Stegman
2010-Apr-01 23:10 UTC
ActiveRecord::Errors is empty when the record is invalid
I''m running into an interesting problem where an ActiveRecord instance #valid? returns false, but #errors#full_messages is empty. This is in one of my models. The code was run in ruby-debug sitting in one of my validation methods. (rdb:1) self.publisher_address.valid? false (rdb:1) self.publisher_address.errors.full_messages [] (rdb:1) a = Address.new(self.publisher_address.attributes) (rdb:1) a.valid? false (rdb:1) a.errors.full_messages ["User can''t be blank", "City can''t be blank"...] self.publisher_address is an unsaved Address object, created using Address.new. So is a, which I just created. Both are invalid, yet a has error messages like it should but self.publisher_address doesn''t. I can''t figure out why. (rdb:1) self.publisher_address #<Address id: nil, user_id: nil,...> (rdb:1) a #<Address id: nil, user_id: nil,...> (rdb:1) self.publisher_address.class Address(id: integer, user_id: integer,...) (rdb:1) a.class Address(id: integer, user_id: integer,...) The #publisher_address method in this model is custom, not an association. I get the hash of the attributes and do return Address.new(publisher_address_attributes) self.publisher_address.errors is an AR::Errors object, but the actual errors are blank: (rdb:1) self.publisher_address.errors #<ActiveRecord::Errors:0x2cddf50 @base=#<Address id: nil, user_id: nil,...>, @errors=#<OrderedHash {}>> Has anyone seen empty errors like this before? -- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group. To post to this group, send email to rubyonrails-talk-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org To unsubscribe from this group, send email to rubyonrails-talk+unsubscribe-/JYPxA39Uh5TLH3MbocFF+G/Ez6ZCGd0@public.gmane.org For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en.