rails--rails/activemodel/CHANGELOG.md

74 lines
3.0 KiB
Markdown
Raw Normal View History

2020-11-02 21:12:47 +00:00
## Rails 6.1.0.rc1 (November 02, 2020) ##
2020-10-22 19:45:53 +00:00
* Pass in `base` instead of `base_class` to Error.human_attribute_name
This is useful in cases where the `human_attribute_name` method depends
on other attributes' values of the class under validation to derive what the
2020-11-02 18:16:45 +00:00
attribute name should be.
*Filipe Sabella*
2020-10-22 19:45:53 +00:00
* Deprecate marshalling load from legacy attributes format.
*Ryuta Kamizono*
* `*_previously_changed?` accepts `:from` and `:to` keyword arguments like `*_changed?`.
topic.update!(status: :archived)
topic.status_previously_changed?(from: "active", to: "archived")
# => true
*George Claghorn*
* Raise FrozenError when trying to write attributes that aren't backed by the database on an object that is frozen:
class Animal
2019-11-24 00:20:00 +00:00
include ActiveModel::Attributes
attribute :age
end
2019-11-24 00:20:00 +00:00
animal = Animal.new
2019-11-24 00:20:00 +00:00
animal.freeze
animal.age = 25 # => FrozenError, "can't modify a frozen Animal"
2019-11-24 00:20:00 +00:00
*Josh Brody*
2020-02-25 05:14:54 +00:00
* Add `*_previously_was` attribute methods when dirty tracking. Example:
pirate.update(catchphrase: "Ahoy!")
pirate.previous_changes["catchphrase"] # => ["Thar She Blows!", "Ahoy!"]
pirate.catchphrase_previously_was # => "Thar She Blows!"
*DHH*
* Encapsulate each validation error as an Error object.
2020-04-15 12:23:24 +00:00
The `ActiveModel`s `errors` collection is now an array of these Error
objects, instead of messages/details hash.
2020-04-15 12:23:24 +00:00
For each of these `Error` object, its `message` and `full_message` methods
are for generating error messages. Its `details` method would return errors
extra parameters, found in the original `details` hash.
2020-04-15 12:23:24 +00:00
The change tries its best at maintaining backward compatibility, however
some edge cases wont be covered, like `errors#first` will return `ActiveModel::Error` and manipulating
`errors.messages` and `errors.details` hashes directly will have no effect. Moving forward,
please convert those direct manipulations to use provided API methods instead.
2020-01-14 16:17:23 +00:00
The list of deprecated methods and their planned future behavioral changes at the next major release are:
* `errors#slice!` will be removed.
* `errors#each` with the `key, value` two-arguments block will stop working, while the `error` single-argument block would return `Error` object.
* `errors#values` will be removed.
* `errors#keys` will be removed.
* `errors#to_xml` will be removed.
* `errors#to_h` will be removed, and can be replaced with `errors#to_hash`.
* Manipulating `errors` itself as a hash will have no effect (e.g. `errors[:foo] = 'bar'`).
* Manipulating the hash returned by `errors#messages` (e.g. `errors.messages[:foo] = 'bar'`) will have no effect.
* Manipulating the hash returned by `errors#details` (e.g. `errors.details[:foo].clear`) will have no effect.
*lulalala*
2019-11-24 00:20:00 +00:00
2020-04-15 12:23:24 +00:00
2019-04-24 19:57:14 +00:00
Please check [6-0-stable](https://github.com/rails/rails/blob/6-0-stable/activemodel/CHANGELOG.md) for previous changes.