-
Notifications
You must be signed in to change notification settings - Fork 189
/
Copy pathdatabase_rake_test.rb
69 lines (54 loc) · 2.24 KB
/
database_rake_test.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
require 'helper'
require 'rake'
module ActiveRecord
module SessionStore
class DatabaseRakeTest < ActiveSupport::TestCase
migration_class = ActiveRecord::VERSION::MAJOR < 5 ? ActiveRecord::Migration : ActiveRecord::Migration[4.2]
class AddTimestampsToSession < migration_class
self.verbose = false
def change
add_column Session.table_name, :created_at, :datetime
add_column Session.table_name, :updated_at, :datetime
end
end
def setup
Session.drop_table! if Session.table_exists?
Session.create_table!
AddTimestampsToSession.new.exec_migration(ActiveRecord::Base.connection, :up)
Session.connection.schema_cache.clear!
Session.reset_column_information
Rake.application.rake_require "tasks/database"
Rake::Task.tasks.each(&:reenable)
Rake::Task.define_task(:environment)
Rake::Task.define_task("db:load_config")
end
def teardown
Session.drop_table! if Session.table_exists?
Session.connection.schema_cache.clear!
Session.reset_column_information
end
def test_trim_task
cutoff_period = 30.days.ago
Session.create!(data: "obsolete") do |session|
session.updated_at = 5.minutes.until(cutoff_period)
end
recent_session = Session.create!(data: "recent") do |session|
session.updated_at = 5.minutes.since(cutoff_period)
end
Rake.application.invoke_task 'db:sessions:trim'
old_session_count = Session.where("updated_at < ?", cutoff_period).count
retained_session = Session.find(recent_session.id)
assert_equal 0, old_session_count
assert_equal retained_session, recent_session
end
def test_upgrade_task
Session.create!(session_id: "original_session_id", data: "data")
Session.create!(session_id: "2::secure_session_id", data: "data")
Rake.application.invoke_task 'db:sessions:upgrade'
assert_nil Session.find_by_session_id("original_session_id")
assert Session.find_by_session_id(Rack::Session::SessionId.new("original_session_id").private_id)
assert Session.find_by_session_id("2::secure_session_id")
end
end
end
end