123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183 |
- # vim: set fileencoding=utf-8 :
- #
- # (C) 2015-2017 Guido Günther <agx@sigxcpu.org>
- #
- # This program 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 2 of the License, or
- # (at your option) any later version.
- #
- # This program 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 this program; if not, please see
- # <http://www.gnu.org/licenses/>
- import hashlib
- import os
- import subprocess
- from tests.component import (ComponentTestBase,
- ComponentTestGitRepository)
- from tests.component.deb import DEB_TEST_DATA_DIR
- from tests.component.deb.fixtures import RepoFixtures
- from nose.tools import ok_, eq_, assert_false, assert_true
- from gbp.scripts.import_dsc import main as import_dsc
- from gbp.scripts.buildpackage import main as buildpackage
- class TestBuildpackage(ComponentTestBase):
- """Test building a debian package"""
- @staticmethod
- def _dsc_name(pkg, version, dir):
- return os.path.join(DEB_TEST_DATA_DIR,
- dir,
- '%s_%s.dsc' % (pkg, version))
- def _test_buildpackage(self, repo, opts=[]):
- prebuild_out = os.path.join(repo.path, 'prebuild.out')
- postbuild_out = os.path.join(repo.path, 'postbuild.out')
- args = ['arg0',
- '--git-prebuild=printenv > %s' % prebuild_out,
- '--git-postbuild=printenv > %s' % postbuild_out,
- '--git-builder=/bin/true',
- '--git-cleaner=/bin/true'] + opts
- os.chdir(repo.path)
- ret = buildpackage(args)
- ok_(ret == 0, "Building the package failed")
- eq_(os.path.exists(prebuild_out), True)
- eq_(os.path.exists(postbuild_out), True)
- self.check_hook_vars('prebuild', ["GBP_BUILD_DIR",
- "GBP_GIT_DIR",
- "GBP_BUILD_DIR"])
- self.check_hook_vars('postbuild', ["GBP_CHANGES_FILE",
- "GBP_BUILD_DIR",
- "GBP_CHANGES_FILE",
- "GBP_BUILD_DIR"])
- @RepoFixtures.native()
- def test_debian_buildpackage(self, repo):
- """Test that building a native debian package works"""
- self._test_buildpackage(repo)
- @RepoFixtures.quilt30()
- def test_non_native_buildpackage(self, repo):
- """Test that building a source 3.0 debian package works"""
- self._test_buildpackage(repo)
- @RepoFixtures.native()
- def test_tag_only(self, repo):
- """Test that only tagging a native debian package works"""
- repo.delete_tag('debian/0.4.14') # make sure we can tag again
- ret = buildpackage(['arg0',
- '--git-tag-only',
- '--git-posttag=printenv > posttag.out',
- '--git-builder=touch builder-run.stamp',
- '--git-cleaner=/bin/true'])
- ok_(ret == 0, "Building the package failed")
- eq_(os.path.exists('posttag.out'), True)
- eq_(os.path.exists('builder-run.stamp'), False)
- self.check_hook_vars('posttag', [("GBP_TAG", "debian/0.4.14"),
- ("GBP_BRANCH", "master"),
- "GBP_SHA1"])
- def test_component_generation(self):
- """Test that generating tarball and additional tarball works without pristine-tar"""
- pkg = 'hello-debhelper'
- dsc = self._dsc_name(pkg, '2.8-1', 'dsc-3.0-additional-tarballs')
- tarballs = ["../%s_2.8.orig-foo.tar.gz" % pkg,
- "../%s_2.8.orig.tar.gz" % pkg]
- assert import_dsc(['arg0', '--no-pristine-tar', dsc]) == 0
- repo = ComponentTestGitRepository(pkg)
- os.chdir(pkg)
- assert_false(repo.has_branch('pristine-tar'), "Pristine-tar branch must not exist")
- for t in tarballs:
- self.assertFalse(os.path.exists(t), "Tarball %s must not exist" % t)
- ret = buildpackage(['arg0',
- '--git-component=foo',
- '--git-no-pristine-tar',
- '--git-posttag=printenv > posttag.out',
- '--git-builder=touch builder-run.stamp',
- '--git-cleaner=/bin/true'])
- ok_(ret == 0, "Building the package failed")
- for t in tarballs:
- self.assertTrue(os.path.exists(t), "Tarball %s not found" % t)
- def test_pristinetar_component_generation(self):
- """Test that generating tarball and additional tarball works with pristine-tar"""
- pkg = 'hello-debhelper'
- dsc = self._dsc_name(pkg, '2.8-1', 'dsc-3.0-additional-tarballs')
- tarballs = ["../%s_2.8.orig-foo.tar.gz" % pkg,
- "../%s_2.8.orig.tar.gz" % pkg]
- assert import_dsc(['arg0', '--pristine-tar', dsc]) == 0
- repo = ComponentTestGitRepository(pkg)
- os.chdir(pkg)
- assert_true(repo.has_branch('pristine-tar'), "Pristine-tar branch must exist")
- for t in tarballs:
- self.assertFalse(os.path.exists(t), "Tarball %s must not exist" % t)
- # Make sure the tree object for importing the main tarball is recreated
- repo.collect_garbage(prune='all', aggressive=True)
- ret = buildpackage(['arg0',
- '--git-component=foo',
- '--git-pristine-tar',
- '--git-posttag=printenv > posttag.out',
- '--git-builder=touch builder-run.stamp',
- '--git-cleaner=/bin/true'])
- ok_(ret == 0, "Building the package failed")
- for t in tarballs:
- self.assertTrue(os.path.exists(t), "Tarball %s not found" % t)
- @RepoFixtures.quilt30()
- def test_export_dir_buildpackage(self, repo):
- """Test that building with a export dir works"""
- self._test_buildpackage(repo, ['--git-export-dir=../foo/bar'])
- ok_(os.path.exists('../foo/bar'))
- @RepoFixtures.native()
- def test_argument_quoting(self, repo):
- """Test that we quote arguments to builder (#)"""
- with open('../arg with spaces', 'w'):
- pass
- # We use ls as builder to look for a file with spaces. This
- # will fail if build arguments are not properly quoted and
- # therefore split up
- ret = buildpackage(['arg0',
- '--git-builder=ls',
- '--git-cleaner=/bin/true',
- '../arg with spaces'])
- ok_(ret == 0, "Building the package failed")
- @RepoFixtures.quilt30()
- def test_tarball_default_compression(self, repo):
- """Test that we use defaults for compression if not given (#820846)"""
- self._test_buildpackage(repo, ['--git-no-pristine-tar'])
- tarball = "../hello-debhelper_2.8.orig.tar.gz"
- out = subprocess.check_output(["file", tarball])
- ok_("max compression" not in out)
- m1 = hashlib.md5(open(tarball, 'rb').read()).hexdigest()
- os.unlink(tarball)
- eq_(buildpackage(['arg0',
- '--git-ignore-new',
- '--git-builder=/bin/true',
- '--git-cleaner=/bin/true',
- '../arg with spaces']), 0)
- m2 = hashlib.md5(open(tarball, 'rb').read()).hexdigest()
- eq_(m1, m2, "Regenerated tarball has different checksum")
- @RepoFixtures.quilt30
- def test_tarball_max_compression(self, repo):
- """Test that passing max compression works (#820846)"""
- self._test_buildpackage(repo, ['--git-no-pristine-tar', '--git-compression-level=9'])
- out = subprocess.check_output(["file", "../hello-debhelper_2.8.orig.tar.gz"])
- ok_("max compression" in out)
|