Use default og:image if Addressable::URI fails

This commit is contained in:
Anton Khorev 2024-06-15 15:57:10 +03:00
parent c03649355a
commit b97834f1fd
2 changed files with 34 additions and 1 deletions

View file

@ -6,7 +6,7 @@ module OpenGraphHelper
"og:site_name" => t("layouts.project_name.title"),
"og:title" => title || t("layouts.project_name.title"),
"og:type" => "website",
"og:image" => og_image ? Addressable::URI.join(root_url, og_image).normalize : image_url("osm_logo_256.png"),
"og:image" => og_image_url(og_image),
"og:url" => url_for(:only_path => false),
"og:description" => t("layouts.intro_text")
}
@ -15,4 +15,15 @@ module OpenGraphHelper
tag.meta(:property => property, :content => content)
end, "\n")
end
private
def og_image_url(og_image)
begin
return Addressable::URI.join(root_url, og_image).normalize if og_image
rescue Addressable::URI::InvalidURIError
# return default image
end
image_url("osm_logo_256.png")
end
end

View file

@ -744,6 +744,17 @@ class DiaryEntriesControllerTest < ActionDispatch::IntegrationTest
end
end
def test_show_og_image_with_no_image
user = create(:user)
diary_entry = create(:diary_entry, :user => user, :body => "nothing")
get diary_entry_path(user, diary_entry)
assert_response :success
assert_dom "head meta[property='og:image']" do
assert_dom "> @content", ActionController::Base.helpers.image_url("osm_logo_256.png", :host => root_url)
end
end
def test_show_og_image
user = create(:user)
diary_entry = create(:diary_entry, :user => user, :body => "![some picture](https://example.com/picture.jpg)")
@ -788,6 +799,17 @@ class DiaryEntriesControllerTest < ActionDispatch::IntegrationTest
end
end
def test_show_og_image_with_invalid_uri
user = create(:user)
diary_entry = create(:diary_entry, :user => user, :body => "![](:)")
get diary_entry_path(user, diary_entry)
assert_response :success
assert_dom "head meta[property='og:image']" do
assert_dom "> @content", ActionController::Base.helpers.image_url("osm_logo_256.png", :host => root_url)
end
end
def test_hide
user = create(:user)
diary_entry = create(:diary_entry, :user => user)