My :counter_cache column isn''t working properly. I wouldn''t normally ask about a relatively trivial issue like this but I''ve been banging my head on this for a bit and haven''t gotten anywhere. I must be missing something simple. Please take a look: class Comments < ActiveRecord::Base belongs_to :test_case, :counter_cache => true end class TestCases < ActiveRecord::Base has_many :test_case_to_users has_many :comments has_many :users, :through => :test_case_to_users named_scope :broken, :conditions => [ "broken = ?", true ] named_scope :fixed, :conditions => [ "broken = ?", false ] named_scope :for_user, lambda { |user_id| { :include => :users, :conditions => ["users.id = ?", user_id ] } } end class CreateComments < ActiveRecord::Migration def self.up create_table :comments do |t| t.string :name t.string :body t.integer :test_case_id t.timestamps end end def self.down drop_table :comments end end class CreateTestCases < ActiveRecord::Migration def self.up create_table :test_cases do |t| t.string :name t.boolean :broken, :default => true t.integer :comments_count, :default => 0 t.timestamps end end def self.down drop_table :test_cases end end I''m getting the following: NoMethodError: undefined method `find'' for ActiveRecord::TestCase:Class from /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations/belongs_to_association.rb:44:in `find_target'' from /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations/association_proxy.rb:240:in `load_target'' from /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations/association_proxy.rb:112:in `reload'' from /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations.rb:1231:in `test_case'' from /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations.rb:1010:in `send'' from /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations.rb:1010:in `belongs_to_counter_cache_after_create_for_test_case'' from /Users/jimenglert/.gem/ruby/1.8/gems/activesupport-2.3.2/lib/active_support/callbacks.rb:178:in `send'' from /Users/jimenglert/.gem/ruby/1.8/gems/activesupport-2.3.2/lib/active_support/callbacks.rb:178:in `evaluate_method'' Any ideas? --~--~---------~--~----~------------~-------~--~----~ 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-/JYPxA39Uh5TLH3MbocFFw@public.gmane.org To unsubscribe from this group, send email to rubyonrails-talk+unsubscribe-/JYPxA39Uh5TLH3MbocFFw@public.gmane.org For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en -~----------~----~----~----~------~----~------~--~---
Singularize your model names: Comment & TestCase -e On Sep 10, 8:50 pm, James Englert <englert.ja...-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> wrote:> My :counter_cache column isn''t working properly. > > I wouldn''t normally ask about a relatively trivial issue like this but I''ve > been banging my head on this for a bit and haven''t gotten anywhere. I must > be missing something simple. Please take a look: > > class Comments < ActiveRecord::Base > belongs_to :test_case, :counter_cache => true > end > > class TestCases < ActiveRecord::Base > has_many :test_case_to_users > has_many :comments > has_many :users, :through => :test_case_to_users > > named_scope :broken, :conditions => [ "broken = ?", true ] > named_scope :fixed, :conditions => [ "broken = ?", false ] > named_scope :for_user, lambda { |user_id| { :include => :users, > :conditions => ["users.id = ?", user_id ] } } > end > > class CreateComments < ActiveRecord::Migration > def self.up > create_table :comments do |t| > t.string :name > t.string :body > > t.integer :test_case_id > > t.timestamps > end > end > > def self.down > drop_table :comments > end > end > > class CreateTestCases < ActiveRecord::Migration > def self.up > create_table :test_cases do |t| > t.string :name > t.boolean :broken, :default => true > > t.integer :comments_count, :default => 0 > > t.timestamps > end > end > > def self.down > drop_table :test_cases > end > end > > I''m getting the following: > > NoMethodError: undefined method `find'' for ActiveRecord::TestCase:Class > from > /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations/belongs_to_association.rb:44:in > `find_target'' > from > /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations/association_proxy.rb:240:in > `load_target'' > from > /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations/association_proxy.rb:112:in > `reload'' > from > /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations.rb:1231:in > `test_case'' > from > /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations.rb:1010:in > `send'' > from > /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations.rb:1010:in > `belongs_to_counter_cache_after_create_for_test_case'' > from > /Users/jimenglert/.gem/ruby/1.8/gems/activesupport-2.3.2/lib/active_support/callbacks.rb:178:in > `send'' > from > /Users/jimenglert/.gem/ruby/1.8/gems/activesupport-2.3.2/lib/active_support/callbacks.rb:178:in > `evaluate_method'' > > Any ideas?
Thats actually how I originally had it. I was playing around with pluralizing them as a last resort and forgot to change them back. I get the same error with: class Comment < ActiveRecord::Base belongs_to :test_case, :counter_cache => true end class TestCase < ActiveRecord::Base has_many :test_case_to_users has_many :comments has_many :users, :through => :test_case_to_users named_scope :broken, :conditions => [ "broken = ?", true ] named_scope :fixed, :conditions => [ "broken = ?", false ] named_scope :for_user, lambda { |user_id| { :include => :users, :conditions => ["users.id = ?", user_id ] } } end Sorry for the confusion, JIm On Fri, Sep 11, 2009 at 3:12 AM, Eric <ericghill-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> wrote:> > Singularize your model names: Comment & TestCase > > -e > > On Sep 10, 8:50 pm, James Englert <englert.ja...-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> wrote: > > My :counter_cache column isn''t working properly. > > > > I wouldn''t normally ask about a relatively trivial issue like this but > I''ve > > been banging my head on this for a bit and haven''t gotten anywhere. I > must > > be missing something simple. Please take a look: > > > > class Comments < ActiveRecord::Base > > belongs_to :test_case, :counter_cache => true > > end > > > > class TestCases < ActiveRecord::Base > > has_many :test_case_to_users > > has_many :comments > > has_many :users, :through => :test_case_to_users > > > > named_scope :broken, :conditions => [ "broken = ?", true ] > > named_scope :fixed, :conditions => [ "broken = ?", false ] > > named_scope :for_user, lambda { |user_id| { :include => :users, > > :conditions => ["users.id = ?", user_id ] } } > > end > > > > class CreateComments < ActiveRecord::Migration > > def self.up > > create_table :comments do |t| > > t.string :name > > t.string :body > > > > t.integer :test_case_id > > > > t.timestamps > > end > > end > > > > def self.down > > drop_table :comments > > end > > end > > > > class CreateTestCases < ActiveRecord::Migration > > def self.up > > create_table :test_cases do |t| > > t.string :name > > t.boolean :broken, :default => true > > > > t.integer :comments_count, :default => 0 > > > > t.timestamps > > end > > end > > > > def self.down > > drop_table :test_cases > > end > > end > > > > I''m getting the following: > > > > NoMethodError: undefined method `find'' for ActiveRecord::TestCase:Class > > from > > > /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations/belongs_to_association.rb:44:in > > `find_target'' > > from > > > /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations/association_proxy.rb:240:in > > `load_target'' > > from > > > /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations/association_proxy.rb:112:in > > `reload'' > > from > > > /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations.rb:1231:in > > `test_case'' > > from > > > /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations.rb:1010:in > > `send'' > > from > > > /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations.rb:1010:in > > `belongs_to_counter_cache_after_create_for_test_case'' > > from > > > /Users/jimenglert/.gem/ruby/1.8/gems/activesupport-2.3.2/lib/active_support/callbacks.rb:178:in > > `send'' > > from > > > /Users/jimenglert/.gem/ruby/1.8/gems/activesupport-2.3.2/lib/active_support/callbacks.rb:178:in > > `evaluate_method'' > > > > Any ideas? > > >--~--~---------~--~----~------------~-------~--~----~ 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-/JYPxA39Uh5TLH3MbocFFw@public.gmane.org To unsubscribe from this group, send email to rubyonrails-talk+unsubscribe-/JYPxA39Uh5TLH3MbocFFw@public.gmane.org For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en -~----------~----~----~----~------~----~------~--~---
Figured it out. TestCase is also defined by active record. It will probably be easiest to just rename it from TestCase to something else. On Fri, Sep 11, 2009 at 7:40 AM, James Englert <englert.james-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>wrote:> Thats actually how I originally had it. I was playing around with > pluralizing them as a last resort and forgot to change them back. I get the > same error with: > > class Comment < ActiveRecord::Base > belongs_to :test_case, :counter_cache => true > end > > class TestCase < ActiveRecord::Base > has_many :test_case_to_users > has_many :comments > has_many :users, :through => :test_case_to_users > > named_scope :broken, :conditions => [ "broken = ?", true ] > named_scope :fixed, :conditions => [ "broken = ?", false ] > named_scope :for_user, lambda { |user_id| { :include => :users, > :conditions => ["users.id = ?", user_id ] } } > end > > > Sorry for the confusion, > JIm > > > On Fri, Sep 11, 2009 at 3:12 AM, Eric <ericghill-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> wrote: > >> >> Singularize your model names: Comment & TestCase >> >> -e >> >> On Sep 10, 8:50 pm, James Englert <englert.ja...-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> wrote: >> > My :counter_cache column isn''t working properly. >> > >> > I wouldn''t normally ask about a relatively trivial issue like this but >> I''ve >> > been banging my head on this for a bit and haven''t gotten anywhere. I >> must >> > be missing something simple. Please take a look: >> > >> > class Comments < ActiveRecord::Base >> > belongs_to :test_case, :counter_cache => true >> > end >> > >> > class TestCases < ActiveRecord::Base >> > has_many :test_case_to_users >> > has_many :comments >> > has_many :users, :through => :test_case_to_users >> > >> > named_scope :broken, :conditions => [ "broken = ?", true ] >> > named_scope :fixed, :conditions => [ "broken = ?", false ] >> > named_scope :for_user, lambda { |user_id| { :include => :users, >> > :conditions => ["users.id = ?", user_id ] } } >> > end >> > >> > class CreateComments < ActiveRecord::Migration >> > def self.up >> > create_table :comments do |t| >> > t.string :name >> > t.string :body >> > >> > t.integer :test_case_id >> > >> > t.timestamps >> > end >> > end >> > >> > def self.down >> > drop_table :comments >> > end >> > end >> > >> > class CreateTestCases < ActiveRecord::Migration >> > def self.up >> > create_table :test_cases do |t| >> > t.string :name >> > t.boolean :broken, :default => true >> > >> > t.integer :comments_count, :default => 0 >> > >> > t.timestamps >> > end >> > end >> > >> > def self.down >> > drop_table :test_cases >> > end >> > end >> > >> > I''m getting the following: >> > >> > NoMethodError: undefined method `find'' for ActiveRecord::TestCase:Class >> > from >> > >> /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations/belongs_to_association.rb:44:in >> > `find_target'' >> > from >> > >> /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations/association_proxy.rb:240:in >> > `load_target'' >> > from >> > >> /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations/association_proxy.rb:112:in >> > `reload'' >> > from >> > >> /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations.rb:1231:in >> > `test_case'' >> > from >> > >> /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations.rb:1010:in >> > `send'' >> > from >> > >> /Library/Ruby/Gems/1.8/gems/activerecord-2.3.2/lib/active_record/associations.rb:1010:in >> > `belongs_to_counter_cache_after_create_for_test_case'' >> > from >> > >> /Users/jimenglert/.gem/ruby/1.8/gems/activesupport-2.3.2/lib/active_support/callbacks.rb:178:in >> > `send'' >> > from >> > >> /Users/jimenglert/.gem/ruby/1.8/gems/activesupport-2.3.2/lib/active_support/callbacks.rb:178:in >> > `evaluate_method'' >> > >> > Any ideas? >> >> >> >--~--~---------~--~----~------------~-------~--~----~ 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-/JYPxA39Uh5TLH3MbocFFw@public.gmane.org To unsubscribe from this group, send email to rubyonrails-talk+unsubscribe-/JYPxA39Uh5TLH3MbocFFw@public.gmane.org For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en -~----------~----~----~----~------~----~------~--~---