1
0
mirror of https://github.com/mikf/gallery-dl.git synced 2024-11-23 03:02:50 +01:00
gallery-dl/test/test_extractors.py

116 lines
3.5 KiB
Python
Raw Normal View History

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
2017-01-09 12:27:20 +01:00
# Copyright 2015-2017 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.
import sys
import unittest
2017-11-12 20:51:12 +01:00
from gallery_dl import extractor, job, config, exception
2017-01-09 12:27:20 +01:00
2015-12-15 23:45:40 +01:00
class TestExtractors(unittest.TestCase):
2016-02-18 15:53:53 +01:00
def setUp(self):
name = "gallerydl"
email = "gallerydl@openaliasbox.org"
config.set(("cache", "file"), ":memory:")
config.set(("extractor", "username"), name)
config.set(("extractor", "password"), name)
config.set(("extractor", "nijie", "username"), email)
config.set(("extractor", "seiga", "username"), email)
2017-10-25 12:55:36 +02:00
config.set(("downloader", "part"), False)
2017-07-25 14:59:41 +02:00
def tearDown(self):
config.clear()
2017-01-09 12:27:20 +01:00
def _run_test(self, extr, url, result):
if result:
if "options" in result:
for key, value in result["options"]:
config.set(key.split("."), value)
content = "content" in result
else:
content = False
2017-10-25 12:55:36 +02:00
tjob = job.TestJob(url, content=content)
2017-02-26 02:06:56 +01:00
self.assertEqual(extr, tjob.extractor.__class__)
2017-06-13 23:10:42 +02:00
if not result:
return
if "exception" in result:
self.assertRaises(result["exception"], tjob.run)
return
2017-11-12 20:51:12 +01:00
try:
tjob.run()
except exception.HttpError as exc:
try:
if 500 <= exc.args[0].response.status_code < 600:
self.skipTest(exc)
except AttributeError as e:
pass
raise
2015-12-13 03:56:29 +01:00
if "url" in result:
self.assertEqual(result["url"], tjob.hash_url.hexdigest())
2015-12-13 03:56:29 +01:00
if "keyword" in result:
self.assertEqual(result["keyword"], tjob.hash_keyword.hexdigest())
2017-10-25 12:55:36 +02:00
if "content" in result:
self.assertEqual(result["content"], tjob.hash_content.hexdigest())
if "count" in result:
self.assertEqual(len(tjob.urllist), int(result["count"]))
if "pattern" in result:
for url in tjob.urllist:
self.assertRegex(url, result["pattern"])
2016-02-18 15:53:53 +01:00
2017-03-14 08:51:58 +01:00
# dynamically generate tests
2017-01-09 12:27:20 +01:00
def _generate_test(extr, tcase):
2016-02-18 15:53:53 +01:00
def test(self):
2017-01-09 12:27:20 +01:00
url, result = tcase
print("\n", url, sep="")
self._run_test(extr, url, result)
2016-02-18 15:53:53 +01:00
return test
2017-01-30 19:40:15 +01:00
skip = [
# don't work on travis-ci
"exhentai", "kissmanga", "mangafox", "dynastyscans", "nijie",
2017-07-24 10:50:40 +02:00
"archivedmoe", "archiveofsins", "thebarchive",
# temporary issues
"mangapark",
]
# enable selective testing for direct calls
if __name__ == '__main__' and len(sys.argv) > 1:
if sys.argv[1].lower() == "all":
extractors = extractor.extractors()
else:
extractors = [
extr for extr in extractor.extractors()
if extr.category in sys.argv or
hasattr(extr, "basecategory") and extr.basecategory in sys.argv
]
del sys.argv[1:]
2017-02-10 21:20:27 +01:00
else:
extractors = [
extr for extr in extractor.extractors()
if extr.category not in skip
]
2016-02-18 15:53:53 +01:00
for extr in extractors:
2017-01-09 12:27:20 +01:00
if hasattr(extr, "test") and extr.test:
name = "test_" + extr.__name__ + "_"
for num, tcase in enumerate(extr.test, 1):
test = _generate_test(extr, tcase)
test.__name__ = name + str(num)
setattr(TestExtractors, test.__name__, test)
del test
2017-01-09 12:27:20 +01:00
if __name__ == '__main__':
unittest.main(warnings='ignore')