mirror of
https://git.yoctoproject.org/poky
synced 2026-05-09 17:39:31 +00:00
oeqa/selftest/imagefeatures: fix RPM4 test
* Use our new runqemu function * Don't hard-code the RPM4 version * Double-check the native version is RPM4 * Check that an rpm 4.x package is in the image manifest (this isn't strictly necessary, but "belt-and-braces" and it serves as an example of how to do that) * Check that the database is working on the target * Ensure the image actually has openssh in it so we can connect to it Initial runqemu adaptation by Richard Purdie <richard.purdie@linuxfoundation.org> Part of the fix for [YOCTO #7994]. (From OE-Core rev: 80289106423746b7d7fd4c4fd181ffbae93f71d1) Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
90a52ffd44
commit
86f0232bff
@@ -78,16 +78,17 @@ class ImageFeatures(oeSelfTest):
|
|||||||
def test_rpm_version_4_support_on_image(self):
|
def test_rpm_version_4_support_on_image(self):
|
||||||
"""
|
"""
|
||||||
Summary: Check rpm version 4 support on image
|
Summary: Check rpm version 4 support on image
|
||||||
Expected: Rpm version must be 4.11.2
|
Expected: Rpm version must be 4.x
|
||||||
Product: oe-core
|
Product: oe-core
|
||||||
Author: Ionut Chisanovici <ionutx.chisanovici@intel.com>
|
Author: Ionut Chisanovici <ionutx.chisanovici@intel.com>
|
||||||
AutomatedBy: Daniel Istrate <daniel.alexandrux.istrate@intel.com>
|
AutomatedBy: Daniel Istrate <daniel.alexandrux.istrate@intel.com>
|
||||||
"""
|
"""
|
||||||
|
|
||||||
rpm_version = '4.11.2'
|
features = 'PREFERRED_VERSION_rpm = "4.%"\n'
|
||||||
features = 'IMAGE_INSTALL_append = " rpm"\n'
|
features += 'PREFERRED_VERSION_rpm-native = "4.%"\n'
|
||||||
features += 'PREFERRED_VERSION_rpm = "{}"\n'.format(rpm_version)
|
# Use openssh in IMAGE_INSTALL instead of ssh-server-openssh in EXTRA_IMAGE_FEATURES as a workaround for bug 8047
|
||||||
features += 'PREFERRED_VERSION_rpm-native = "{}"\n'.format(rpm_version)
|
features += 'IMAGE_INSTALL_append = " openssh"\n'
|
||||||
|
features += 'EXTRA_IMAGE_FEATURES = "empty-root-password allow-empty-password package-management"\n'
|
||||||
features += 'RPMROOTFSDEPENDS_remove = "rpmresolve-native:do_populate_sysroot"'
|
features += 'RPMROOTFSDEPENDS_remove = "rpmresolve-native:do_populate_sysroot"'
|
||||||
|
|
||||||
# Append 'features' to local.conf
|
# Append 'features' to local.conf
|
||||||
@@ -96,32 +97,44 @@ class ImageFeatures(oeSelfTest):
|
|||||||
# Build a core-image-minimal
|
# Build a core-image-minimal
|
||||||
bitbake('core-image-minimal')
|
bitbake('core-image-minimal')
|
||||||
|
|
||||||
# Boot qemu image & get rpm version
|
# Check the native version of rpm is correct
|
||||||
proc_qemu = pexpect.spawn('runqemu qemux86 nographic')
|
native_bindir = get_bb_var('STAGING_BINDIR_NATIVE')
|
||||||
try:
|
result = runCmd(os.path.join(native_bindir, 'rpm') + ' --version')
|
||||||
proc_qemu.expect('qemux86 login:', timeout=100)
|
self.assertIn('version 4.', result.output)
|
||||||
proc_qemu.sendline(self.root_user)
|
|
||||||
proc_qemu.expect(self.prompt)
|
|
||||||
proc_qemu.sendline('rpm --version')
|
|
||||||
proc_qemu.expect(self.prompt)
|
|
||||||
except Exception as e:
|
|
||||||
try:
|
|
||||||
killpg(proc_qemu.pid, signal.SIGTERM)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
self.fail('Failed to start qemu: %s' % e)
|
|
||||||
|
|
||||||
found_rpm_version = proc_qemu.before
|
# Check manifest for the rpm package
|
||||||
|
deploydir = get_bb_var('DEPLOY_DIR_IMAGE')
|
||||||
|
imgname = get_bb_var('IMAGE_LINK_NAME', 'core-image-minimal')
|
||||||
|
with open(os.path.join(deploydir, imgname) + '.manifest', 'r') as f:
|
||||||
|
for line in f:
|
||||||
|
splitline = line.split()
|
||||||
|
if len(splitline) > 2:
|
||||||
|
rpm_version = splitline[2]
|
||||||
|
if splitline[0] == 'rpm':
|
||||||
|
if not rpm_version.startswith('4.'):
|
||||||
|
self.fail('rpm version %s found in image, expected 4.x' % rpm_version)
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
self.fail('No rpm package found in image')
|
||||||
|
|
||||||
# Make sure the retrieved rpm version is the expected one
|
# Now do a couple of runtime tests
|
||||||
self.assertIn(rpm_version, found_rpm_version,
|
with runqemu("core-image-minimal", self) as qemu:
|
||||||
'RPM version is not {}, found instead {}.'.format(rpm_version, found_rpm_version))
|
command = "rpm --version"
|
||||||
|
status, output = qemu.run(command)
|
||||||
|
self.assertEqual(0, status, 'Failed to run command "%s": %s' % (command, output))
|
||||||
|
found_rpm_version = output.strip()
|
||||||
|
|
||||||
|
# Make sure the retrieved rpm version is the expected one
|
||||||
|
if rpm_version not in found_rpm_version:
|
||||||
|
self.fail('RPM version is not {}, found instead {}.'.format(rpm_version, found_rpm_version))
|
||||||
|
|
||||||
|
# Test that the rpm database is there and working
|
||||||
|
command = "rpm -qa"
|
||||||
|
status, output = qemu.run(command)
|
||||||
|
self.assertEqual(0, status, 'Failed to run command "%s": %s' % (command, output))
|
||||||
|
self.assertIn('packagegroup-core-boot', output)
|
||||||
|
self.assertIn('busybox', output)
|
||||||
|
|
||||||
# Cleanup (close qemu)
|
|
||||||
try:
|
|
||||||
killpg(proc_qemu.pid, signal.SIGTERM)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
@testcase(1116)
|
@testcase(1116)
|
||||||
def test_clutter_image_can_be_built(self):
|
def test_clutter_image_can_be_built(self):
|
||||||
|
|||||||
Reference in New Issue
Block a user