summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJun Wang <junbill.wang@samsung.com>2016-03-21 19:34:15 +0800
committerJun Wang <junbill.wang@samsung.com>2016-03-21 19:36:17 +0800
commit98ebae2eb4504a80000aa21a4ddc6266e25c17cb (patch)
treec3611540d0afd81aec7e0ddee574559349c77337
parent7c4962c9ce5cdab6d191f11297ea1b14dc464c14 (diff)
downloadgit-buildpackage-98ebae2eb4504a80000aa21a4ddc6266e25c17cb.tar.gz
git-buildpackage-98ebae2eb4504a80000aa21a4ddc6266e25c17cb.tar.bz2
git-buildpackage-98ebae2eb4504a80000aa21a4ddc6266e25c17cb.zip
Fix 20_test_rpm.py to suit different edition of python.
Change-Id: Ibe03d1614fafb5ceb01af634da90eda8d1426fbd
-rw-r--r--tests/20_test_rpm.py199
1 files changed, 107 insertions, 92 deletions
diff --git a/tests/20_test_rpm.py b/tests/20_test_rpm.py
index adf205f5..f76b129f 100644
--- a/tests/20_test_rpm.py
+++ b/tests/20_test_rpm.py
@@ -20,23 +20,17 @@ import filecmp
import os
import shutil
import tempfile
-from nose.tools import assert_raises, eq_, ok_ # pylint: disable=E0611
+from nose.tools import assert_raises, eq_
from gbp.errors import GbpError
from gbp.rpm import (SrcRpmFile, SpecFile, parse_srpm, NoSpecError, guess_spec,
guess_spec_repo, spec_from_repo)
from gbp.git.repository import GitRepository
-# Disable "Method could be a function"
-# pylint: disable=R0201
-
-
-DATA_DIR = os.path.join(os.path.dirname(os.path.abspath(__file__)), 'data',
- 'rpm')
+DATA_DIR = os.path.abspath(os.path.splitext(__file__)[0] + '_data')
SRPM_DIR = os.path.join(DATA_DIR, 'srpms')
SPEC_DIR = os.path.join(DATA_DIR, 'specs')
-
class SpecFileTester(SpecFile):
"""Helper class for testing"""
@@ -45,36 +39,30 @@ class SpecFileTester(SpecFile):
return super(SpecFileTester, self).__getattribute__(name)
-class RpmTestBase(object):
- """Test base class"""
- def __init__(self):
- self.tmpdir = None
+class TestSrcRpmFile(object):
+ """Test L{gbp.rpm.SrcRpmFile}"""
def setup(self):
- """Test case setup"""
self.tmpdir = tempfile.mkdtemp(prefix='gbp_%s_' % __name__, dir='.')
def teardown(self):
- """Test case teardown"""
shutil.rmtree(self.tmpdir)
-class TestSrcRpmFile(RpmTestBase):
- """Test L{gbp.rpm.SrcRpmFile}"""
-
def test_srpm(self):
"""Test parsing of a source rpm"""
srpm = SrcRpmFile(os.path.join(SRPM_DIR, 'gbp-test-1.0-1.src.rpm'))
- eq_(srpm.version, {'release': '1', 'upstreamversion': '1.0'})
- eq_(srpm.name, 'gbp-test')
- eq_(srpm.upstreamversion, '1.0')
- eq_(srpm.packager, None)
+ assert srpm.version == {'release': '1', 'upstreamversion': '1.0'}
+ assert srpm.name == 'gbp-test'
+ assert srpm.upstreamversion == '1.0'
+ assert srpm.packager is None
def test_srpm_2(self):
"""Test parsing of another source rpm"""
srpm = SrcRpmFile(os.path.join(SRPM_DIR, 'gbp-test2-3.0-0.src.rpm'))
- eq_(srpm.version, {'release': '0', 'upstreamversion': '3.0',
- 'epoch': '2'})
- eq_(srpm.packager, 'Markus Lehtonen <markus.lehtonen@linux.intel.com>')
+ assert srpm.version == {'release': '0', 'upstreamversion': '3.0',
+ 'epoch': '2'}
+ assert srpm.packager == 'Markus Lehtonen '\
+ '<markus.lehtonen@linux.intel.com>'
def test_unpack_srpm(self):
"""Test unpacking of a source rpm"""
@@ -82,37 +70,44 @@ class TestSrcRpmFile(RpmTestBase):
srpm.unpack(self.tmpdir)
for fn in ['gbp-test-1.0.tar.bz2', 'foo.txt', 'bar.tar.gz', 'my.patch',
'my2.patch', 'my3.patch']:
- ok_(os.path.exists(os.path.join(self.tmpdir, fn)),
- "%s not found" % fn)
+ assert os.path.exists(os.path.join(self.tmpdir, fn)), \
+ "%s not found" % fn
-class TestSpecFile(RpmTestBase):
+
+class TestSpecFile(object):
"""Test L{gbp.rpm.SpecFile}"""
+ def setup(self):
+ self.tmpdir = tempfile.mkdtemp(prefix='gbp_%s_' % __name__, dir='.')
+
+ def teardown(self):
+ shutil.rmtree(self.tmpdir)
+
def test_spec(self):
"""Test parsing of a valid spec file"""
spec_filepath = os.path.join(SPEC_DIR, 'gbp-test.spec')
spec = SpecFileTester(spec_filepath)
# Test basic properties
- eq_(spec.specfile, os.path.basename(spec_filepath))
- eq_(spec.specdir, os.path.dirname(spec_filepath))
- eq_(spec.specpath, spec_filepath)
+ assert spec.specfile == os.path.basename(spec_filepath)
+ assert spec.specdir == os.path.dirname(spec_filepath)
+ assert spec.specpath == spec_filepath
- eq_(spec.name, 'gbp-test')
- eq_(spec.packager, None)
+ assert spec.name == 'gbp-test'
+ assert spec.packager is None
- eq_(spec.upstreamversion, '1.0')
- eq_(spec.release, '1')
- eq_(spec.epoch, None)
- eq_(spec.version, {'release': '1', 'upstreamversion': '1.0'})
+ assert spec.upstreamversion == '1.0'
+ assert spec.release == '1'
+ assert spec.epoch is None
+ assert spec.version == {'release': '1', 'upstreamversion': '1.0'}
orig = spec.orig_src
- eq_(orig['filename'], 'gbp-test-1.0.tar.bz2')
- eq_(orig['uri'], 'gbp-test-1.0.tar.bz2')
- eq_(orig['filename_base'], 'gbp-test-1.0')
- eq_(orig['archive_fmt'], 'tar')
- eq_(orig['compression'], 'bzip2')
- eq_(orig['prefix'], 'gbp-test/')
+ assert orig['filename'] == 'gbp-test-1.0.tar.bz2'
+ assert orig['uri'] == 'gbp-test-1.0.tar.bz2'
+ assert orig['filename_base'] == 'gbp-test-1.0'
+ assert orig['archive_fmt'] == 'tar'
+ assert orig['compression'] == 'bzip2'
+ assert orig['prefix'] == 'gbp-test/'
def test_spec_2(self):
"""Test parsing of another valid spec file"""
@@ -120,19 +115,20 @@ class TestSpecFile(RpmTestBase):
spec = SpecFile(spec_filepath)
# Test basic properties
- eq_(spec.name, 'gbp-test2')
- eq_(spec.packager, 'Markus Lehtonen <markus.lehtonen@linux.intel.com>')
+ assert spec.name == 'gbp-test2'
+ assert spec.packager == 'Markus Lehtonen ' \
+ '<markus.lehtonen@linux.intel.com>'
- eq_(spec.epoch, '2')
- eq_(spec.version, {'release': '0', 'upstreamversion': '3.0',
- 'epoch': '2'})
+ assert spec.epoch == '2'
+ assert spec.version == {'release': '0', 'upstreamversion': '3.0',
+ 'epoch': '2'}
orig = spec.orig_src
- eq_(orig['filename'], 'gbp-test2-3.0.tar.gz')
- eq_(orig['uri'], 'ftp://ftp.host.com/gbp-test2-3.0.tar.gz')
- eq_(orig['archive_fmt'], 'tar')
- eq_(orig['compression'], 'gzip')
- eq_(orig['prefix'], '')
+ assert orig['filename'] == 'gbp-test2-3.0.tar.gz'
+ assert orig['uri'] == 'ftp://ftp.host.com/gbp-test2-3.0.tar.gz'
+ assert orig['archive_fmt'] == 'tar'
+ assert orig['compression'] == 'gzip'
+ assert orig['prefix'] == ''
def test_spec_3(self):
"""Test parsing of yet another valid spec file"""
@@ -140,12 +136,12 @@ class TestSpecFile(RpmTestBase):
spec = SpecFile(spec_filepath)
# Test basic properties
- eq_(spec.name, 'gbp-test-native')
+ assert spec.name == 'gbp-test-native'
orig = spec.orig_src
- eq_(orig['filename'], 'gbp-test-native-1.0.zip')
- eq_(orig['archive_fmt'], 'zip')
- eq_(orig['compression'], None)
- eq_(orig['prefix'], 'gbp-test-native-1.0/')
+ assert orig['filename'] == 'gbp-test-native-1.0.zip'
+ assert orig['archive_fmt'] == 'zip'
+ assert orig['compression'] == None
+ assert orig['prefix'] == 'gbp-test-native-1.0/'
def test_spec_4(self):
"""Test parsing of spec without orig tarball"""
@@ -153,8 +149,8 @@ class TestSpecFile(RpmTestBase):
spec = SpecFile(spec_filepath)
# Test basic properties
- eq_(spec.name, 'gbp-test-native2')
- eq_(spec.orig_src, None)
+ assert spec.name == 'gbp-test-native2'
+ assert spec.orig_src is None
def test_parse_raw(self):
"""Test parsing of a valid spec file"""
@@ -174,9 +170,9 @@ class TestSpecFile(RpmTestBase):
spec = SpecFile(filedata=spec_data)
# Test basic properties
- eq_(spec.specfile, None)
- eq_(spec.specdir, None)
- eq_(spec.name, 'gbp-test')
+ assert spec.specfile == None
+ assert spec.specdir == None
+ assert spec.name == 'gbp-test'
def test_update_spec(self):
"""Test spec autoupdate functionality"""
@@ -188,14 +184,14 @@ class TestSpecFile(RpmTestBase):
spec = SpecFile(tmp_spec)
spec.update_patches(['new.patch'], {})
spec.write_spec_file()
- eq_(filecmp.cmp(tmp_spec, reference_spec), True)
+ assert filecmp.cmp(tmp_spec, reference_spec) is True
# Test adding the VCS tag and adding changelog
reference_spec = os.path.join(SPEC_DIR, 'gbp-test-reference2.spec')
spec.set_tag('VCS', None, 'myvcstag')
spec.set_changelog("* Wed Feb 05 2014 Name <email> 1\n- New entry\n")
spec.write_spec_file()
- eq_(filecmp.cmp(tmp_spec, reference_spec), True)
+ assert filecmp.cmp(tmp_spec, reference_spec) is True
def test_update_spec2(self):
"""Another test for spec autoupdate functionality"""
@@ -209,7 +205,7 @@ class TestSpecFile(RpmTestBase):
'2.patch': {'ifarch': '%ix86'}})
spec.set_tag('VCS', None, 'myvcstag')
spec.write_spec_file()
- eq_(filecmp.cmp(tmp_spec, reference_spec), True)
+ assert filecmp.cmp(tmp_spec, reference_spec) is True
# Test updating patches again, removing the VCS tag and re-writing
# changelog
@@ -218,7 +214,7 @@ class TestSpecFile(RpmTestBase):
spec.set_tag('VCS', None, '')
spec.set_changelog("* Wed Feb 05 2014 Name <email> 2\n- New entry\n\n")
spec.write_spec_file()
- eq_(filecmp.cmp(tmp_spec, reference_spec), True)
+ assert filecmp.cmp(tmp_spec, reference_spec) is True
def test_modifying(self):
"""Test updating/deleting of tags and macros"""
@@ -232,10 +228,10 @@ class TestSpecFile(RpmTestBase):
prev = spec.protected('_delete_tag')('Vendor', None)
spec.protected('_set_tag')('License', None, 'new license', prev)
spec.protected('_delete_tag')('source', 0)
- eq_(spec.sources(), {})
+ assert spec.sources() == {}
spec.protected('_delete_tag')('patch', 0)
spec.protected('_delete_tag')('patch', -1)
- eq_(spec.protected('_patches')(), {})
+ assert spec.protected('_patches')() == {}
prev = spec.protected('_delete_tag')('invalidtag', None)
assert_raises(GbpError, spec.protected('_set_tag'),
@@ -271,7 +267,7 @@ class TestSpecFile(RpmTestBase):
# Check resulting spec file
spec.write_spec_file()
- eq_(filecmp.cmp(tmp_spec, reference_spec), True)
+ assert filecmp.cmp(tmp_spec, reference_spec) is True
def test_modifying_err(self):
"""Test error conditions of modification methods"""
@@ -315,7 +311,7 @@ class TestSpecFile(RpmTestBase):
spec = SpecFile(spec_filepath)
# Check that we quess orig source and prefix correctly
- eq_(spec.orig_src['prefix'], 'foobar/')
+ assert spec.orig_src['prefix'] == 'foobar/'
def test_tags(self):
"""Test parsing of all the different tags of spec file"""
@@ -332,33 +328,33 @@ class TestSpecFile(RpmTestBase):
elif name not in spec.protected('_listtags'):
rval = 'my_%s' % name
if rval:
- eq_(val['value'], rval, ("'%s:' is '%s', expecting '%s'" %
- (name, val['value'], rval)))
- eq_(spec.ignorepatches, [])
+ assert val['value'] == rval, ("'%s:' is '%s', expecting '%s'" %
+ (name, val['value'], rval))
+ assert spec.ignorepatches == []
# Check patch numbers and patch filenames
patches = {}
for patch in spec.protected('_tags')['patch']['lines']:
patches[patch['num']] = patch['linevalue']
- eq_(patches, {0: 'my_patch0', -1: 'my_patch'})
+ assert patches == {0: 'my_patch0', -1: 'my_patch'}
def test_patch_series(self):
"""Test the getting the patches as a patchseries"""
spec_filepath = os.path.join(SPEC_DIR, 'gbp-test-native.spec')
spec = SpecFileTester(spec_filepath)
- eq_(len(spec.patchseries()), 0)
+ assert len(spec.patchseries()) == 0
spec.update_patches(['1.patch', '2.patch', '3.patch'], {})
- eq_(len(spec.patchseries()), 3)
+ assert len(spec.patchseries()) == 3
spec.protected('_gbp_tags')['ignore-patches'].append({'args': "0"})
spec.update_patches(['4.patch'], {})
- eq_(len(spec.patchseries()), 1)
- eq_(len(spec.patchseries(ignored=True)), 2)
+ assert len(spec.patchseries()) == 1
+ assert len(spec.patchseries(ignored=True)) == 2
spec.protected('_delete_special_macro')('patch', 0)
- eq_(len(spec.patchseries(ignored=True)), 1)
+ assert len(spec.patchseries(ignored=True)) == 1
series = spec.patchseries(unapplied=True, ignored=True)
- eq_(len(series), 2)
- eq_(os.path.basename(series[-1].path), '1.patch')
+ assert len(series) == 2
+ assert os.path.basename(series[-1].path) == '1.patch'
def test_patch_series_quirks(self):
"""Patches are applied in order different from the patch numbering"""
@@ -367,23 +363,42 @@ class TestSpecFile(RpmTestBase):
# Check series is returned in the order the patches are applied
files = [os.path.basename(patch.path) for patch in spec.patchseries()]
- eq_(files, ['05.patch', '01.patch'])
+ assert files == ['05.patch', '01.patch']
# Also ignored patches are returned in the correct order
files = [os.path.basename(patch.path) for patch in
spec.patchseries(ignored=True)]
- eq_(files, ['05.patch', '02.patch', '01.patch'])
+ assert files == ['05.patch', '02.patch', '01.patch']
# Unapplied patches are added to the end of the series
files = [os.path.basename(patch.path) for patch in
spec.patchseries(unapplied=True)]
- eq_(files, ['05.patch', '01.patch', '03.patch'])
+ assert files == ['05.patch', '01.patch', '03.patch']
# Return all patches (for which tag is found)
files = [os.path.basename(patch.path) for patch in
spec.patchseries(unapplied=True, ignored=True)]
- eq_(files, ['05.patch', '02.patch', '01.patch', '03.patch', '04.patch'])
+ assert files == ['05.patch', '02.patch', '01.patch', '03.patch',
+ '04.patch']
-class TestUtilityFunctions(RpmTestBase):
+class TestUtilityFunctions(object):
"""Test utility functions of L{gbp.rpm}"""
+ def setup(self):
+ self.tmpdir = tempfile.mkdtemp(prefix='gbp_%s_' % __name__, dir='.')
+
+ def teardown(self):
+ shutil.rmtree(self.tmpdir)
+
+ def test_parse_srpm(self):
+ """Test parse_srpm() function"""
+ parse_srpm(os.path.join(SRPM_DIR, 'gbp-test-1.0-1.src.rpm'))
+ assert_raises(GbpError, parse_srpm,
+ os.path.join(DATA_DIR, 'notexists.src.rpm'))
+
+ """
+ with assert_raises(GbpError):
+ parse_srpm(os.path.join(DATA_DIR, 'notexists.src.rpm'))
+ with assert_raises(GbpError):
+ parse_srpm(os.path.join(SPEC_DIR, 'gbp-test.spec'))
+ """
def test_guess_spec(self):
"""Test guess_spec() function"""
@@ -412,8 +427,8 @@ class TestUtilityFunctions(RpmTestBase):
# Spec found
spec = guess_spec(SPEC_DIR, recursive=False,
preferred_name = 'gbp-test2.spec')
- eq_(spec.specfile, 'gbp-test2.spec')
- eq_(spec.specdir, SPEC_DIR)
+ assert spec.specfile == 'gbp-test2.spec'
+ assert spec.specdir == SPEC_DIR
def test_guess_spec_repo(self):
"""Test guess_spec_repo() and spec_from_repo() functions"""
@@ -445,9 +460,9 @@ class TestUtilityFunctions(RpmTestBase):
# Spec found
spec = guess_spec_repo(repo, 'HEAD', 'packaging', recursive=False)
spec = guess_spec_repo(repo, 'HEAD', recursive=True)
- eq_(spec.specfile, 'gbp-test.spec')
- eq_(spec.specdir, 'packaging')
- eq_(spec.specpath, 'packaging/gbp-test.spec')
+ assert spec.specfile == 'gbp-test.spec'
+ assert spec.specdir == 'packaging'
+ assert spec.specpath == 'packaging/gbp-test.spec'
# Test spec_from_repo()
assert_raises(NoSpecError, spec_from_repo,
@@ -459,6 +474,6 @@ class TestUtilityFunctions(RpmTestBase):
"""
spec = spec_from_repo(repo, 'HEAD', 'packaging/gbp-test.spec')
- eq_(spec.specfile, 'gbp-test.spec')
+ assert spec.specfile == 'gbp-test.spec'
# vim:et:ts=4:sw=4:et:sts=4:ai:set list listchars=tab\:»·,trail\:·: