moebooru: fetch tags (#3911).
This commit is contained in:
@@ -76,6 +76,12 @@ module Sources
|
|||||||
nil
|
nil
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def tags
|
||||||
|
api_response[:tags].to_s.split.map do |tag|
|
||||||
|
[tag.tr("_", " "), "https://#{site_name}/post?tags=#{CGI.escape(tag)}"]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def headers
|
def headers
|
||||||
{ "Referer" => "http://#{site_name}" }
|
{ "Referer" => "http://#{site_name}" }
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ require "test_helper"
|
|||||||
|
|
||||||
module Sources
|
module Sources
|
||||||
class MoebooruTest < ActiveSupport::TestCase
|
class MoebooruTest < ActiveSupport::TestCase
|
||||||
def assert_source_data_equals(url, referer = nil, site_name: nil, image_url: nil, page_url: nil, size: nil)
|
def assert_source_data_equals(url, referer = nil, site_name: nil, image_url: nil, page_url: nil, size: nil, tags: [])
|
||||||
site = Sources::Strategies.find(url)
|
site = Sources::Strategies.find(url)
|
||||||
|
|
||||||
assert_equal(site_name, site.site_name)
|
assert_equal(site_name, site.site_name)
|
||||||
@@ -10,6 +10,7 @@ module Sources
|
|||||||
assert_equal([image_url], site.image_urls)
|
assert_equal([image_url], site.image_urls)
|
||||||
assert_equal(image_url, site.canonical_url)
|
assert_equal(image_url, site.canonical_url)
|
||||||
assert_equal(page_url, site.page_url) if page_url.present?
|
assert_equal(page_url, site.page_url) if page_url.present?
|
||||||
|
assert_equal(tags.sort, site.tags.map(&:first).sort)
|
||||||
assert_equal(size, site.size)
|
assert_equal(size, site.size)
|
||||||
assert_nothing_raised { site.to_h }
|
assert_nothing_raised { site.to_h }
|
||||||
end
|
end
|
||||||
@@ -29,11 +30,13 @@ module Sources
|
|||||||
@samp = "https://files.yande.re/sample/7ecfdead705d7b956b26b1d37b98d089/yande.re%20482880%20sample%20bayashiko%20journey_to_the_west%20sun_wukong.jpg"
|
@samp = "https://files.yande.re/sample/7ecfdead705d7b956b26b1d37b98d089/yande.re%20482880%20sample%20bayashiko%20journey_to_the_west%20sun_wukong.jpg"
|
||||||
@full = "https://files.yande.re/image/7ecfdead705d7b956b26b1d37b98d089/yande.re%20482880.jpg"
|
@full = "https://files.yande.re/image/7ecfdead705d7b956b26b1d37b98d089/yande.re%20482880.jpg"
|
||||||
@page = "https://yande.re/post/show/482880"
|
@page = "https://yande.re/post/show/482880"
|
||||||
|
@tags = ["bayashiko", "journey to the west", "sun wukong"]
|
||||||
@size = 362_554
|
@size = 362_554
|
||||||
|
@data = { site_name: "yande.re", image_url: @full, page_url: @page, size: @size, tags: @tags}
|
||||||
|
|
||||||
assert_source_data_equals(@samp, site_name: "yande.re", image_url: @full, page_url: @page, size: @size)
|
assert_source_data_equals(@samp, @data)
|
||||||
assert_source_data_equals(@full, site_name: "yande.re", image_url: @full, page_url: @page, size: @size)
|
assert_source_data_equals(@full, @data)
|
||||||
assert_source_data_equals(@page, site_name: "yande.re", image_url: @full, page_url: @page, size: @size)
|
assert_source_data_equals(@page, @data)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -43,12 +46,14 @@ module Sources
|
|||||||
@jpeg = "https://files.yande.re/sample/fb27a7ea6c48b2ef76fe915e378b9098/yande.re%20398018%20detexted%20misaki_kurehito%20saenai_heroine_no_sodatekata%20sawamura_spencer_eriri%20thighhighs.jpg"
|
@jpeg = "https://files.yande.re/sample/fb27a7ea6c48b2ef76fe915e378b9098/yande.re%20398018%20detexted%20misaki_kurehito%20saenai_heroine_no_sodatekata%20sawamura_spencer_eriri%20thighhighs.jpg"
|
||||||
@full = "https://files.yande.re/image/fb27a7ea6c48b2ef76fe915e378b9098/yande.re%20398018.png"
|
@full = "https://files.yande.re/image/fb27a7ea6c48b2ef76fe915e378b9098/yande.re%20398018.png"
|
||||||
@page = "https://yande.re/post/show/398018"
|
@page = "https://yande.re/post/show/398018"
|
||||||
|
@tags = ["misaki kurehito", "saenai heroine no sodatekata", "sawamura spencer eriri", "detexted", "thighhighs"]
|
||||||
@size = 9_118_998
|
@size = 9_118_998
|
||||||
|
@data = { site_name: "yande.re", image_url: @full, page_url: @page, size: @size, tags: @tags}
|
||||||
|
|
||||||
assert_source_data_equals(@samp, site_name: "yande.re", image_url: @full, page_url: @page, size: @size)
|
assert_source_data_equals(@samp, @data)
|
||||||
assert_source_data_equals(@jpeg, site_name: "yande.re", image_url: @full, page_url: @page, size: @size)
|
assert_source_data_equals(@jpeg, @data)
|
||||||
assert_source_data_equals(@full, site_name: "yande.re", image_url: @full, page_url: @page, size: @size)
|
assert_source_data_equals(@full, @data)
|
||||||
assert_source_data_equals(@page, site_name: "yande.re", image_url: @full, page_url: @page, size: @size)
|
assert_source_data_equals(@page, @data)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -57,11 +62,13 @@ module Sources
|
|||||||
@samp = "https://files.yande.re/sample/fb27a7ea6c48b2ef76fe915e378b9098.jpg"
|
@samp = "https://files.yande.re/sample/fb27a7ea6c48b2ef76fe915e378b9098.jpg"
|
||||||
@jpeg = "https://files.yande.re/jpeg/fb27a7ea6c48b2ef76fe915e378b9098.jpg"
|
@jpeg = "https://files.yande.re/jpeg/fb27a7ea6c48b2ef76fe915e378b9098.jpg"
|
||||||
@full = "https://files.yande.re/image/fb27a7ea6c48b2ef76fe915e378b9098.png"
|
@full = "https://files.yande.re/image/fb27a7ea6c48b2ef76fe915e378b9098.png"
|
||||||
|
@tags = []
|
||||||
@size = 9_118_998
|
@size = 9_118_998
|
||||||
|
@data = { site_name: "yande.re", image_url: @full, page_url: @page, size: @size, tags: @tags}
|
||||||
|
|
||||||
assert_source_data_equals(@samp, site_name: "yande.re", image_url: @full, size: @size)
|
assert_source_data_equals(@samp, @data)
|
||||||
assert_source_data_equals(@jpeg, site_name: "yande.re", image_url: @full, size: @size)
|
assert_source_data_equals(@jpeg, @data)
|
||||||
assert_source_data_equals(@full, site_name: "yande.re", image_url: @full, size: @size)
|
assert_source_data_equals(@full, @data)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -74,11 +81,17 @@ module Sources
|
|||||||
@full = "https://konachan.com/image/ca12cdb79a66d242e95a6f958341bf05/Konachan.com%20-%20270916.png"
|
@full = "https://konachan.com/image/ca12cdb79a66d242e95a6f958341bf05/Konachan.com%20-%20270916.png"
|
||||||
@page = "https://konachan.com/post/show/270916"
|
@page = "https://konachan.com/post/show/270916"
|
||||||
@size = 8_167_593
|
@size = 8_167_593
|
||||||
|
@tags = %w[
|
||||||
|
anthropomorphism bed blonde_hair bow brown_eyes doll
|
||||||
|
girls_frontline hara_shoutarou hoodie long_hair pantyhose scar skirt
|
||||||
|
twintails ump-45_(girls_frontline) ump-9_(girls_frontline)
|
||||||
|
].map { |tag| tag.tr("_", " ") }
|
||||||
|
|
||||||
assert_source_data_equals(@samp, site_name: "konachan.com", image_url: @full, page_url: @page, size: @size)
|
@data = { site_name: "konachan.com", image_url: @full, page_url: @page, size: @size, tags: @tags}
|
||||||
assert_source_data_equals(@jpeg, site_name: "konachan.com", image_url: @full, page_url: @page, size: @size)
|
assert_source_data_equals(@samp, @data)
|
||||||
assert_source_data_equals(@full, site_name: "konachan.com", image_url: @full, page_url: @page, size: @size)
|
assert_source_data_equals(@jpeg, @data)
|
||||||
assert_source_data_equals(@page, site_name: "konachan.com", image_url: @full, page_url: @page, size: @size)
|
assert_source_data_equals(@full, @data)
|
||||||
|
assert_source_data_equals(@page, @data)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
Reference in New Issue
Block a user