remove extractor/test.py (#4504)

pull/5256/head
Mike Fährmann 7 months ago
parent fde9e25c9f
commit 8a11b72253
No known key found for this signature in database
GPG Key ID: 5680CA389D365A88

@ -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…
Cancel
Save