Sha256: dfc81cfbb4c56f7b524a16fafeeb9200964e42ef18489eb162f3960e991c65b7

Contents?: true

Size: 1.3 KB

Versions: 6

Compression:

Stored size: 1.3 KB

Contents

require 'test_helper'

class TimestampTest < ActiveSupport::TestCase

  setup do
    PaperTrail.timestamp_field = :custom_created_at
    change_schema
    PaperTrail::Version.connection.schema_cache.clear!
    PaperTrail::Version.reset_column_information

    Fluxor.instance_eval <<-END
      has_paper_trail
    END

    @fluxor = Fluxor.create :name => 'Some text.'
    @fluxor.update_attributes :name => 'Some more text.'
    @fluxor.update_attributes :name => 'Even more text.'
  end

  teardown do
    PaperTrail.timestamp_field = :created_at
  end

  test 'versions works with custom timestamp field' do
    # Normal behaviour
    assert_equal 3, @fluxor.versions.length
    assert_nil @fluxor.versions[0].reify
    assert_equal 'Some text.', @fluxor.versions[1].reify.name
    assert_equal 'Some more text.', @fluxor.versions[2].reify.name

    # Tinker with custom timestamps.
    now = Time.now.utc
    @fluxor.versions.reverse.each_with_index do |version, index|
      version.update_attribute :custom_created_at, (now + index.seconds)
    end

    # Test we are ordering by custom timestamps.
    @fluxor.versions true  # reload association
    assert_nil @fluxor.versions[2].reify
    assert_equal 'Some text.', @fluxor.versions[1].reify.name
    assert_equal 'Some more text.', @fluxor.versions[0].reify.name
  end

end

Version data entries

6 entries across 6 versions & 2 rubygems

Version Path
paper_trail-3.0.1 test/unit/timestamp_test.rb
paper_trail-3.0.0 test/unit/timestamp_test.rb
paper_trail-3.0.0.rc2 test/unit/timestamp_test.rb
paper_trail-3.0.0.rc1 test/unit/timestamp_test.rb
paper_trail_without_deprecated-3.0.0.beta1 test/unit/timestamp_test.rb
paper_trail-3.0.0.beta1 test/unit/timestamp_test.rb