mirror of
https://github.com/mikf/gallery-dl.git
synced 2024-11-25 04:02:32 +01:00
remove extractor/test.py (#4504)
This commit is contained in:
parent
fde9e25c9f
commit
8a11b72253
@ -194,7 +194,6 @@ modules = [
|
|||||||
"directlink",
|
"directlink",
|
||||||
"recursive",
|
"recursive",
|
||||||
"oauth",
|
"oauth",
|
||||||
"test",
|
|
||||||
"ytdl",
|
"ytdl",
|
||||||
"generic",
|
"generic",
|
||||||
]
|
]
|
||||||
|
@ -1,81 +0,0 @@
|
|||||||
# -*- coding: utf-8 -*-
|
|
||||||
|
|
||||||
# Copyright 2016-2023 Mike Fährmann
|
|
||||||
#
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License version 2 as
|
|
||||||
# published by the Free Software Foundation.
|
|
||||||
|
|
||||||
"""Utility extractor to execute tests of other extractors"""
|
|
||||||
|
|
||||||
from .common import Extractor, Message
|
|
||||||
from .. import extractor, exception
|
|
||||||
|
|
||||||
|
|
||||||
class TestExtractor(Extractor):
|
|
||||||
"""Extractor to select and run the test URLs of other extractors
|
|
||||||
|
|
||||||
The general form is 'test:<categories>:<subcategories>:<indices>', where
|
|
||||||
<categories> and <subcategories> are comma-separated (sub)category names
|
|
||||||
and <indices> is a comma-seperated list of array indices.
|
|
||||||
To select all possible values for a field use the star '*' character or
|
|
||||||
leave the field empty.
|
|
||||||
|
|
||||||
Examples:
|
|
||||||
- test:pixiv
|
|
||||||
run all pixiv tests
|
|
||||||
|
|
||||||
- test:pixiv:user,favorite:0
|
|
||||||
run the first test of the PixivUser- and PixivFavoriteExtractor
|
|
||||||
|
|
||||||
- test:
|
|
||||||
run all tests
|
|
||||||
"""
|
|
||||||
category = "test"
|
|
||||||
pattern = r"t(?:est)?:([^:]*)(?::([^:]*)(?::(\*|[\d,]*))?)?$"
|
|
||||||
example = "test:CATEGORY"
|
|
||||||
|
|
||||||
def __init__(self, match):
|
|
||||||
Extractor.__init__(self, match)
|
|
||||||
categories, subcategories, indices = match.groups()
|
|
||||||
self.categories = self._split(categories)
|
|
||||||
self.subcategories = self._split(subcategories)
|
|
||||||
self.indices = self._split(indices) or self
|
|
||||||
|
|
||||||
def items(self):
|
|
||||||
extractors = extractor.extractors()
|
|
||||||
|
|
||||||
if self.categories:
|
|
||||||
extractors = [
|
|
||||||
extr for extr in extractors
|
|
||||||
if extr.category in self.categories
|
|
||||||
]
|
|
||||||
|
|
||||||
if self.subcategories:
|
|
||||||
extractors = [
|
|
||||||
extr for extr in extractors
|
|
||||||
if extr.subcategory in self.subcategories
|
|
||||||
]
|
|
||||||
|
|
||||||
tests = [
|
|
||||||
test
|
|
||||||
for extr in extractors
|
|
||||||
for index, test in enumerate(extr._get_tests())
|
|
||||||
if str(index) in self.indices
|
|
||||||
]
|
|
||||||
|
|
||||||
if not tests:
|
|
||||||
raise exception.NotFoundError("test")
|
|
||||||
|
|
||||||
for test in tests:
|
|
||||||
yield Message.Queue, test[0], {}
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def __contains__(_):
|
|
||||||
return True
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def _split(value):
|
|
||||||
if value and value != "*":
|
|
||||||
return value.split(",")
|
|
||||||
return None
|
|
@ -563,7 +563,7 @@ WINDOWS = (os.name == "nt")
|
|||||||
SENTINEL = object()
|
SENTINEL = object()
|
||||||
USERAGENT = "gallery-dl/" + version.__version__
|
USERAGENT = "gallery-dl/" + version.__version__
|
||||||
EXECUTABLE = getattr(sys, "frozen", False)
|
EXECUTABLE = getattr(sys, "frozen", False)
|
||||||
SPECIAL_EXTRACTORS = {"oauth", "recursive", "test"}
|
SPECIAL_EXTRACTORS = {"oauth", "recursive", "generic"}
|
||||||
GLOBALS = {
|
GLOBALS = {
|
||||||
"contains" : contains,
|
"contains" : contains,
|
||||||
"parse_int": text.parse_int,
|
"parse_int": text.parse_int,
|
||||||
|
@ -1,29 +0,0 @@
|
|||||||
# -*- coding: utf-8 -*-
|
|
||||||
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License version 2 as
|
|
||||||
# published by the Free Software Foundation.
|
|
||||||
|
|
||||||
from gallery_dl.extractor import test
|
|
||||||
|
|
||||||
|
|
||||||
__tests__ = (
|
|
||||||
{
|
|
||||||
"#url" : "test:pixiv",
|
|
||||||
"#category": ("", "test", ""),
|
|
||||||
"#class" : test.TestExtractor,
|
|
||||||
},
|
|
||||||
|
|
||||||
{
|
|
||||||
"#url" : "test:pixiv:user,favorite:0",
|
|
||||||
"#category": ("", "test", ""),
|
|
||||||
"#class" : test.TestExtractor,
|
|
||||||
},
|
|
||||||
|
|
||||||
{
|
|
||||||
"#url" : "test:",
|
|
||||||
"#category": ("", "test", ""),
|
|
||||||
"#class" : test.TestExtractor,
|
|
||||||
},
|
|
||||||
|
|
||||||
)
|
|
@ -63,7 +63,7 @@ class TestCookiejar(unittest.TestCase):
|
|||||||
|
|
||||||
def _test_warning(self, filename, exc):
|
def _test_warning(self, filename, exc):
|
||||||
config.set((), "cookies", filename)
|
config.set((), "cookies", filename)
|
||||||
log = logging.getLogger("test")
|
log = logging.getLogger("generic")
|
||||||
|
|
||||||
with mock.patch.object(log, "warning") as mock_warning:
|
with mock.patch.object(log, "warning") as mock_warning:
|
||||||
cookies = _get_extractor("test").cookies
|
cookies = _get_extractor("test").cookies
|
||||||
@ -173,7 +173,7 @@ class TestCookieUtils(unittest.TestCase):
|
|||||||
self.assertFalse(extr.cookies_domain, "empty")
|
self.assertFalse(extr.cookies_domain, "empty")
|
||||||
|
|
||||||
now = int(time.time())
|
now = int(time.time())
|
||||||
log = logging.getLogger("test")
|
log = logging.getLogger("generic")
|
||||||
|
|
||||||
extr.cookies.set("a", "1", expires=now-100)
|
extr.cookies.set("a", "1", expires=now-100)
|
||||||
with mock.patch.object(log, "warning") as mw:
|
with mock.patch.object(log, "warning") as mw:
|
||||||
@ -212,7 +212,7 @@ URLS = {
|
|||||||
"idolcomplex": "https://idol.sankakucomplex.com/post/show/1",
|
"idolcomplex": "https://idol.sankakucomplex.com/post/show/1",
|
||||||
"nijie" : "https://nijie.info/view.php?id=1",
|
"nijie" : "https://nijie.info/view.php?id=1",
|
||||||
"horne" : "https://horne.red/view.php?id=1",
|
"horne" : "https://horne.red/view.php?id=1",
|
||||||
"test" : "test:",
|
"test" : "generic:https://example.org/",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -33,7 +33,7 @@ class MockDownloaderModule(Mock):
|
|||||||
class FakeJob():
|
class FakeJob():
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.extractor = extractor.find("test:")
|
self.extractor = extractor.find("generic:https://example.org/")
|
||||||
self.extractor.initialize()
|
self.extractor.initialize()
|
||||||
self.pathfmt = path.PathFormat(self.extractor)
|
self.pathfmt = path.PathFormat(self.extractor)
|
||||||
self.out = output.NullOutput()
|
self.out = output.NullOutput()
|
||||||
|
@ -45,7 +45,7 @@ class TestExtractorModule(unittest.TestCase):
|
|||||||
"https://example.org/file.jpg",
|
"https://example.org/file.jpg",
|
||||||
"tumblr:foobar",
|
"tumblr:foobar",
|
||||||
"oauth:flickr",
|
"oauth:flickr",
|
||||||
"test:pixiv:",
|
"generic:https://example.org/",
|
||||||
"recursive:https://example.org/document.html",
|
"recursive:https://example.org/document.html",
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -208,7 +208,7 @@ class TestExtractorModule(unittest.TestCase):
|
|||||||
class TestExtractorWait(unittest.TestCase):
|
class TestExtractorWait(unittest.TestCase):
|
||||||
|
|
||||||
def test_wait_seconds(self):
|
def test_wait_seconds(self):
|
||||||
extr = extractor.find("test:")
|
extr = extractor.find("generic:https://example.org/")
|
||||||
seconds = 5
|
seconds = 5
|
||||||
until = time.time() + seconds
|
until = time.time() + seconds
|
||||||
|
|
||||||
@ -222,7 +222,7 @@ class TestExtractorWait(unittest.TestCase):
|
|||||||
self._assert_isotime(calls[0][1][1], until)
|
self._assert_isotime(calls[0][1][1], until)
|
||||||
|
|
||||||
def test_wait_until(self):
|
def test_wait_until(self):
|
||||||
extr = extractor.find("test:")
|
extr = extractor.find("generic:https://example.org/")
|
||||||
until = time.time() + 5
|
until = time.time() + 5
|
||||||
|
|
||||||
with patch("time.sleep") as sleep, patch.object(extr, "log") as log:
|
with patch("time.sleep") as sleep, patch.object(extr, "log") as log:
|
||||||
@ -237,7 +237,7 @@ class TestExtractorWait(unittest.TestCase):
|
|||||||
self._assert_isotime(calls[0][1][1], until)
|
self._assert_isotime(calls[0][1][1], until)
|
||||||
|
|
||||||
def test_wait_until_datetime(self):
|
def test_wait_until_datetime(self):
|
||||||
extr = extractor.find("test:")
|
extr = extractor.find("generic:https://example.org/")
|
||||||
until = datetime.utcnow() + timedelta(seconds=5)
|
until = datetime.utcnow() + timedelta(seconds=5)
|
||||||
until_local = datetime.now() + timedelta(seconds=5)
|
until_local = datetime.now() + timedelta(seconds=5)
|
||||||
|
|
||||||
|
@ -30,7 +30,8 @@ class MockPostprocessorModule(Mock):
|
|||||||
|
|
||||||
class FakeJob():
|
class FakeJob():
|
||||||
|
|
||||||
def __init__(self, extr=extractor.find("test:")):
|
def __init__(self, extr=extractor.find("generic:https://example.org/")):
|
||||||
|
extr.directory_fmt = ("{category}",)
|
||||||
self.extractor = extr
|
self.extractor = extr
|
||||||
self.pathfmt = path.PathFormat(extr)
|
self.pathfmt = path.PathFormat(extr)
|
||||||
self.out = output.NullOutput()
|
self.out = output.NullOutput()
|
||||||
|
Loading…
Reference in New Issue
Block a user