2019-04-30 08:27:42 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-06-05 09:41:40 +08:00
|
|
|
require 'rails_helper'
|
|
|
|
|
|
|
|
RSpec.describe UserExport do
|
2019-05-07 11:12:20 +08:00
|
|
|
fab!(:user) { Fabricate(:user) }
|
2018-06-05 09:41:40 +08:00
|
|
|
|
|
|
|
describe '.remove_old_exports' do
|
|
|
|
it 'should remove the right records' do
|
2019-04-03 16:01:19 +08:00
|
|
|
csv_file_1 = Fabricate(:upload, created_at: 3.days.ago)
|
2018-06-05 09:41:40 +08:00
|
|
|
export = UserExport.create!(
|
|
|
|
file_name: "test",
|
|
|
|
user: user,
|
2019-04-03 16:01:19 +08:00
|
|
|
upload_id: csv_file_1.id,
|
2018-06-05 09:41:40 +08:00
|
|
|
created_at: 3.days.ago
|
|
|
|
)
|
|
|
|
|
2019-04-03 16:01:19 +08:00
|
|
|
csv_file_2 = Fabricate(:upload, created_at: 1.day.ago)
|
2018-06-05 09:41:40 +08:00
|
|
|
export2 = UserExport.create!(
|
|
|
|
file_name: "test2",
|
|
|
|
user: user,
|
2019-04-03 16:01:19 +08:00
|
|
|
upload_id: csv_file_2.id,
|
2018-06-05 09:41:40 +08:00
|
|
|
created_at: 1.day.ago
|
|
|
|
)
|
|
|
|
|
|
|
|
expect do
|
|
|
|
UserExport.remove_old_exports
|
|
|
|
end.to change { UserExport.count }.by(-1)
|
|
|
|
|
|
|
|
expect(UserExport.exists?(id: export.id)).to eq(false)
|
2019-04-03 16:01:19 +08:00
|
|
|
expect(Upload.exists?(id: csv_file_1.id)).to eq(false)
|
2018-06-05 09:41:40 +08:00
|
|
|
expect(UserExport.exists?(id: export2.id)).to eq(true)
|
2019-04-03 16:01:19 +08:00
|
|
|
expect(Upload.exists?(id: csv_file_2.id)).to eq(true)
|
2018-06-05 09:41:40 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|