Fix tests
Signed-off-by: Lubomír Sedlář <lsedlar@redhat.com>
This commit is contained in:
parent
11779f6644
commit
054b91c798
@ -92,8 +92,8 @@ class GatherMethodHybrid(pungi.phases.gather.method.GatherMethodBase):
|
|||||||
if arch not in self.package_maps:
|
if arch not in self.package_maps:
|
||||||
pkg_map = {}
|
pkg_map = {}
|
||||||
for pkgset in self.package_sets:
|
for pkgset in self.package_sets:
|
||||||
for pkg_arch in pkgset[arch].rpms_by_arch:
|
for pkg_arch in pkgset.package_sets[arch].rpms_by_arch:
|
||||||
for pkg in pkgset[arch].rpms_by_arch[pkg_arch]:
|
for pkg in pkgset.package_sets[arch].rpms_by_arch[pkg_arch]:
|
||||||
pkg_map[_fmt_nevra(pkg, pkg_arch)] = pkg
|
pkg_map[_fmt_nevra(pkg, pkg_arch)] = pkg
|
||||||
self.package_maps[arch] = pkg_map
|
self.package_maps[arch] = pkg_map
|
||||||
|
|
||||||
@ -119,8 +119,8 @@ class GatherMethodHybrid(pungi.phases.gather.method.GatherMethodBase):
|
|||||||
more than one debuginfo package with the same name.
|
more than one debuginfo package with the same name.
|
||||||
"""
|
"""
|
||||||
for pkgset in self.package_sets:
|
for pkgset in self.package_sets:
|
||||||
for pkg_arch in pkgset[self.arch].rpms_by_arch:
|
for pkg_arch in pkgset.package_sets[self.arch].rpms_by_arch:
|
||||||
for pkg in pkgset[self.arch].rpms_by_arch[pkg_arch]:
|
for pkg in pkgset.package_sets[self.arch].rpms_by_arch[pkg_arch]:
|
||||||
self.debuginfo[pkg.arch][pkg.name].add(pkg)
|
self.debuginfo[pkg.arch][pkg.name].add(pkg)
|
||||||
|
|
||||||
def _get_debuginfo(self, name, arch):
|
def _get_debuginfo(self, name, arch):
|
||||||
@ -134,8 +134,8 @@ class GatherMethodHybrid(pungi.phases.gather.method.GatherMethodBase):
|
|||||||
"""
|
"""
|
||||||
expanded = set()
|
expanded = set()
|
||||||
for pkgset in self.package_sets:
|
for pkgset in self.package_sets:
|
||||||
for pkg_arch in pkgset[self.arch].rpms_by_arch:
|
for pkg_arch in pkgset.package_sets[self.arch].rpms_by_arch:
|
||||||
for pkg in pkgset[self.arch].rpms_by_arch[pkg_arch]:
|
for pkg in pkgset.package_sets[self.arch].rpms_by_arch[pkg_arch]:
|
||||||
for pattern in patterns:
|
for pattern in patterns:
|
||||||
if fnmatch(pkg.name, pattern):
|
if fnmatch(pkg.name, pattern):
|
||||||
expanded.add(pkg)
|
expanded.add(pkg)
|
||||||
@ -158,8 +158,8 @@ class GatherMethodHybrid(pungi.phases.gather.method.GatherMethodBase):
|
|||||||
install_match = install % "*"
|
install_match = install % "*"
|
||||||
self.langpacks[name] = set()
|
self.langpacks[name] = set()
|
||||||
for pkgset in self.package_sets:
|
for pkgset in self.package_sets:
|
||||||
for pkg_arch in pkgset[arch].rpms_by_arch:
|
for pkg_arch in pkgset.package_sets[arch].rpms_by_arch:
|
||||||
for pkg in pkgset[arch].rpms_by_arch[pkg_arch]:
|
for pkg in pkgset.package_sets[arch].rpms_by_arch[pkg_arch]:
|
||||||
if not fnmatch(pkg.name, install_match):
|
if not fnmatch(pkg.name, install_match):
|
||||||
# Does not match the pattern, ignore...
|
# Does not match the pattern, ignore...
|
||||||
continue
|
continue
|
||||||
|
@ -187,9 +187,7 @@ class PkgsetSourceKoji(pungi.phases.pkgset.source.PkgsetSourceBase):
|
|||||||
|
|
||||||
def get_pkgset_from_koji(compose, koji_wrapper, path_prefix):
|
def get_pkgset_from_koji(compose, koji_wrapper, path_prefix):
|
||||||
event_info = get_koji_event_info(compose, koji_wrapper)
|
event_info = get_koji_event_info(compose, koji_wrapper)
|
||||||
pkgsets = populate_global_pkgset(compose, koji_wrapper, path_prefix, event_info)
|
return populate_global_pkgset(compose, koji_wrapper, path_prefix, event_info)
|
||||||
|
|
||||||
return pkgsets
|
|
||||||
|
|
||||||
|
|
||||||
def _add_module_to_variant(koji_wrapper, variant, build, add_to_variant_modules=False):
|
def _add_module_to_variant(koji_wrapper, variant, build, add_to_variant_modules=False):
|
||||||
|
@ -9,6 +9,7 @@ import sys
|
|||||||
sys.path.insert(0, os.path.join(os.path.dirname(__file__), ".."))
|
sys.path.insert(0, os.path.join(os.path.dirname(__file__), ".."))
|
||||||
|
|
||||||
from pungi.phases.gather.methods import method_hybrid as hybrid
|
from pungi.phases.gather.methods import method_hybrid as hybrid
|
||||||
|
from pungi.phases.pkgset.common import MaterializedPackageSet as PkgSet
|
||||||
from tests import helpers
|
from tests import helpers
|
||||||
|
|
||||||
|
|
||||||
@ -44,7 +45,9 @@ class TestMethodHybrid(helpers.PungiTestCase):
|
|||||||
)
|
)
|
||||||
CW.return_value.get_langpacks.return_value = {"glibc": "glibc-langpack-%s"}
|
CW.return_value.get_langpacks.return_value = {"glibc": "glibc-langpack-%s"}
|
||||||
eg.return_value = ["foo", "bar"]
|
eg.return_value = ["foo", "bar"]
|
||||||
package_sets = [{"x86_64": mock.Mock(rpms_by_arch={"x86_64": [pkg]})}]
|
package_sets = [
|
||||||
|
PkgSet({"x86_64": mock.Mock(rpms_by_arch={"x86_64": [pkg]})}, {})
|
||||||
|
]
|
||||||
arch = "x86_64"
|
arch = "x86_64"
|
||||||
variant = compose.variants["Server"]
|
variant = compose.variants["Server"]
|
||||||
|
|
||||||
@ -104,50 +107,53 @@ class TestMethodHybrid(helpers.PungiTestCase):
|
|||||||
CW.return_value.get_langpacks.return_value = {"foo": "foo-%s"}
|
CW.return_value.get_langpacks.return_value = {"foo": "foo-%s"}
|
||||||
m = hybrid.GatherMethodHybrid(compose)
|
m = hybrid.GatherMethodHybrid(compose)
|
||||||
m.package_sets = [
|
m.package_sets = [
|
||||||
{
|
PkgSet(
|
||||||
"x86_64": mock.Mock(
|
{
|
||||||
rpms_by_arch={
|
"x86_64": mock.Mock(
|
||||||
"x86_64": [
|
rpms_by_arch={
|
||||||
MockPkg(
|
"x86_64": [
|
||||||
name="foo",
|
MockPkg(
|
||||||
version="1",
|
name="foo",
|
||||||
release="2",
|
version="1",
|
||||||
arch="x86_64",
|
release="2",
|
||||||
epoch=0,
|
arch="x86_64",
|
||||||
sourcerpm=None,
|
epoch=0,
|
||||||
file_path=None,
|
sourcerpm=None,
|
||||||
),
|
file_path=None,
|
||||||
MockPkg(
|
),
|
||||||
name="foo-en",
|
MockPkg(
|
||||||
version="1",
|
name="foo-en",
|
||||||
release="2",
|
version="1",
|
||||||
arch="x86_64",
|
release="2",
|
||||||
epoch=0,
|
arch="x86_64",
|
||||||
sourcerpm=None,
|
epoch=0,
|
||||||
file_path=None,
|
sourcerpm=None,
|
||||||
),
|
file_path=None,
|
||||||
MockPkg(
|
),
|
||||||
name="foo-devel",
|
MockPkg(
|
||||||
version="1",
|
name="foo-devel",
|
||||||
release="2",
|
version="1",
|
||||||
arch="x86_64",
|
release="2",
|
||||||
epoch=0,
|
arch="x86_64",
|
||||||
sourcerpm=None,
|
epoch=0,
|
||||||
file_path=None,
|
sourcerpm=None,
|
||||||
),
|
file_path=None,
|
||||||
MockPkg(
|
),
|
||||||
name="foo-debuginfo",
|
MockPkg(
|
||||||
version="1",
|
name="foo-debuginfo",
|
||||||
release="2",
|
version="1",
|
||||||
arch="x86_64",
|
release="2",
|
||||||
epoch=0,
|
arch="x86_64",
|
||||||
sourcerpm=None,
|
epoch=0,
|
||||||
file_path=None,
|
sourcerpm=None,
|
||||||
),
|
file_path=None,
|
||||||
]
|
),
|
||||||
}
|
]
|
||||||
)
|
}
|
||||||
}
|
)
|
||||||
|
},
|
||||||
|
{},
|
||||||
|
)
|
||||||
]
|
]
|
||||||
m.prepare_langpacks("x86_64", compose.variants["Server"])
|
m.prepare_langpacks("x86_64", compose.variants["Server"])
|
||||||
|
|
||||||
@ -158,41 +164,44 @@ class TestMethodHybrid(helpers.PungiTestCase):
|
|||||||
m = hybrid.GatherMethodHybrid(compose)
|
m = hybrid.GatherMethodHybrid(compose)
|
||||||
m.arch = "x86_64"
|
m.arch = "x86_64"
|
||||||
m.package_sets = [
|
m.package_sets = [
|
||||||
{
|
PkgSet(
|
||||||
"x86_64": mock.Mock(
|
{
|
||||||
rpms_by_arch={
|
"x86_64": mock.Mock(
|
||||||
"x86_64": [
|
rpms_by_arch={
|
||||||
MockPkg(
|
"x86_64": [
|
||||||
name="foo",
|
MockPkg(
|
||||||
version="1",
|
name="foo",
|
||||||
release="2",
|
version="1",
|
||||||
arch="x86_64",
|
release="2",
|
||||||
epoch=0,
|
arch="x86_64",
|
||||||
sourcerpm=None,
|
epoch=0,
|
||||||
file_path=None,
|
sourcerpm=None,
|
||||||
),
|
file_path=None,
|
||||||
MockPkg(
|
),
|
||||||
name="foo-en",
|
MockPkg(
|
||||||
version="1",
|
name="foo-en",
|
||||||
release="2",
|
version="1",
|
||||||
arch="x86_64",
|
release="2",
|
||||||
epoch=0,
|
arch="x86_64",
|
||||||
sourcerpm=None,
|
epoch=0,
|
||||||
file_path=None,
|
sourcerpm=None,
|
||||||
),
|
file_path=None,
|
||||||
MockPkg(
|
),
|
||||||
name="bar",
|
MockPkg(
|
||||||
version="1",
|
name="bar",
|
||||||
release="2",
|
version="1",
|
||||||
arch="x86_64",
|
release="2",
|
||||||
epoch=0,
|
arch="x86_64",
|
||||||
sourcerpm=None,
|
epoch=0,
|
||||||
file_path=None,
|
sourcerpm=None,
|
||||||
),
|
file_path=None,
|
||||||
]
|
),
|
||||||
}
|
]
|
||||||
)
|
}
|
||||||
}
|
)
|
||||||
|
},
|
||||||
|
{},
|
||||||
|
)
|
||||||
]
|
]
|
||||||
expanded = m.expand_list(["foo*"])
|
expanded = m.expand_list(["foo*"])
|
||||||
|
|
||||||
@ -282,6 +291,13 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
self.phase = hybrid.GatherMethodHybrid(self.compose)
|
self.phase = hybrid.GatherMethodHybrid(self.compose)
|
||||||
self.phase.multilib_methods = []
|
self.phase.multilib_methods = []
|
||||||
self.phase.arch = "x86_64"
|
self.phase.arch = "x86_64"
|
||||||
|
self.phase.variant = self.compose.variants["Server"]
|
||||||
|
self.phase.package_sets = [
|
||||||
|
PkgSet(
|
||||||
|
{"x86_64": mock.Mock(rpms_by_arch={"x86_64": []})},
|
||||||
|
{"x86_64": "/path/for/p1"},
|
||||||
|
)
|
||||||
|
]
|
||||||
self.logfile1 = os.path.join(
|
self.logfile1 = os.path.join(
|
||||||
self.compose.topdir, "logs/x86_64/hybrid-depsolver-Server-iter-1.x86_64.log"
|
self.compose.topdir, "logs/x86_64/hybrid-depsolver-Server-iter-1.x86_64.log"
|
||||||
)
|
)
|
||||||
@ -335,7 +351,7 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
mock.call(
|
mock.call(
|
||||||
self.config1,
|
self.config1,
|
||||||
"x86_64",
|
"x86_64",
|
||||||
[self._repo("repo")],
|
["/path/for/p1"],
|
||||||
[],
|
[],
|
||||||
platform="pl",
|
platform="pl",
|
||||||
filter_packages=[("foo", None)],
|
filter_packages=[("foo", None)],
|
||||||
@ -361,7 +377,6 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
}
|
}
|
||||||
po.return_value = ([("p-1-1", "x86_64", frozenset())], ["m1"])
|
po.return_value = ([("p-1-1", "x86_64", frozenset())], ["m1"])
|
||||||
self.phase.packages = {"p-1-1.x86_64": mock.Mock()}
|
self.phase.packages = {"p-1-1.x86_64": mock.Mock()}
|
||||||
self.phase.package_sets = [{"x86_64": mock.Mock(rpms_by_arch={"x86_64": []})}]
|
|
||||||
|
|
||||||
res = self.phase.run_solver(
|
res = self.phase.run_solver(
|
||||||
self.compose.variants["Server"],
|
self.compose.variants["Server"],
|
||||||
@ -391,7 +406,7 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
mock.call(
|
mock.call(
|
||||||
self.config1,
|
self.config1,
|
||||||
"x86_64",
|
"x86_64",
|
||||||
[self._repo("repo")],
|
["/path/for/p1"],
|
||||||
[],
|
[],
|
||||||
platform="pl",
|
platform="pl",
|
||||||
filter_packages=["foo"],
|
filter_packages=["foo"],
|
||||||
@ -431,7 +446,7 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
mock.call(
|
mock.call(
|
||||||
self.config1,
|
self.config1,
|
||||||
"x86_64",
|
"x86_64",
|
||||||
[self._repo("repo")],
|
["/path/for/p1"],
|
||||||
[],
|
[],
|
||||||
platform=None,
|
platform=None,
|
||||||
filter_packages=[],
|
filter_packages=[],
|
||||||
@ -501,7 +516,7 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
mock.call(
|
mock.call(
|
||||||
self.config1,
|
self.config1,
|
||||||
"x86_64",
|
"x86_64",
|
||||||
[self._repo("repo")],
|
["/path/for/p1"],
|
||||||
[],
|
[],
|
||||||
platform=None,
|
platform=None,
|
||||||
filter_packages=[],
|
filter_packages=[],
|
||||||
@ -509,7 +524,7 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
mock.call(
|
mock.call(
|
||||||
self.config2,
|
self.config2,
|
||||||
"x86_64",
|
"x86_64",
|
||||||
[self._repo("repo")],
|
["/path/for/p1"],
|
||||||
[],
|
[],
|
||||||
platform=None,
|
platform=None,
|
||||||
filter_packages=[],
|
filter_packages=[],
|
||||||
@ -528,7 +543,6 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
"pkg-1.0-1.x86_64": mock.Mock(),
|
"pkg-1.0-1.x86_64": mock.Mock(),
|
||||||
"pkg-en-1.0-1.noarch": mock.Mock(),
|
"pkg-en-1.0-1.noarch": mock.Mock(),
|
||||||
}
|
}
|
||||||
self.phase.package_sets = [{"x86_64": mock.Mock(rpms_by_arch={"x86_64": []})}]
|
|
||||||
|
|
||||||
res = self.phase.run_solver(
|
res = self.phase.run_solver(
|
||||||
self.compose.variants["Server"],
|
self.compose.variants["Server"],
|
||||||
@ -567,7 +581,7 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
mock.call(
|
mock.call(
|
||||||
self.config1,
|
self.config1,
|
||||||
"x86_64",
|
"x86_64",
|
||||||
[self._repo("repo")],
|
["/path/for/p1"],
|
||||||
[],
|
[],
|
||||||
platform=None,
|
platform=None,
|
||||||
filter_packages=["foo"],
|
filter_packages=["foo"],
|
||||||
@ -575,7 +589,7 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
mock.call(
|
mock.call(
|
||||||
self.config2,
|
self.config2,
|
||||||
"x86_64",
|
"x86_64",
|
||||||
[self._repo("repo")],
|
["/path/for/p1"],
|
||||||
[],
|
[],
|
||||||
platform=None,
|
platform=None,
|
||||||
filter_packages=["foo"],
|
filter_packages=["foo"],
|
||||||
@ -661,7 +675,7 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
mock.call(
|
mock.call(
|
||||||
self.config1,
|
self.config1,
|
||||||
"x86_64",
|
"x86_64",
|
||||||
[self._repo("repo")],
|
["/path/for/p1"],
|
||||||
[],
|
[],
|
||||||
platform=None,
|
platform=None,
|
||||||
filter_packages=[],
|
filter_packages=[],
|
||||||
@ -669,7 +683,7 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
mock.call(
|
mock.call(
|
||||||
self.config2,
|
self.config2,
|
||||||
"x86_64",
|
"x86_64",
|
||||||
[self._repo("repo")],
|
["/path/for/p1"],
|
||||||
[],
|
[],
|
||||||
platform=None,
|
platform=None,
|
||||||
filter_packages=[],
|
filter_packages=[],
|
||||||
@ -782,7 +796,7 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
mock.call(
|
mock.call(
|
||||||
self.config1,
|
self.config1,
|
||||||
"x86_64",
|
"x86_64",
|
||||||
[self._repo("repo")],
|
["/path/for/p1"],
|
||||||
[],
|
[],
|
||||||
platform=None,
|
platform=None,
|
||||||
filter_packages=[],
|
filter_packages=[],
|
||||||
@ -790,7 +804,7 @@ class TestRunSolver(HelperMixin, helpers.PungiTestCase):
|
|||||||
mock.call(
|
mock.call(
|
||||||
self.config2,
|
self.config2,
|
||||||
"x86_64",
|
"x86_64",
|
||||||
[self._repo("repo")],
|
["/path/for/p1"],
|
||||||
[],
|
[],
|
||||||
platform=None,
|
platform=None,
|
||||||
filter_packages=[],
|
filter_packages=[],
|
||||||
|
@ -10,8 +10,6 @@ try:
|
|||||||
except ImportError:
|
except ImportError:
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
from six.moves import cPickle as pickle
|
|
||||||
|
|
||||||
sys.path.insert(0, os.path.join(os.path.dirname(__file__), ".."))
|
sys.path.insert(0, os.path.join(os.path.dirname(__file__), ".."))
|
||||||
|
|
||||||
from pungi.phases.pkgset.sources import source_koji
|
from pungi.phases.pkgset.sources import source_koji
|
||||||
@ -84,96 +82,69 @@ class TestPopulateGlobalPkgset(helpers.PungiTestCase):
|
|||||||
self.pkgset_path = os.path.join(self.topdir, 'work', 'global', 'pkgset_global.pickle')
|
self.pkgset_path = os.path.join(self.topdir, 'work', 'global', 'pkgset_global.pickle')
|
||||||
self.koji_module_path = os.path.join(self.topdir, 'work', 'global', 'koji-module-Server.yaml')
|
self.koji_module_path = os.path.join(self.topdir, 'work', 'global', 'koji-module-Server.yaml')
|
||||||
|
|
||||||
@unittest.skip("TODO not working now")
|
@mock.patch("pungi.phases.pkgset.sources.source_koji.MaterializedPackageSet.create")
|
||||||
@mock.patch('six.moves.cPickle.dumps')
|
|
||||||
@mock.patch('pungi.phases.pkgset.pkgsets.KojiPackageSet')
|
@mock.patch('pungi.phases.pkgset.pkgsets.KojiPackageSet')
|
||||||
def test_populate(self, KojiPackageSet, pickle_dumps):
|
def test_populate(self, KojiPackageSet, materialize):
|
||||||
|
materialize.side_effect = self.mock_materialize
|
||||||
pickle_dumps.return_value = b'DATA'
|
|
||||||
|
|
||||||
orig_pkgset = KojiPackageSet.return_value
|
orig_pkgset = KojiPackageSet.return_value
|
||||||
|
|
||||||
pkgset = source_koji.populate_global_pkgset(
|
pkgsets = source_koji.populate_global_pkgset(
|
||||||
self.compose, self.koji_wrapper, '/prefix', 123456)
|
self.compose, self.koji_wrapper, "/prefix", 123456
|
||||||
|
|
||||||
self.assertIs(pkgset, orig_pkgset)
|
|
||||||
self.assertEqual(
|
|
||||||
pkgset.mock_calls,
|
|
||||||
[
|
|
||||||
mock.call.populate(
|
|
||||||
'f25',
|
|
||||||
123456,
|
|
||||||
inherit=True,
|
|
||||||
logfile=self.topdir + '/logs/global/packages_from_f25.global.log',
|
|
||||||
include_packages=set(),
|
|
||||||
),
|
|
||||||
mock.call.save_file_list(
|
|
||||||
self.topdir + '/work/global/package_list/global.conf',
|
|
||||||
remove_path_prefix='/prefix',
|
|
||||||
),
|
|
||||||
mock.call.save_file_cache(
|
|
||||||
self.topdir + '/work/global/pkgset_file_cache.pickle'
|
|
||||||
),
|
|
||||||
]
|
|
||||||
)
|
)
|
||||||
self.assertItemsEqual(pickle_dumps.call_args_list,
|
|
||||||
[mock.call(orig_pkgset, protocol=pickle.HIGHEST_PROTOCOL)])
|
|
||||||
with open(self.pkgset_path) as f:
|
|
||||||
self.assertEqual(f.read(), 'DATA')
|
|
||||||
|
|
||||||
@unittest.skip("TODO not working now")
|
self.assertEqual(len(pkgsets), 1)
|
||||||
@mock.patch('six.moves.cPickle.dumps')
|
self.assertIs(pkgsets[0], orig_pkgset)
|
||||||
|
pkgsets[0].assert_has_calls(
|
||||||
|
[mock.call.populate("f25", 123456, inherit=True, include_packages=set())],
|
||||||
|
)
|
||||||
|
|
||||||
|
def mock_materialize(self, compose, pkgset, prefix, mmd):
|
||||||
|
self.assertEqual(prefix, "/prefix")
|
||||||
|
self.assertEqual(compose, self.compose)
|
||||||
|
return pkgset
|
||||||
|
|
||||||
|
@mock.patch("pungi.phases.pkgset.sources.source_koji.MaterializedPackageSet.create")
|
||||||
@mock.patch('pungi.phases.pkgset.pkgsets.KojiPackageSet')
|
@mock.patch('pungi.phases.pkgset.pkgsets.KojiPackageSet')
|
||||||
def test_populate_with_multiple_koji_tags(self, KojiPackageSet, pickle_dumps):
|
def test_populate_with_multiple_koji_tags(
|
||||||
|
self, KojiPackageSet, materialize
|
||||||
|
):
|
||||||
self.compose = helpers.DummyCompose(self.topdir, {
|
self.compose = helpers.DummyCompose(self.topdir, {
|
||||||
'pkgset_koji_tag': ['f25', 'f25-extra'],
|
'pkgset_koji_tag': ['f25', 'f25-extra'],
|
||||||
'sigkeys': ["foo", "bar"],
|
'sigkeys': ["foo", "bar"],
|
||||||
})
|
})
|
||||||
|
|
||||||
pickle_dumps.return_value = b'DATA'
|
materialize.side_effect = self.mock_materialize
|
||||||
|
|
||||||
orig_pkgset = KojiPackageSet.return_value
|
pkgsets = source_koji.populate_global_pkgset(
|
||||||
|
self.compose, self.koji_wrapper, "/prefix", 123456
|
||||||
|
)
|
||||||
|
|
||||||
pkgset = source_koji.populate_global_pkgset(
|
self.assertEqual(len(pkgsets), 2)
|
||||||
self.compose, self.koji_wrapper, '/prefix', 123456)
|
init_calls = KojiPackageSet.call_args_list
|
||||||
|
self.assertItemsEqual([call[0][0] for call in init_calls], ["f25", "f25-extra"])
|
||||||
|
self.assertItemsEqual(
|
||||||
|
[call[0][1] for call in init_calls], [self.koji_wrapper] * 2
|
||||||
|
)
|
||||||
|
self.assertItemsEqual(
|
||||||
|
[call[0][2] for call in init_calls], [["foo", "bar"]] * 2
|
||||||
|
)
|
||||||
|
|
||||||
self.assertIs(pkgset, orig_pkgset)
|
pkgsets[0].assert_has_calls(
|
||||||
pkgset.assert_has_calls(
|
[mock.call.populate("f25", 123456, inherit=True, include_packages=set())]
|
||||||
|
)
|
||||||
|
pkgsets[1].assert_has_calls(
|
||||||
[
|
[
|
||||||
mock.call.populate(
|
mock.call.populate(
|
||||||
'f25',
|
"f25-extra", 123456, inherit=True, include_packages=set()
|
||||||
123456,
|
|
||||||
inherit=True,
|
|
||||||
logfile=self.topdir + '/logs/global/packages_from_f25.global.log',
|
|
||||||
include_packages=set(),
|
|
||||||
),
|
),
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
pkgset.assert_has_calls(
|
|
||||||
[
|
|
||||||
mock.call.populate(
|
|
||||||
'f25-extra',
|
|
||||||
123456,
|
|
||||||
inherit=True,
|
|
||||||
logfile=self.topdir + '/logs/global/packages_from_f25-extra.global.log',
|
|
||||||
include_packages=set(),
|
|
||||||
),
|
|
||||||
]
|
|
||||||
)
|
|
||||||
pkgset.assert_has_calls([mock.call.save_file_list(self.topdir + '/work/global/package_list/global.conf',
|
|
||||||
remove_path_prefix='/prefix')])
|
|
||||||
# for each tag, call pkgset.fast_merge once for each variant and once for global pkgset
|
|
||||||
self.assertEqual(pkgset.fast_merge.call_count, 2 * (len(self.compose.all_variants.values()) + 1))
|
|
||||||
self.assertItemsEqual(pickle_dumps.call_args_list,
|
|
||||||
[mock.call(orig_pkgset, protocol=pickle.HIGHEST_PROTOCOL)])
|
|
||||||
with open(self.pkgset_path) as f:
|
|
||||||
self.assertEqual(f.read(), 'DATA')
|
|
||||||
|
|
||||||
@mock.patch('six.moves.cPickle.dumps')
|
@mock.patch("pungi.phases.pkgset.sources.source_koji.MaterializedPackageSet.create")
|
||||||
@mock.patch('pungi.phases.pkgset.pkgsets.KojiPackageSet.populate')
|
@mock.patch('pungi.phases.pkgset.pkgsets.KojiPackageSet.populate')
|
||||||
@mock.patch('pungi.phases.pkgset.pkgsets.KojiPackageSet.save_file_list')
|
@mock.patch('pungi.phases.pkgset.pkgsets.KojiPackageSet.save_file_list')
|
||||||
def test_populate_packages_to_gather(self, save_file_list, popuplate,
|
def test_populate_packages_to_gather(self, save_file_list, popuplate, materialize):
|
||||||
pickle_dumps):
|
|
||||||
self.compose = helpers.DummyCompose(self.topdir, {
|
self.compose = helpers.DummyCompose(self.topdir, {
|
||||||
'gather_method': 'nodeps',
|
'gather_method': 'nodeps',
|
||||||
'pkgset_koji_tag': 'f25',
|
'pkgset_koji_tag': 'f25',
|
||||||
@ -182,7 +153,8 @@ class TestPopulateGlobalPkgset(helpers.PungiTestCase):
|
|||||||
('.*', {'*': ['pkg', 'foo.x86_64']}),
|
('.*', {'*': ['pkg', 'foo.x86_64']}),
|
||||||
]
|
]
|
||||||
})
|
})
|
||||||
pickle_dumps.return_value = b'DATA'
|
|
||||||
|
materialize.side_effect = self.mock_materialize
|
||||||
|
|
||||||
pkgsets = source_koji.populate_global_pkgset(
|
pkgsets = source_koji.populate_global_pkgset(
|
||||||
self.compose, self.koji_wrapper, '/prefix', 123456)
|
self.compose, self.koji_wrapper, '/prefix', 123456)
|
||||||
@ -201,43 +173,21 @@ class TestGetPackageSetFromKoji(helpers.PungiTestCase):
|
|||||||
self.koji_wrapper.koji_proxy.getLastEvent.return_value = EVENT_INFO
|
self.koji_wrapper.koji_proxy.getLastEvent.return_value = EVENT_INFO
|
||||||
self.koji_wrapper.koji_proxy.getTag.return_value = TAG_INFO
|
self.koji_wrapper.koji_proxy.getTag.return_value = TAG_INFO
|
||||||
|
|
||||||
@unittest.skip("TODO not working now")
|
|
||||||
@mock.patch('pungi.phases.pkgset.common.create_arch_repos')
|
|
||||||
@mock.patch('pungi.phases.pkgset.sources.source_koji.populate_global_pkgset')
|
@mock.patch('pungi.phases.pkgset.sources.source_koji.populate_global_pkgset')
|
||||||
def test_get_package_sets(self, pgp, car):
|
def test_get_package_sets(self, pgp):
|
||||||
expected = {"x86_64": mock.Mock(), "global": pgp.return_value}
|
pkgsets = source_koji.get_pkgset_from_koji(
|
||||||
|
self.compose, self.koji_wrapper, "/prefix"
|
||||||
def mock_create_arch_repos(compose, path_prefix, paths):
|
)
|
||||||
for arch in compose.get_arches():
|
|
||||||
paths[arch] = "/repo/for/" + arch
|
|
||||||
|
|
||||||
car.side_effect = mock_create_arch_repos
|
|
||||||
|
|
||||||
pkgsets = source_koji.get_pkgset_from_koji(self.compose, self.koji_wrapper, '/prefix')
|
|
||||||
|
|
||||||
self.assertItemsEqual(
|
self.assertItemsEqual(
|
||||||
self.koji_wrapper.koji_proxy.mock_calls,
|
self.koji_wrapper.koji_proxy.mock_calls,
|
||||||
[mock.call.getLastEvent()]
|
[mock.call.getLastEvent()]
|
||||||
)
|
)
|
||||||
|
self.assertEqual(pkgsets, pgp.return_value)
|
||||||
|
|
||||||
self.assertEqual(len(pkgsets), 1)
|
|
||||||
self.assertEqual(pgp.call_args_list,
|
|
||||||
[mock.call(self.compose, self.koji_wrapper, '/prefix',
|
|
||||||
EVENT_INFO)])
|
|
||||||
global_repo = os.path.join(self.topdir, "work/global/repo")
|
|
||||||
self.assertItemsEqual(
|
|
||||||
car.call_args_list,
|
|
||||||
[mock.call(self.compose, "/prefix", pkgsets[0].paths)],
|
|
||||||
)
|
|
||||||
|
|
||||||
self.assertEqual(pkgsets[0].package_sets, expected)
|
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
pkgsets[0].paths,
|
pgp.call_args_list,
|
||||||
{
|
[mock.call(self.compose, self.koji_wrapper, '/prefix', EVENT_INFO)],
|
||||||
"amd64": "/repo/for/amd64",
|
|
||||||
"global": global_repo,
|
|
||||||
"x86_64": "/repo/for/x86_64",
|
|
||||||
}
|
|
||||||
)
|
)
|
||||||
|
|
||||||
def test_get_koji_modules(self):
|
def test_get_koji_modules(self):
|
||||||
|
Loading…
Reference in New Issue
Block a user