2019-07-17 19:07:10 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2022-07-27 22:27:38 -04:00
|
|
|
RSpec.describe BackupRestore::Backuper do
|
2023-03-14 12:07:18 -04:00
|
|
|
describe "#get_parameterized_title" do
|
|
|
|
it "returns a non-empty parameterized title when site title contains unicode" do
|
|
|
|
SiteSetting.title = "Ɣ"
|
|
|
|
backuper = BackupRestore::Backuper.new(Discourse.system_user.id)
|
2019-07-17 19:07:10 -04:00
|
|
|
|
2023-03-14 12:07:18 -04:00
|
|
|
expect(backuper.send(:get_parameterized_title)).to eq("discourse")
|
|
|
|
end
|
2019-07-17 19:07:10 -04:00
|
|
|
|
2023-03-14 12:07:18 -04:00
|
|
|
it "returns a valid parameterized site title" do
|
|
|
|
SiteSetting.title = "Coding Horror"
|
|
|
|
backuper = BackupRestore::Backuper.new(Discourse.system_user.id)
|
2019-07-17 19:07:10 -04:00
|
|
|
|
2023-03-14 12:07:18 -04:00
|
|
|
expect(backuper.send(:get_parameterized_title)).to eq("coding-horror")
|
|
|
|
end
|
2019-07-17 19:07:10 -04:00
|
|
|
end
|
2021-08-03 13:06:50 -04:00
|
|
|
|
|
|
|
describe "#notify_user" do
|
|
|
|
before { freeze_time Time.zone.parse("2010-01-01 12:00") }
|
|
|
|
|
|
|
|
it "includes logs if short" do
|
|
|
|
SiteSetting.max_export_file_size_kb = 1
|
|
|
|
SiteSetting.export_authorized_extensions = "tar.gz"
|
|
|
|
|
|
|
|
silence_stdout do
|
|
|
|
backuper = BackupRestore::Backuper.new(Discourse.system_user.id)
|
|
|
|
|
|
|
|
expect { backuper.send(:notify_user) }.to change { Topic.private_messages.count }.by(
|
2023-01-09 06:18:21 -05:00
|
|
|
1,
|
2022-07-19 10:03:03 -04:00
|
|
|
).and not_change { Upload.count }
|
2021-08-03 13:06:50 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
expect(Topic.last.first_post.raw).to include(
|
|
|
|
"```text\n[2010-01-01 12:00:00] Notifying 'system' of the end of the backup...\n```",
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "include upload if log is long" do
|
|
|
|
SiteSetting.max_post_length = 250
|
|
|
|
|
|
|
|
silence_stdout do
|
2022-01-09 14:26:52 -05:00
|
|
|
backuper = BackupRestore::Backuper.new(Discourse.system_user.id)
|
2021-08-03 13:06:50 -04:00
|
|
|
|
|
|
|
expect { backuper.send(:notify_user) }.to change { Topic.private_messages.count }.by(
|
2023-01-09 06:18:21 -05:00
|
|
|
1,
|
2021-08-03 13:06:50 -04:00
|
|
|
).and change { Upload.where(original_filename: "log.txt.zip").count }.by(1)
|
|
|
|
end
|
|
|
|
|
|
|
|
expect(Topic.last.first_post.raw).to include("[log.txt.zip|attachment]")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "includes trimmed logs if log is long and upload cannot be saved" do
|
|
|
|
SiteSetting.max_post_length = 348
|
|
|
|
SiteSetting.max_export_file_size_kb = 1
|
|
|
|
SiteSetting.export_authorized_extensions = "tar.gz"
|
|
|
|
|
|
|
|
silence_stdout do
|
|
|
|
backuper = BackupRestore::Backuper.new(Discourse.system_user.id)
|
|
|
|
|
|
|
|
1.upto(10).each { |i| backuper.send(:log, "Line #{i}") }
|
|
|
|
|
|
|
|
expect { backuper.send(:notify_user) }.to change { Topic.private_messages.count }.by(
|
2023-01-09 06:18:21 -05:00
|
|
|
1,
|
2022-07-19 10:03:03 -04:00
|
|
|
).and not_change { Upload.count }
|
2021-08-03 13:06:50 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
expect(Topic.last.first_post.raw).to include(
|
|
|
|
"```text\n...\n[2010-01-01 12:00:00] Line 10\n[2010-01-01 12:00:00] Notifying 'system' of the end of the backup...\n```",
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
2023-03-14 12:07:18 -04:00
|
|
|
|
|
|
|
describe "#run" do
|
|
|
|
subject(:run) { backup.run }
|
|
|
|
|
|
|
|
let(:backup) { described_class.new(user.id) }
|
|
|
|
let(:user) { Discourse.system_user }
|
|
|
|
let(:store) { backup.store }
|
|
|
|
|
|
|
|
before { backup.stubs(:success).returns(success) }
|
|
|
|
|
|
|
|
context "when the result is successful" do
|
|
|
|
let(:success) { true }
|
|
|
|
it "refreshes disk stats" do
|
2023-12-13 13:00:27 -05:00
|
|
|
store.expects(:reset_cache).at_least_once
|
|
|
|
run
|
|
|
|
end
|
|
|
|
it "deletes any old backups" do
|
|
|
|
store.expects(:delete_prior_to_n_days)
|
2023-03-14 12:07:18 -04:00
|
|
|
run
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2019-07-17 19:07:10 -04:00
|
|
|
end
|