mirror of
https://github.com/paper-trail-gem/paper_trail.git
synced 2022-11-09 11:33:19 -05:00
2b479a7f08
* Change update_attributes to update In Rails 6.0 update_attributes/update_attributes! is considered deprecated. Method update/update! is the replacement. * CI: Don't use Bundler 1.16.1 - Bundler 1.16.1 has bug where dependencies can't be resolved properly when a gem is a release candidate or an alpha version. The underlying bundler issue can be found here https://github.com/bundler/bundler/issues/6449 * Disable eager_load in test env: - In Rails 6.0, rails/rails@3b95478 made a change to eagerly define attribute methods of a Model when `eager_load` is enabled. This breaks our test suite because of the way we run migration. The TL;DR is that doing `People.attribute_names` will return an empty array instead of `[:id, time_zone, ...]`. You can find a failing build here https://travis-ci.org/paper-trail-gem/paper_trail/jobs/463369634 Basically what happens is: 1) The dummy app boot, attribute methods of each model are defined but since migration didn't run yet, the tables aren't even created resulting in a empty attribute set. 2) Migration runs, but it's already too late. In this commit I disabled eager_loading in test, AFAIT there isn't much benefit in eager_loading the dummy app anyway. Also renaming the `user.rb` file to `postgres_user.rb` in order for rails autoloading to work correctly.
42 lines
1.3 KiB
Ruby
42 lines
1.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require "spec_helper"
|
|
|
|
RSpec.describe LegacyWidget, type: :model, versioning: true do
|
|
describe "#custom_version" do
|
|
it "knows which version it came from" do
|
|
widget = described_class.create(name: "foo", version: 2)
|
|
%w[bar baz].each { |name| widget.update(name: name) }
|
|
version = widget.versions.last
|
|
reified = version.reify
|
|
expect(reified.custom_version).to(eq(version))
|
|
end
|
|
end
|
|
|
|
describe "#previous_version" do
|
|
it "return its previous self" do
|
|
widget = described_class.create(name: "foo", version: 2)
|
|
%w[bar baz].each { |name| widget.update(name: name) }
|
|
version = widget.versions.last
|
|
reified = version.reify
|
|
expect(reified.paper_trail.previous_version).to(eq(reified.versions[-2].reify))
|
|
end
|
|
end
|
|
|
|
describe "#update" do
|
|
it "does not create a PT version record because the updated column is ignored" do
|
|
described_class.create.update(version: 1)
|
|
expect(PaperTrail::Version.count).to(eq(1))
|
|
end
|
|
end
|
|
|
|
describe "#version" do
|
|
it "is a normal attribute and has nothing to do with PT" do
|
|
widget = described_class.create(name: "foo", version: 2)
|
|
expect(widget.versions.size).to(eq(1))
|
|
expect(widget.version).to(eq(2))
|
|
widget.update(version: 3)
|
|
expect(widget.version).to(eq(3))
|
|
end
|
|
end
|
|
end
|