Failing test case for values not persisting after add_column #6702
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Given a migration like
both the assignment to 'body' and the save will succeed, but the value isn't written into the database, and you're left with nil values for 'body'.
(Obviously the "puts Post.inspect" is artificial - in our case, I think a plugin is loading our models prematurely, and so ActiveRecord caches the pre-migration column information)
The attached (failing) test checks that the new column's value is persisted properly. Perhaps this could be achieved by implicitly calling reset_column_information after each schema change. However, I don't care too much about that behaviour - I'd be just as happy with getting NoMethodError on trying to assign to 'body'. We were caught out and lost some production data because the model update appeared to work fine, when it was actually just dropping the values assigned to it.
See #6679 for prior discussion.