DEV: Make `CookedPostProcessor#post_process_images` method private.

This commit is contained in:
Guo Xiang Tan 2019-05-27 11:28:37 +08:00
parent baf7eac704
commit f54e4b71b1
2 changed files with 378 additions and 385 deletions

View File

@ -65,15 +65,6 @@ class CookedPostProcessor
BadgeGranter.grant(Badge.find(Badge::FirstReplyByEmail), @post.user, post_id: @post.id) if @post.is_reply_by_email? BadgeGranter.grant(Badge.find(Badge::FirstReplyByEmail), @post.user, post_id: @post.id) if @post.is_reply_by_email?
end end
def post_process_images
extract_images.each do |img|
unless add_image_placeholder!(img)
limit_size!(img)
convert_to_link!(img)
end
end
end
def post_process_quotes def post_process_quotes
@doc.css("aside.quote").each do |q| @doc.css("aside.quote").each do |q|
post_number = q['data-post'] post_number = q['data-post']
@ -688,6 +679,15 @@ class CookedPostProcessor
private private
def post_process_images
extract_images.each do |img|
unless add_image_placeholder!(img)
limit_size!(img)
convert_to_link!(img)
end
end
end
def process_inline_onebox(element) def process_inline_onebox(element)
inline_onebox = InlineOneboxer.lookup( inline_onebox = InlineOneboxer.lookup(
element.attributes["href"].value, element.attributes["href"].value,

View File

@ -6,11 +6,7 @@ require "file_store/s3_store"
describe CookedPostProcessor do describe CookedPostProcessor do
context "#post_process" do context "#post_process" do
fab!(:upload) do fab!(:upload) { Fabricate(:upload) }
Fabricate(:upload,
url: '/uploads/default/original/1X/1/1234567890123456.jpg'
)
end
fab!(:post) do fab!(:post) do
Fabricate(:post, raw: <<~RAW) Fabricate(:post, raw: <<~RAW)
@ -254,10 +250,8 @@ describe CookedPostProcessor do
end end
end end
end end
end
context "#post_process_images" do
context "processing images" do
before do before do
SiteSetting.responsive_post_image_sizes = "" SiteSetting.responsive_post_image_sizes = ""
end end
@ -306,8 +300,7 @@ describe CookedPostProcessor do
cpp = CookedPostProcessor.new(post) cpp = CookedPostProcessor.new(post)
cpp.add_to_size_cache(upload.url, 2000, 1500) cpp.add_to_size_cache(upload.url, 2000, 1500)
cpp.post_process_images cpp.post_process
cpp.optimize_urls
html = cpp.html html = cpp.html
@ -321,8 +314,7 @@ describe CookedPostProcessor do
cpp = CookedPostProcessor.new(post) cpp = CookedPostProcessor.new(post)
cpp.add_to_size_cache(upload.url, 2000, 1500) cpp.add_to_size_cache(upload.url, 2000, 1500)
cpp.post_process_images cpp.post_process
cpp.optimize_urls
html = cpp.html html = cpp.html
@ -348,8 +340,7 @@ describe CookedPostProcessor do
cpp = CookedPostProcessor.new(post) cpp = CookedPostProcessor.new(post)
cpp.add_to_size_cache(upload.url, 200, 4000) cpp.add_to_size_cache(upload.url, 200, 4000)
cpp.post_process_images cpp.post_process
cpp.optimize_urls
expect(cpp.html).to_not include('srcset="') expect(cpp.html).to_not include('srcset="')
end end
@ -368,8 +359,7 @@ describe CookedPostProcessor do
let(:cpp) { CookedPostProcessor.new(post, image_sizes: image_sizes) } let(:cpp) { CookedPostProcessor.new(post, image_sizes: image_sizes) }
before do before do
cpp.post_process_images cpp.post_process
cpp.optimize_urls
end end
context "valid" do context "valid" do
@ -406,7 +396,7 @@ describe CookedPostProcessor do
it "adds the width and height to images that don't have them" do it "adds the width and height to images that don't have them" do
FastImage.expects(:size).returns([123, 456]) FastImage.expects(:size).returns([123, 456])
cpp.post_process_images cpp.post_process
expect(cpp.html).to match(/width="123" height="456"/) expect(cpp.html).to match(/width="123" height="456"/)
expect(cpp).to be_dirty expect(cpp).to be_dirty
end end
@ -414,9 +404,14 @@ describe CookedPostProcessor do
end end
context "with large images" do context "with large images" do
fab!(:upload) { Fabricate(:upload) } fab!(:upload) { Fabricate(:upload) }
fab!(:post) { Fabricate(:post_with_large_image) }
fab!(:post) do
Fabricate(:post, raw: <<~HTML)
<img src="#{upload.url}">
HTML
end
let(:cpp) { CookedPostProcessor.new(post, disable_loading_image: true) } let(:cpp) { CookedPostProcessor.new(post, disable_loading_image: true) }
before do before do
@ -426,16 +421,13 @@ describe CookedPostProcessor do
end end
it "generates overlay information" do it "generates overlay information" do
Upload.expects(:get_from_url).returns(upload)
OptimizedImage.expects(:resize).returns(true) OptimizedImage.expects(:resize).returns(true)
FileStore::BaseStore.any_instance.expects(:get_depth_for).returns(0) FileStore::BaseStore.any_instance.expects(:get_depth_for).returns(0)
cpp.post_process_images cpp.post_process
cpp.optimize_urls
expect(cpp.html).to match_html <<~HTML expect(cpp.html).to match_html <<~HTML
<p><div class="lightbox-wrapper"><a class="lightbox" href="//test.localhost/uploads/default/original/1X/1234567890123456.jpg" data-download-href="//test.localhost/uploads/default/#{upload.sha1}" title="logo.png"><img src="//test.localhost/uploads/default/optimized/1X/#{upload.sha1}_#{OptimizedImage::VERSION}_690x788.png" width="690" height="788"><div class="meta"> <p><div class="lightbox-wrapper"><a class="lightbox" href="//test.localhost#{upload.url}" data-download-href="//test.localhost/uploads/default/#{upload.sha1}" title="logo.png"><img src="//test.localhost/uploads/default/optimized/1X/#{upload.sha1}_#{OptimizedImage::VERSION}_690x788.png" width="690" height="788"><div class="meta">
<svg class="fa d-icon d-icon-far-image svg-icon" aria-hidden="true"><use xlink:href="#far-image"></use></svg><span class="filename">logo.png</span><span class="informations">1750×2000 1.21 KB</span><svg class="fa d-icon d-icon-discourse-expand svg-icon" aria-hidden="true"><use xlink:href="#discourse-expand"></use></svg> <svg class="fa d-icon d-icon-far-image svg-icon" aria-hidden="true"><use xlink:href="#far-image"></use></svg><span class="filename">logo.png</span><span class="informations">1750×2000 1.21 KB</span><svg class="fa d-icon d-icon-discourse-expand svg-icon" aria-hidden="true"><use xlink:href="#discourse-expand"></use></svg>
</div></a></div></p> </div></a></div></p>
HTML HTML
@ -452,9 +444,7 @@ describe CookedPostProcessor do
end end
it 'should not add lightbox' do it 'should not add lightbox' do
cpp.post_process_oneboxes cpp.post_process
cpp.post_process_images
cpp.optimize_urls
expect(cpp.html).to match_html <<~HTML expect(cpp.html).to match_html <<~HTML
<p><img class="onebox" src="//test.localhost/uploads/default/original/1X/1234567890123456.jpg" width="690" height="788"></p> <p><img class="onebox" src="//test.localhost/uploads/default/original/1X/1234567890123456.jpg" width="690" height="788"></p>
@ -468,8 +458,7 @@ describe CookedPostProcessor do
end end
it 'should not add lightbox' do it 'should not add lightbox' do
cpp.post_process_images cpp.post_process
cpp.optimize_urls
expect(cpp.html).to match_html <<~HTML expect(cpp.html).to match_html <<~HTML
<p><img src="//test.localhost/uploads/default/original/1X/1234567890123456.svg" width="690" height="788"></p> <p><img src="//test.localhost/uploads/default/original/1X/1234567890123456.svg" width="690" height="788"></p>
@ -483,8 +472,7 @@ describe CookedPostProcessor do
it 'should not add lightbox' do it 'should not add lightbox' do
SiteSetting.crawl_images = true SiteSetting.crawl_images = true
cpp.post_process_images cpp.post_process
cpp.optimize_urls
expect(cpp.html).to match_html("<p><img src=\"http://test.discourse/uploads/default/original/1X/1234567890123456.svg?somepamas\" width=\"690\"\ height=\"788\"></p>") expect(cpp.html).to match_html("<p><img src=\"http://test.discourse/uploads/default/original/1X/1234567890123456.svg?somepamas\" width=\"690\"\ height=\"788\"></p>")
end end
@ -494,24 +482,27 @@ describe CookedPostProcessor do
end end
context "with tall images" do context "with tall images" do
fab!(:upload) { Fabricate(:upload) }
fab!(:post) do
Fabricate(:post, raw: <<~HTML)
<img src="#{upload.url}">
HTML
end
let(:upload) { Fabricate(:upload) }
let(:post) { Fabricate(:post_with_large_image) }
let(:cpp) { CookedPostProcessor.new(post, disable_loading_image: true) } let(:cpp) { CookedPostProcessor.new(post, disable_loading_image: true) }
before do before do
SiteSetting.create_thumbnails = true SiteSetting.create_thumbnails = true
Upload.expects(:get_from_url).returns(upload)
FastImage.expects(:size).returns([860, 2000]) FastImage.expects(:size).returns([860, 2000])
OptimizedImage.expects(:resize).never OptimizedImage.expects(:resize).never
OptimizedImage.expects(:crop).returns(true) OptimizedImage.expects(:crop).returns(true)
FileStore::BaseStore.any_instance.expects(:get_depth_for).returns(0) FileStore::BaseStore.any_instance.expects(:get_depth_for).returns(0)
end end
it "crops the image" do it "crops the image" do
cpp.post_process_images cpp.post_process
expect(cpp.html).to match(/width="690" height="500">/) expect(cpp.html).to match(/width="690" height="500">/)
expect(cpp).to be_dirty expect(cpp).to be_dirty
end end
@ -519,28 +510,29 @@ describe CookedPostProcessor do
end end
context "with iPhone X screenshots" do context "with iPhone X screenshots" do
fab!(:upload) { Fabricate(:upload) }
fab!(:post) do
Fabricate(:post, raw: <<~HTML)
<img src="#{upload.url}">
HTML
end
let(:upload) { Fabricate(:upload) }
let(:post) { Fabricate(:post_with_large_image) }
let(:cpp) { CookedPostProcessor.new(post, disable_loading_image: true) } let(:cpp) { CookedPostProcessor.new(post, disable_loading_image: true) }
before do before do
SiteSetting.create_thumbnails = true SiteSetting.create_thumbnails = true
Upload.expects(:get_from_url).returns(upload)
FastImage.expects(:size).returns([1125, 2436]) FastImage.expects(:size).returns([1125, 2436])
OptimizedImage.expects(:resize).returns(true) OptimizedImage.expects(:resize).returns(true)
OptimizedImage.expects(:crop).never OptimizedImage.expects(:crop).never
FileStore::BaseStore.any_instance.expects(:get_depth_for).returns(0) FileStore::BaseStore.any_instance.expects(:get_depth_for).returns(0)
end end
it "crops the image" do it "crops the image" do
cpp.post_process_images cpp.post_process
cpp.optimize_urls
expect(cpp.html).to match_html <<~HTML expect(cpp.html).to match_html <<~HTML
<p><div class="lightbox-wrapper"><a class="lightbox" href="//test.localhost/uploads/default/original/1X/1234567890123456.jpg" data-download-href="//test.localhost/uploads/default/#{upload.sha1}" title="logo.png"><img src="//test.localhost/uploads/default/optimized/1X/#{upload.sha1}_#{OptimizedImage::VERSION}_230x500.png" width="230" height="500"><div class="meta"> <p><div class="lightbox-wrapper"><a class="lightbox" href="//test.localhost#{upload.url}" data-download-href="//test.localhost/uploads/default/#{upload.sha1}" title="logo.png"><img src="//test.localhost/uploads/default/optimized/1X/#{upload.sha1}_#{OptimizedImage::VERSION}_230x500.png" width="230" height="500"><div class="meta">
<svg class="fa d-icon d-icon-far-image svg-icon" aria-hidden="true"><use xlink:href="#far-image"></use></svg><span class="filename">logo.png</span><span class="informations">1125×2436 1.21 KB</span><svg class="fa d-icon d-icon-discourse-expand svg-icon" aria-hidden="true"><use xlink:href="#discourse-expand"></use></svg> <svg class="fa d-icon d-icon-far-image svg-icon" aria-hidden="true"><use xlink:href="#far-image"></use></svg><span class="filename">logo.png</span><span class="informations">1125×2436 1.21 KB</span><svg class="fa d-icon d-icon-discourse-expand svg-icon" aria-hidden="true"><use xlink:href="#discourse-expand"></use></svg>
</div></a></div></p> </div></a></div></p>
HTML HTML
@ -551,9 +543,14 @@ describe CookedPostProcessor do
end end
context "with large images when using subfolders" do context "with large images when using subfolders" do
fab!(:upload) { Fabricate(:upload) } fab!(:upload) { Fabricate(:upload) }
fab!(:post) { Fabricate(:post_with_large_image_on_subfolder) }
fab!(:post) do
Fabricate(:post, raw: <<~HTML)
<img src="/subfolder#{upload.url}">
HTML
end
let(:cpp) { CookedPostProcessor.new(post, disable_loading_image: true) } let(:cpp) { CookedPostProcessor.new(post, disable_loading_image: true) }
let(:base_url) { "http://test.localhost/subfolder" } let(:base_url) { "http://test.localhost/subfolder" }
let(:base_uri) { "/subfolder" } let(:base_uri) { "/subfolder" }
@ -563,8 +560,6 @@ describe CookedPostProcessor do
SiteSetting.create_thumbnails = true SiteSetting.create_thumbnails = true
Discourse.stubs(:base_url).returns(base_url) Discourse.stubs(:base_url).returns(base_url)
Discourse.stubs(:base_uri).returns(base_uri) Discourse.stubs(:base_uri).returns(base_uri)
Upload.expects(:get_from_url).returns(upload)
FastImage.expects(:size).returns([1750, 2000]) FastImage.expects(:size).returns([1750, 2000])
OptimizedImage.expects(:resize).returns(true) OptimizedImage.expects(:resize).returns(true)
@ -572,11 +567,10 @@ describe CookedPostProcessor do
end end
it "generates overlay information" do it "generates overlay information" do
cpp.post_process_images cpp.post_process
cpp.optimize_urls
expect(cpp.html). to match_html <<~HTML expect(cpp.html). to match_html <<~HTML
<p><div class="lightbox-wrapper"><a class="lightbox" href="//test.localhost/subfolder/uploads/default/original/1X/1234567890123456.jpg" data-download-href="//test.localhost/subfolder/uploads/default/#{upload.sha1}" title="logo.png"><img src="//test.localhost/subfolder/uploads/default/optimized/1X/#{upload.sha1}_#{OptimizedImage::VERSION}_690x788.png" width="690" height="788"><div class="meta"> <p><div class="lightbox-wrapper"><a class="lightbox" href="//test.localhost/subfolder#{upload.url}" data-download-href="//test.localhost/subfolder/uploads/default/#{upload.sha1}" title="logo.png"><img src="//test.localhost/subfolder/uploads/default/optimized/1X/#{upload.sha1}_#{OptimizedImage::VERSION}_690x788.png" width="690" height="788"><div class="meta">
<svg class="fa d-icon d-icon-far-image svg-icon" aria-hidden="true"><use xlink:href="#far-image"></use></svg><span class="filename">logo.png</span><span class="informations">1750×2000 1.21 KB</span><svg class="fa d-icon d-icon-discourse-expand svg-icon" aria-hidden="true"><use xlink:href="#discourse-expand"></use></svg> <svg class="fa d-icon d-icon-far-image svg-icon" aria-hidden="true"><use xlink:href="#far-image"></use></svg><span class="filename">logo.png</span><span class="informations">1750×2000 1.21 KB</span><svg class="fa d-icon d-icon-discourse-expand svg-icon" aria-hidden="true"><use xlink:href="#discourse-expand"></use></svg>
</div></a></div></p> </div></a></div></p>
HTML HTML
@ -586,11 +580,10 @@ describe CookedPostProcessor do
it "should escape the filename" do it "should escape the filename" do
upload.update!(original_filename: "><img src=x onerror=alert('haha')>.png") upload.update!(original_filename: "><img src=x onerror=alert('haha')>.png")
cpp.post_process_images cpp.post_process
cpp.optimize_urls
expect(cpp.html).to match_html <<~HTML expect(cpp.html).to match_html <<~HTML
<p><div class="lightbox-wrapper"><a class="lightbox" href="//test.localhost/subfolder/uploads/default/original/1X/1234567890123456.jpg" data-download-href="//test.localhost/subfolder/uploads/default/#{upload.sha1}" title="&amp;gt;&amp;lt;img src=x onerror=alert(&amp;#39;haha&amp;#39;)&amp;gt;.png"><img src="//test.localhost/subfolder/uploads/default/optimized/1X/#{upload.sha1}_#{OptimizedImage::VERSION}_690x788.png" width="690" height="788"><div class="meta"> <p><div class="lightbox-wrapper"><a class="lightbox" href="//test.localhost/subfolder#{upload.url}" data-download-href="//test.localhost/subfolder/uploads/default/#{upload.sha1}" title="&amp;gt;&amp;lt;img src=x onerror=alert(&amp;#39;haha&amp;#39;)&amp;gt;.png"><img src="//test.localhost/subfolder/uploads/default/optimized/1X/#{upload.sha1}_#{OptimizedImage::VERSION}_690x788.png" width="690" height="788"><div class="meta">
<svg class="fa d-icon d-icon-far-image svg-icon" aria-hidden="true"><use xlink:href="#far-image"></use></svg><span class="filename">&amp;gt;&amp;lt;img src=x onerror=alert(&amp;#39;haha&amp;#39;)&amp;gt;.png</span><span class="informations">1750×2000 1.21 KB</span><svg class="fa d-icon d-icon-discourse-expand svg-icon" aria-hidden="true"><use xlink:href="#discourse-expand"></use></svg> <svg class="fa d-icon d-icon-far-image svg-icon" aria-hidden="true"><use xlink:href="#far-image"></use></svg><span class="filename">&amp;gt;&amp;lt;img src=x onerror=alert(&amp;#39;haha&amp;#39;)&amp;gt;.png</span><span class="informations">1750×2000 1.21 KB</span><svg class="fa d-icon d-icon-discourse-expand svg-icon" aria-hidden="true"><use xlink:href="#discourse-expand"></use></svg>
</div></a></div></p> </div></a></div></p>
HTML HTML
@ -599,28 +592,29 @@ describe CookedPostProcessor do
end end
context "with title" do context "with title" do
fab!(:upload) { Fabricate(:upload) }
fab!(:post) do
Fabricate(:post, raw: <<~HTML)
<img src="#{upload.url}" title="WAT">
HTML
end
let(:upload) { Fabricate(:upload) }
let(:post) { Fabricate(:post_with_large_image_and_title) }
let(:cpp) { CookedPostProcessor.new(post, disable_loading_image: true) } let(:cpp) { CookedPostProcessor.new(post, disable_loading_image: true) }
before do before do
SiteSetting.max_image_height = 2000 SiteSetting.max_image_height = 2000
SiteSetting.create_thumbnails = true SiteSetting.create_thumbnails = true
Upload.expects(:get_from_url).returns(upload)
FastImage.expects(:size).returns([1750, 2000]) FastImage.expects(:size).returns([1750, 2000])
OptimizedImage.expects(:resize).returns(true) OptimizedImage.expects(:resize).returns(true)
FileStore::BaseStore.any_instance.expects(:get_depth_for).returns(0) FileStore::BaseStore.any_instance.expects(:get_depth_for).returns(0)
end end
it "generates overlay information" do it "generates overlay information" do
cpp.post_process_images cpp.post_process
cpp.optimize_urls
expect(cpp.html).to match_html <<~HTML expect(cpp.html).to match_html <<~HTML
<p><div class="lightbox-wrapper"><a class="lightbox" href="//test.localhost/uploads/default/original/1X/1234567890123456.jpg" data-download-href="//test.localhost/uploads/default/#{upload.sha1}" title="WAT"><img src="//test.localhost/uploads/default/optimized/1X/#{upload.sha1}_#{OptimizedImage::VERSION}_690x788.png" title="WAT" width="690" height="788"><div class="meta"> <p><div class="lightbox-wrapper"><a class="lightbox" href="//test.localhost#{upload.url}" data-download-href="//test.localhost/uploads/default/#{upload.sha1}" title="WAT"><img src="//test.localhost/uploads/default/optimized/1X/#{upload.sha1}_#{OptimizedImage::VERSION}_690x788.png" title="WAT" width="690" height="788"><div class="meta">
<svg class="fa d-icon d-icon-far-image svg-icon" aria-hidden="true"><use xlink:href="#far-image"></use></svg><span class="filename">WAT</span><span class="informations">1750×2000 1.21 KB</span><svg class="fa d-icon d-icon-discourse-expand svg-icon" aria-hidden="true"><use xlink:href="#discourse-expand"></use></svg> <svg class="fa d-icon d-icon-far-image svg-icon" aria-hidden="true"><use xlink:href="#far-image"></use></svg><span class="filename">WAT</span><span class="informations">1750×2000 1.21 KB</span><svg class="fa d-icon d-icon-discourse-expand svg-icon" aria-hidden="true"><use xlink:href="#discourse-expand"></use></svg>
</div></a></div></p> </div></a></div></p>
HTML HTML
@ -638,7 +632,8 @@ describe CookedPostProcessor do
it "adds a topic image if there's one in the first post" do it "adds a topic image if there's one in the first post" do
FastImage.stubs(:size) FastImage.stubs(:size)
expect(post.topic.image_url).to eq(nil) expect(post.topic.image_url).to eq(nil)
cpp.update_post_image
cpp.post_process
post.topic.reload post.topic.reload
expect(post.topic.image_url).to be_present expect(post.topic.image_url).to be_present
end end
@ -651,12 +646,12 @@ describe CookedPostProcessor do
it "adds a post image if there's one in the post" do it "adds a post image if there's one in the post" do
FastImage.stubs(:size) FastImage.stubs(:size)
expect(reply.image_url).to eq(nil) expect(reply.image_url).to eq(nil)
cpp.update_post_image cpp.post_process
reply.reload reply.reload
expect(reply.image_url).to be_present expect(reply.image_url).to be_present
end end
end end
end
end end
context "#extract_images" do context "#extract_images" do
@ -867,9 +862,7 @@ describe CookedPostProcessor do
post.save_custom_fields post.save_custom_fields
cpp = CookedPostProcessor.new(post, invalidate_oneboxes: true) cpp = CookedPostProcessor.new(post, invalidate_oneboxes: true)
cpp.post_process_oneboxes cpp.post_process
cpp.post_process_images
cpp.optimize_urls
expect(cpp.doc.to_s).to match(/<div class="large-image-placeholder">/) expect(cpp.doc.to_s).to match(/<div class="large-image-placeholder">/)
end end