tests: Add tests for _install_branding with and without variant
This adds tests to make sure that the changes to _install_branding are working as expected. Related: rhbz#1472622
This commit is contained in:
parent
d22ebad3d2
commit
6473143f44
@ -8,7 +8,8 @@ RUN yum -y install --nogpgcheck epel-release && \
|
|||||||
python-coverage libselinux-python sudo \
|
python-coverage libselinux-python sudo \
|
||||||
pykickstart python2-pytoml python-sphinx \
|
pykickstart python2-pytoml python-sphinx \
|
||||||
python2-mock python-semantic_version \
|
python2-mock python-semantic_version \
|
||||||
anaconda-tui python-gevent beakerlib && \
|
anaconda-tui python-gevent beakerlib \
|
||||||
|
python2-rpmfluff && \
|
||||||
yum clean all && \
|
yum clean all && \
|
||||||
rm -rf /var/cache/yum && \
|
rm -rf /var/cache/yum && \
|
||||||
useradd weldr
|
useradd weldr
|
||||||
|
@ -22,7 +22,7 @@ import tempfile
|
|||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
from pylorax import ArchData, DataHolder
|
from pylorax import ArchData, DataHolder
|
||||||
from pylorax.dnfbase import get_dnf_base_object
|
from pylorax.yumbase import get_yum_base_object
|
||||||
from pylorax.treebuilder import RuntimeBuilder
|
from pylorax.treebuilder import RuntimeBuilder
|
||||||
|
|
||||||
# TODO Put these into a common test library location
|
# TODO Put these into a common test library location
|
||||||
@ -38,6 +38,15 @@ def in_tempdir(prefix='tmp'):
|
|||||||
os.chdir(oldcwd)
|
os.chdir(oldcwd)
|
||||||
shutil.rmtree(tmpdir)
|
shutil.rmtree(tmpdir)
|
||||||
|
|
||||||
|
@contextmanager
|
||||||
|
def TemporaryDirectory(prefix='tmp'):
|
||||||
|
"""Execute a block of code with a temporary directory"""
|
||||||
|
tmpdir = tempfile.mkdtemp(prefix=prefix)
|
||||||
|
try:
|
||||||
|
yield tmpdir
|
||||||
|
finally:
|
||||||
|
shutil.rmtree(tmpdir)
|
||||||
|
|
||||||
def makeFakeRPM(repo_dir, name, epoch, version, release, files=None, provides=None):
|
def makeFakeRPM(repo_dir, name, epoch, version, release, files=None, provides=None):
|
||||||
"""Make a fake rpm file in repo_dir"""
|
"""Make a fake rpm file in repo_dir"""
|
||||||
if provides is None:
|
if provides is None:
|
||||||
@ -64,24 +73,24 @@ def makeFakeRPM(repo_dir, name, epoch, version, release, files=None, provides=No
|
|||||||
class InstallBrandingTestCase(unittest.TestCase):
|
class InstallBrandingTestCase(unittest.TestCase):
|
||||||
def install_branding(self, repo_dir, variant=None):
|
def install_branding(self, repo_dir, variant=None):
|
||||||
"""Run the _install_branding and return the names of the installed packages"""
|
"""Run the _install_branding and return the names of the installed packages"""
|
||||||
with tempfile.TemporaryDirectory(prefix="lorax.test.") as root_dir:
|
with TemporaryDirectory(prefix="lorax.test.") as root_dir:
|
||||||
dbo = get_dnf_base_object(root_dir, ["file://"+repo_dir], enablerepos=[], disablerepos=[])
|
ybo = get_yum_base_object(root_dir, ["file://"+repo_dir])
|
||||||
self.assertTrue(dbo is not None)
|
self.assertTrue(ybo is not None)
|
||||||
|
|
||||||
product = DataHolder(name="Fedora", version="33", release="33",
|
product = DataHolder(name="Fedora", version="33", release="33",
|
||||||
variant=variant, bugurl="http://none", isfinal=True)
|
variant=variant, bugurl="http://none", isfinal=True)
|
||||||
arch = ArchData(os.uname().machine)
|
arch = ArchData(os.uname()[4])
|
||||||
rb = RuntimeBuilder(product, arch, dbo)
|
rb = RuntimeBuilder(product, arch, ybo)
|
||||||
rb._install_branding()
|
rb._install_branding()
|
||||||
dbo.resolve()
|
(rc, msg) = ybo.buildTransaction()
|
||||||
self.assertTrue(dbo.transaction is not None)
|
self.assertTrue(rc in [0, 1, 2])
|
||||||
|
ybo.tsInfo.makelists()
|
||||||
return sorted(p.name for p in dbo.transaction.install_set)
|
return sorted([tm.po.name for tm in ybo.tsInfo.installed + ybo.tsInfo.depinstalled])
|
||||||
|
|
||||||
def test_no_pkgs(self):
|
def test_no_pkgs(self):
|
||||||
"""Test with a repo with no system-release packages"""
|
"""Test with a repo with no system-release packages"""
|
||||||
# No system-release packages
|
# No system-release packages
|
||||||
with tempfile.TemporaryDirectory(prefix="lorax.test.repo.") as repo_dir:
|
with TemporaryDirectory(prefix="lorax.test.repo.") as repo_dir:
|
||||||
makeFakeRPM(repo_dir, "fake-milhouse", 0, "1.0.0", "1")
|
makeFakeRPM(repo_dir, "fake-milhouse", 0, "1.0.0", "1")
|
||||||
os.system("createrepo_c " + repo_dir)
|
os.system("createrepo_c " + repo_dir)
|
||||||
|
|
||||||
@ -91,7 +100,7 @@ class InstallBrandingTestCase(unittest.TestCase):
|
|||||||
def test_generic_pkg(self):
|
def test_generic_pkg(self):
|
||||||
"""Test with a repo with only a generic-release package"""
|
"""Test with a repo with only a generic-release package"""
|
||||||
# Only generic-release
|
# Only generic-release
|
||||||
with tempfile.TemporaryDirectory(prefix="lorax.test.repo.") as repo_dir:
|
with TemporaryDirectory(prefix="lorax.test.repo.") as repo_dir:
|
||||||
makeFakeRPM(repo_dir, "generic-release", 0, "33", "1", ["/etc/system-release"], ["system-release"])
|
makeFakeRPM(repo_dir, "generic-release", 0, "33", "1", ["/etc/system-release"], ["system-release"])
|
||||||
os.system("createrepo_c " + repo_dir)
|
os.system("createrepo_c " + repo_dir)
|
||||||
|
|
||||||
@ -101,7 +110,7 @@ class InstallBrandingTestCase(unittest.TestCase):
|
|||||||
def test_two_pkgs(self):
|
def test_two_pkgs(self):
|
||||||
"""Test with a repo with generic-release, and a fedora-release package"""
|
"""Test with a repo with generic-release, and a fedora-release package"""
|
||||||
# Two system-release packages
|
# Two system-release packages
|
||||||
with tempfile.TemporaryDirectory(prefix="lorax.test.repo.") as repo_dir:
|
with TemporaryDirectory(prefix="lorax.test.repo.") as repo_dir:
|
||||||
makeFakeRPM(repo_dir, "generic-release", 0, "33", "1", ["/etc/system-release"], ["system-release"])
|
makeFakeRPM(repo_dir, "generic-release", 0, "33", "1", ["/etc/system-release"], ["system-release"])
|
||||||
makeFakeRPM(repo_dir, "fedora-release", 0, "33", "1", ["/etc/system-release"], ["system-release"])
|
makeFakeRPM(repo_dir, "fedora-release", 0, "33", "1", ["/etc/system-release"], ["system-release"])
|
||||||
makeFakeRPM(repo_dir, "fedora-logos", 0, "33", "1")
|
makeFakeRPM(repo_dir, "fedora-logos", 0, "33", "1")
|
||||||
@ -117,7 +126,7 @@ class InstallBrandingTestCase(unittest.TestCase):
|
|||||||
def test_three_pkgs(self):
|
def test_three_pkgs(self):
|
||||||
"""Test with a repo with generic-release, fedora-release, fedora-release-workstation package"""
|
"""Test with a repo with generic-release, fedora-release, fedora-release-workstation package"""
|
||||||
# Three system-release packages, one with a variant suffix
|
# Three system-release packages, one with a variant suffix
|
||||||
with tempfile.TemporaryDirectory(prefix="lorax.test.repo.") as repo_dir:
|
with TemporaryDirectory(prefix="lorax.test.repo.") as repo_dir:
|
||||||
makeFakeRPM(repo_dir, "generic-release", 0, "33", "1", ["/etc/system-release"], ["system-release"])
|
makeFakeRPM(repo_dir, "generic-release", 0, "33", "1", ["/etc/system-release"], ["system-release"])
|
||||||
makeFakeRPM(repo_dir, "fedora-release", 0, "33", "1", ["/etc/system-release"], ["system-release"])
|
makeFakeRPM(repo_dir, "fedora-release", 0, "33", "1", ["/etc/system-release"], ["system-release"])
|
||||||
makeFakeRPM(repo_dir, "fedora-logos", 0, "33", "1")
|
makeFakeRPM(repo_dir, "fedora-logos", 0, "33", "1")
|
||||||
|
Loading…
Reference in New Issue
Block a user