On Sunday, 17 August 2014 21:57:05 UTC-4, Phil wrote:
>
>
> I hate to reply to myself, but I narrowed it down to Rails caching by
> DEFAULT of model queries. It can be worked around by passing 'true', like
> this:
>
>
> tc.name = "something different"
>
> tc.save!
>
> tp.test_children.map {|x| x.name }.to_sentence # => "test1, test2, test3,
> and test4" *WRONG*
>
> tp.test_children(true).map {|x| x.name }.to_sentence # => "test1, test2,
> test3, and something different" *CORRECT*
>
>
> Another workaround is to just stop using has_many and such in favor of
> manual functions, a la:
>
> def test_children
>
> return TestChild.where(["test_parent_id = ?", self.id])
>
> end
>
>
> Is there a way to turn this sort of caching off globally? (Other caching
> is fine, I don't want to turn all caching off.)
>
>
> BTW- It is a bit mind blowing that this is turned on by default. Possible
> data corruption shouldn't ever be preferred by default over (possible)
> speed gains. I'd still categorize this as a serious bug, at least as a
> configuration default.
>
>
>
The cleanest way to deal with this is to *use* the association. Instead of:
tc = TestChild.new(:name => "test4", :test_parent_id => tp.id)
do:
tp.test_children.new(:name => "test4")
This will correctly reflect the new record when subsequently calling
`tp.test_children`.
--Matt Jones
--
You received this message because you are subscribed to the Google Groups "Ruby
on Rails: Talk" group.
To unsubscribe from this group and stop receiving emails from it, send an email
to [email protected].
To post to this group, send email to [email protected].
To view this discussion on the web visit
https://groups.google.com/d/msgid/rubyonrails-talk/e1a05cf0-ed96-43f1-ac2f-dba617c42921%40googlegroups.com.
For more options, visit https://groups.google.com/d/optout.