discourse/spec/lib/validators/upload_validator_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

115 lines
3.3 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
RSpec.describe UploadValidator do
subject(:validator) { described_class.new }
describe "validate" do
fab!(:user) { Fabricate(:user) }
let(:filename) { "discourse.csv" }
let(:csv_file) { file_from_fixtures(filename, "csv") }
it "should create an invalid upload when the filename is blank" do
SiteSetting.authorized_extensions = "*"
created_upload = UploadCreator.new(csv_file, nil).create_for(user.id)
validator.validate(created_upload)
expect(created_upload).to_not be_valid
2018-04-20 03:09:12 +08:00
expect(created_upload.errors.full_messages.first).to include(
I18n.t("activerecord.errors.messages.blank"),
)
end
it "allows 'gz' as extension when uploading export file" do
SiteSetting.authorized_extensions = ""
expect(
UploadCreator.new(csv_file, "#{filename}.zip", for_export: true).create_for(user.id),
).to be_valid
end
it "allows uses max_export_file_size_kb when uploading export file" do
SiteSetting.max_attachment_size_kb = "0"
SiteSetting.authorized_extensions = "zip"
expect(
UploadCreator.new(csv_file, "#{filename}.zip", for_export: true).create_for(user.id),
).to be_valid
end
describe "size validation" do
it "does not allow images that are too large" do
SiteSetting.max_image_size_kb = 1536
upload =
Fabricate.build(
:upload,
user: Fabricate(:admin),
original_filename: "test.png",
filesize: 2_097_152,
)
validator.validate(upload)
expect(upload.errors.full_messages.first).to eq(
"Filesize #{I18n.t("upload.images.too_large_humanized", max_size: "1.5 MB")}",
)
end
end
describe "when allow_staff_to_upload_any_file_in_pm is true" do
it "should allow uploads for pm" do
upload =
Fabricate.build(
:upload,
user: Fabricate(:admin),
original_filename: "test.ico",
for_private_message: true,
)
expect(validator.validate(upload)).to eq(true)
end
describe "for a normal user" do
it "should not allow uploads for pm" do
upload =
Fabricate.build(
:upload,
user: Fabricate(:user),
original_filename: "test.ico",
for_private_message: true,
)
expect(validator.validate(upload)).to eq(nil)
end
end
end
2018-11-14 15:03:02 +08:00
describe "upload for site settings" do
fab!(:user) { Fabricate(:admin) }
2018-11-14 15:03:02 +08:00
let(:upload) do
Fabricate.build(:upload, user: user, original_filename: "test.ico", for_site_setting: true)
end
before { SiteSetting.authorized_extensions = "png" }
describe "for admin user" do
it "should allow the upload" do
expect(validator.validate(upload)).to eq(true)
2018-11-14 15:03:02 +08:00
end
describe "when filename is invalid" do
it "should not allow the upload" do
upload.original_filename = "test.txt"
expect(validator.validate(upload)).to eq(nil)
2018-11-14 15:03:02 +08:00
end
end
end
describe "for normal user" do
fab!(:user) { Fabricate(:user) }
2018-11-14 15:03:02 +08:00
it "should not allow the upload" do
expect(validator.validate(upload)).to eq(nil)
2018-11-14 15:03:02 +08:00
end
end
end
end
end