diff options
Diffstat (limited to 'tests')
-rw-r--r-- | tests/24_test_gbp_import_orig.py | 23 | ||||
-rw-r--r-- | tests/testutils/debiangittestrepo.py | 4 |
2 files changed, 26 insertions, 1 deletions
diff --git a/tests/24_test_gbp_import_orig.py b/tests/24_test_gbp_import_orig.py index 93b656b0..4ec58478 100644 --- a/tests/24_test_gbp_import_orig.py +++ b/tests/24_test_gbp_import_orig.py @@ -1,7 +1,11 @@ # vim: set fileencoding=utf-8 : """Test L{gbp.command_wrappers.Command}'s tarball unpack""" +import os +import unittest + from gbp.scripts.import_orig import (ImportOrigDebianGitRepository, GbpError) +from gbp.scripts.common.import_orig import download_orig from . testutils import DebianGitTestRepo @@ -29,3 +33,22 @@ class TestImportOrigGitRepository(DebianGitTestRepo): def test_rrr_unknown_action(self): with self.assertRaisesRegexp(GbpError, "Unknown action unknown for tag doesnotmatter"): self.repo.rrr('doesnotmatter', 'unknown', 'tag') + + +@unittest.skipUnless(os.getenv("GBP_NETWORK_TESTS"), "network tests disabled") +class TestImportOrigDownload(DebianGitTestRepo): + HOST = 'git.sigxcpu.org' + + def setUp(self): + DebianGitTestRepo.setUp(self, ImportOrigDebianGitRepository) + os.chdir(self.repodir) + + def test_404_download(self): + with self.assertRaisesRegexp(GbpError, "404 Client Error: Not Found for url"): + download_orig("https://{host}/does_not_exist".format(host=self.HOST)) + + def test_200_download(self): + pkg = 'hello-debhelper_2.6.orig.tar.gz' + url = "https://{host}/cgit/gbp/deb-testdata/tree/dsc-3.0/{pkg}".format(host=self.HOST, + pkg=pkg) + self.assertEqual(download_orig(url).path, '../%s' % pkg) diff --git a/tests/testutils/debiangittestrepo.py b/tests/testutils/debiangittestrepo.py index 9a9ee07d..c52c5f17 100644 --- a/tests/testutils/debiangittestrepo.py +++ b/tests/testutils/debiangittestrepo.py @@ -12,12 +12,14 @@ class DebianGitTestRepo(unittest.TestCase): """Scratch repo for a single unit test""" def setUp(self, repo_cls=None): + name = 'test_repo' self.tmpdir = context.new_tmpdir(__name__) if repo_cls is None: repo_cls = gbp.deb.git.DebianGitRepository - repodir = self.tmpdir.join('test_repo') + repodir = self.tmpdir.join(name) + self.repodir = os.path.join(str(self.tmpdir), name) self.repo = repo_cls.create(repodir) def tearDown(self): |