DEV: Remove use of fake external store in optimized images spec.
Testing against fake stuff is bad because we're not testing against reality when reality changes.
This commit is contained in:
parent
630e9814bc
commit
20e783337d
|
@ -292,38 +292,60 @@ describe OptimizedImage do
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "external store" do
|
describe "external store" do
|
||||||
|
let(:s3_upload) { Fabricate(:upload_s3) }
|
||||||
|
|
||||||
let(:store) { FakeExternalStore.new }
|
before do
|
||||||
before { Discourse.stubs(:store).returns(store) }
|
SiteSetting.enable_s3_uploads = true
|
||||||
|
SiteSetting.s3_upload_bucket = "s3-upload-bucket"
|
||||||
|
SiteSetting.s3_access_key_id = "some key"
|
||||||
|
SiteSetting.s3_secret_access_key = "some secret key"
|
||||||
|
|
||||||
context "when an error happened while generatign the thumbnail" do
|
tempfile = Tempfile.new(["discourse-external", ".png"])
|
||||||
|
|
||||||
it "returns nil" do
|
%i{head get}.each do |method|
|
||||||
OptimizedImage.expects(:resize).returns(false)
|
stub_request(method, "http://#{s3_upload.url}")
|
||||||
expect(OptimizedImage.create_for(upload, 100, 200)).to eq(nil)
|
.to_return(
|
||||||
|
status: 200,
|
||||||
|
body: tempfile.read
|
||||||
|
)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context "when an error happened while generatign the thumbnail" do
|
||||||
|
it "returns nil" do
|
||||||
|
OptimizedImage.expects(:resize).returns(false)
|
||||||
|
expect(OptimizedImage.create_for(s3_upload, 100, 200)).to eq(nil)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context "when the thumbnail is properly generated" do
|
context "when the thumbnail is properly generated" do
|
||||||
|
|
||||||
before do
|
before do
|
||||||
OptimizedImage.expects(:resize).returns(true)
|
OptimizedImage.expects(:resize).returns(true)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "downloads a copy of the original image" do
|
it "downloads a copy of the original image" do
|
||||||
Tempfile.any_instance.expects(:close!)
|
optimized_path = "/optimized/1X/#{s3_upload.sha1}_2_100x200.png"
|
||||||
store.expects(:download).with(upload).returns(Tempfile.new(["discourse-external", ".png"]))
|
|
||||||
OptimizedImage.create_for(upload, 100, 200)
|
stub_request(
|
||||||
end
|
:head,
|
||||||
|
"https://#{SiteSetting.s3_upload_bucket}.s3.amazonaws.com/"
|
||||||
|
)
|
||||||
|
|
||||||
|
stub_request(
|
||||||
|
:put,
|
||||||
|
"https://#{SiteSetting.s3_upload_bucket}.s3.amazonaws.com#{optimized_path}"
|
||||||
|
).to_return(
|
||||||
|
status: 200,
|
||||||
|
headers: { "ETag" => "someetag" }
|
||||||
|
)
|
||||||
|
|
||||||
|
oi = OptimizedImage.create_for(s3_upload, 100, 200)
|
||||||
|
|
||||||
it "works" do
|
|
||||||
oi = OptimizedImage.create_for(upload, 100, 200)
|
|
||||||
expect(oi.sha1).to eq("da39a3ee5e6b4b0d3255bfef95601890afd80709")
|
expect(oi.sha1).to eq("da39a3ee5e6b4b0d3255bfef95601890afd80709")
|
||||||
expect(oi.extension).to eq(".png")
|
expect(oi.extension).to eq(".png")
|
||||||
expect(oi.width).to eq(100)
|
expect(oi.width).to eq(100)
|
||||||
expect(oi.height).to eq(200)
|
expect(oi.height).to eq(200)
|
||||||
expect(oi.url).to eq("/externally/stored/optimized/image.png")
|
expect(oi.url).to eq("//#{SiteSetting.s3_upload_bucket}.s3.dualstack.us-east-1.amazonaws.com#{optimized_path}")
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
@ -361,24 +383,3 @@ class FakeInternalStore
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
class FakeExternalStore
|
|
||||||
|
|
||||||
def path_for(upload)
|
|
||||||
nil
|
|
||||||
end
|
|
||||||
|
|
||||||
def external?
|
|
||||||
true
|
|
||||||
end
|
|
||||||
|
|
||||||
def store_optimized_image(file, optimized_image)
|
|
||||||
"/externally/stored/optimized/image#{optimized_image.extension}"
|
|
||||||
end
|
|
||||||
|
|
||||||
def download(upload)
|
|
||||||
extension = File.extname(upload.original_filename)
|
|
||||||
Tempfile.new(["discourse-s3", extension])
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
Loading…
Reference in New Issue