I have a model for which when I go to save an item it doesn’t seem to get saved. In the console I don’t get a “record not saved” error??? But rather the response seems to give me back a Transaction object (i.e. for which the saved Allocation object has a relationship with)? Any ideas why?
When I create a new “allocation” model object, I check it is valid OK, but when I “save!” it I just get a “nil”? What would this imply. There’s no error as such. It is true to say that I populated the non-null columns with relationship with ID’s of just “1” (i.e. didn’t ensure there was actually a matching record in their tables). Also the DB doesn’t have foreign key constraints for these relationships. Questions here:
Q1 - Does rails check to see that there is a valid object in an association present before allowing the save? (i.e. via the fact that the model has a “belongs_to” in it?
Q2 - If it does do this check what would be the expected output from Rails the object wasn’t there in the associated table (e.g. if one put manually a bad reference ID in)? Would it be “nil” as I got? There wouldn’t be a more specific exception raised? especially if one is using the “save!” method?
That's not quite the whole story. The issue that if you have
belongs_to transaction in your model that creates a transaction method
for reading the association.
This overwrites an internal method called transaction.
The internal method just runs its block inside a database transaction
and is used on saves etc... By replacing that with a transaction
method that does nothing with the block you completely neutre
activerecord.
As of Don't use the transaction instance method so that people with has_one… · rails/rails@455c7f9 · GitHub
this won't be a problem any more.
For the future should there been a way for me to have worked this out myself? i.e. without knowing the internals of Rails, but by using log information, trying things in console etc
PS. Just adding another followup question if I may:
Q1 - For the future should there been a way for me to have worked this out
myself? i.e. without knowing the internals of Rails, but by using log
information, trying things in console etc
Q2 - Is there a list of “reserved names” available somewhere one could use as a check for model names?
Q3 - Can I assume the best step for me is to just rename my model, and work this change through my code?
Q4 - Wondering if it would be a good idea to Rails to check for “bad” model names and give a warning? (similar to warnings like, you not on the optimal mysql driver)
PS. Just adding another followup question if I may:
Q1 - For the future should there been a way for me to have worked
this out myself? i.e. without knowing the internals of Rails, but
by using log information, trying things in console etc
might have found it stepping through save with the debugger. I ran
into this problem myself many moons ago and probably worked it out
like that.
Q2 - Is there a list of "reserved names" available somewhere one
could use as a check for model names?
Not that I know of.
Q3 - Can I assume the best step for me is to just rename my model,
and work this change through my code?
certainly the easiest way out, until 2.3 hits the streets.
Q4 - Wondering if it would be a good idea to Rails to check for
"bad" model names and give a warning? (similar to warnings like,
you not on the optimal mysql driver)
Rails does try (eg with dangerous attribute names)
great - interesting how I’ve been using the “transaction” model for some months but it is only since I’ve had a new model that has an association with it (i.e. the “allocation” model in this case) that I’ve noticed an issue…