mirror of
https://github.com/discourse/discourse.git
synced 2025-01-23 00:45:16 +08:00
6e161d3e75
The most common thing that we do with fab! is: fab!(:thing) { Fabricate(:thing) } This commit adds a shorthand for this which is just simply: fab!(:thing) i.e. If you omit the block, then, by default, you'll get a `Fabricate`d object using the fabricator of the same name.
43 lines
1.4 KiB
Ruby
43 lines
1.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
RSpec.describe UserExport do
|
|
fab!(:user)
|
|
|
|
describe ".remove_old_exports" do
|
|
it "should remove the right records" do
|
|
csv_file_1 = Fabricate(:upload, created_at: 3.days.ago)
|
|
topic_1 = Fabricate(:topic, created_at: 3.days.ago)
|
|
post_1 = Fabricate(:post, topic: topic_1)
|
|
export =
|
|
UserExport.create!(
|
|
file_name: "test",
|
|
user: user,
|
|
upload_id: csv_file_1.id,
|
|
topic_id: topic_1.id,
|
|
created_at: 3.days.ago,
|
|
)
|
|
|
|
csv_file_2 = Fabricate(:upload, created_at: 1.day.ago)
|
|
topic_2 = Fabricate(:topic, created_at: 1.day.ago)
|
|
export2 =
|
|
UserExport.create!(
|
|
file_name: "test2",
|
|
user: user,
|
|
upload_id: csv_file_2.id,
|
|
topic_id: topic_2.id,
|
|
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)
|
|
expect(Upload.exists?(id: csv_file_1.id)).to eq(false)
|
|
expect(Topic.with_deleted.exists?(id: topic_1.id)).to eq(false)
|
|
expect(Post.with_deleted.exists?(id: post_1.id)).to eq(false)
|
|
expect(UserExport.exists?(id: export2.id)).to eq(true)
|
|
expect(Upload.exists?(id: csv_file_2.id)).to eq(true)
|
|
expect(Topic.exists?(id: topic_2.id)).to eq(true)
|
|
end
|
|
end
|
|
end
|