From 630541499a58f98c55d5cc372d21e745c106d250 Mon Sep 17 00:00:00 2001 From: Cody Logan Date: Fri, 13 Oct 2023 12:24:13 -0700 Subject: Refactor parsing logic and revise exception handling --- tests/test_dl.py | 69 ++++++++++++++--------------------------------------- tests/test_parse.py | 60 ++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 78 insertions(+), 51 deletions(-) create mode 100644 tests/test_parse.py (limited to 'tests') diff --git a/tests/test_dl.py b/tests/test_dl.py index abf8763..fc68733 100644 --- a/tests/test_dl.py +++ b/tests/test_dl.py @@ -15,65 +15,32 @@ # You should have received a copy of the GNU General Public License # along with Wikiget. If not, see . +import logging + import pytest -from wikiget.dl import get_dest +from wikiget import USER_AGENT +from wikiget.dl import prep_download, query_api from wikiget.wikiget import construct_parser -class TestGetDest: +# TODO: don't hit the actual API when doing tests +@pytest.mark.skip +class TestQueryApi: parser = construct_parser() - def test_get_dest_with_filename(self): + def test_query_api(self, caplog): + caplog.set_level(logging.DEBUG) args = self.parser.parse_args(["File:Example.jpg"]) - filename, dest, site_name = get_dest(args.FILE, args) - assert filename == "Example.jpg" - assert dest == "Example.jpg" - assert site_name == "commons.wikimedia.org" - - def test_get_dest_with_url(self): - args = self.parser.parse_args( - [ - "https://en.wikipedia.org/wiki/File:Example.jpg", - ] - ) - filename, dest, site_name = get_dest(args.FILE, args) - assert filename == "Example.jpg" - assert dest == "Example.jpg" - assert site_name == "en.wikipedia.org" + file, site = query_api("Example.jpg", "commons.wikimedia.org", args) + assert USER_AGENT in caplog.text - def test_get_dest_with_bad_filename(self): - args = self.parser.parse_args(["Example.jpg"]) - with pytest.raises(SystemExit): - filename, dest, site_name = get_dest(args.FILE, args) - - def test_get_dest_with_different_site(self, caplog: pytest.LogCaptureFixture): - args = self.parser.parse_args( - [ - "https://commons.wikimedia.org/wiki/File:Example.jpg", - "--site", - "commons.wikimedia.org", - ] - ) - filename, dest, site_name = get_dest(args.FILE, args) - assert "target is a URL, ignoring site specified with --site" in caplog.text +@pytest.mark.skip +class TestPrepDownload: + parser = construct_parser() -# TODO: don't hit the actual API when doing tests -# class TestQueryApi: -# parser = construct_parser() -# -# def test_query_api(self, caplog): -# caplog.set_level(logging.DEBUG) -# args = self.parser.parse_args(["File:Example.jpg"]) -# file, site = query_api("Example.jpg", "commons.wikimedia.org", args) -# assert USER_AGENT in caplog.text -# -# -# class TestPrepDownload(): -# parser = construct_parser() -# -# def test_prep_download(self): -# args = self.parser.parse_args(["File:Example.jpg"]) -# file = prep_download(args.FILE, args) -# assert file is not None + def test_prep_download(self): + args = self.parser.parse_args(["File:Example.jpg"]) + file = prep_download(args.FILE, args) + assert file is not None diff --git a/tests/test_parse.py b/tests/test_parse.py new file mode 100644 index 0000000..064b85c --- /dev/null +++ b/tests/test_parse.py @@ -0,0 +1,60 @@ +# wikiget - CLI tool for downloading files from Wikimedia sites +# Copyright (C) 2023 Cody Logan +# SPDX-License-Identifier: GPL-3.0-or-later +# +# Wikiget is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Wikiget is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Wikiget. If not, see . + +import pytest + +from wikiget.exceptions import ParseError +from wikiget.parse import get_dest +from wikiget.wikiget import construct_parser + + +class TestGetDest: + parser = construct_parser() + + def test_get_dest_with_filename(self): + args = self.parser.parse_args(["File:Example.jpg"]) + filename, dest, site_name = get_dest(args.FILE, args) + assert filename == "Example.jpg" + assert dest == "Example.jpg" + assert site_name == "commons.wikimedia.org" + + def test_get_dest_with_url(self): + args = self.parser.parse_args( + [ + "https://en.wikipedia.org/wiki/File:Example.jpg", + ] + ) + filename, dest, site_name = get_dest(args.FILE, args) + assert filename == "Example.jpg" + assert dest == "Example.jpg" + assert site_name == "en.wikipedia.org" + + def test_get_dest_with_bad_filename(self): + args = self.parser.parse_args(["Example.jpg"]) + with pytest.raises(ParseError): + filename, dest, site_name = get_dest(args.FILE, args) + + def test_get_dest_with_different_site(self, caplog: pytest.LogCaptureFixture): + args = self.parser.parse_args( + [ + "https://commons.wikimedia.org/wiki/File:Example.jpg", + "--site", + "commons.wikimedia.org", + ] + ) + filename, dest, site_name = get_dest(args.FILE, args) + assert "target is a URL, ignoring site specified with --site" in caplog.text -- cgit v1.2.3