From 64cf26eaf4c51c0cee54b9d30104f7eede1a1ee7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mike=20F=C3=A4hrmann?= Date: Sat, 18 Dec 2021 23:04:33 +0100 Subject: [PATCH] allow specifying sleep-* options as string either as single value or as range: "3.5", "2.1 - 5.0" --- docs/configuration.rst | 4 ++++ gallery_dl/util.py | 20 ++++++++++++++------ test/test_util.py | 25 +++++++++++++++++++++++++ 3 files changed, 43 insertions(+), 6 deletions(-) diff --git a/docs/configuration.rst b/docs/configuration.rst index 73664df2..b90ed95b 100644 --- a/docs/configuration.rst +++ b/docs/configuration.rst @@ -3365,9 +3365,11 @@ Duration Type * ``float`` * ``list`` with 2 ``floats`` + * ``string`` Example * ``2.85`` * ``[1.5, 3.0]`` + * ``"2.85"``, ``"1.5-3.0"`` Description A |Duration|_ represents a span of time in seconds. @@ -3375,6 +3377,8 @@ Description * If given as a ``list`` with 2 floating-point numbers ``a`` & ``b`` , it will be randomly chosen with uniform distribution such that ``a <= N <=b``. (see `random.uniform() `_) + * If given as a ``string``, it can either represent a single ``float`` + value (``"2.85"``) or a range (``"1.5-3.0"``). Path diff --git a/gallery_dl/util.py b/gallery_dl/util.py index d25194e3..bccae2db 100644 --- a/gallery_dl/util.py +++ b/gallery_dl/util.py @@ -428,18 +428,26 @@ def build_duration_func(duration, min=0.0): if not duration: return None - try: - lower, upper = duration - except TypeError: - pass + if isinstance(duration, str): + lower, _, upper = duration.partition("-") + lower = float(lower) else: + try: + lower, upper = duration + except TypeError: + lower, upper = duration, None + + if upper: + upper = float(upper) return functools.partial( random.uniform, lower if lower > min else min, upper if upper > min else min, ) - - return functools.partial(identity, duration if duration > min else min) + else: + if lower < min: + lower = min + return lambda: lower def build_extractor_filter(categories, negate=True, special=None): diff --git a/test/test_util.py b/test/test_util.py index 32e97849..ce403a8e 100644 --- a/test/test_util.py +++ b/test/test_util.py @@ -357,6 +357,31 @@ class TestOther(unittest.TestCase): with self.assertRaises(exception.StopExtraction): expr() + def test_build_duration_func(self, f=util.build_duration_func): + for v in (0, 0.0, "", None, (), []): + self.assertIsNone(f(v)) + + def test_single(df, v): + for _ in range(10): + self.assertEqual(df(), v) + + def test_range(df, lower, upper): + for __ in range(10): + v = df() + self.assertGreaterEqual(v, lower) + self.assertLessEqual(v, upper) + + test_single(f(3), 3) + test_single(f(3.0), 3.0) + test_single(f("3"), 3) + test_single(f("3.0-"), 3) + test_single(f(" 3 -"), 3) + + test_range(f((2, 4)), 2, 4) + test_range(f([2, 4]), 2, 4) + test_range(f("2-4"), 2, 4) + test_range(f(" 2.0 - 4 "), 2, 4) + def test_extractor_filter(self): # empty func = util.build_extractor_filter("")