mirror of
https://git.yoctoproject.org/poky
synced 2026-04-23 18:32:12 +02:00
selftest: imagefeatures.py: respect IMAGE_LINK_NAME for debugfs and manifest as well
* these cases were correctly respecting IMAGE_LINK_NAME in most tests
* the only exception was relatively wide glob for manifest:
"test-empty-image-*.manifest"
* and even wider glob for -dbg:
"*-dbg.rootfs.tar.bz2"
* replace them with the exact filename we expect for given image
* be aware that gzip won't accept the symlink in IMAGE_LINK_NAME causing:
2023-03-13 08:58:23,845 - oe-selftest - INFO - ... FAIL
2023-03-13 08:58:23,845 - oe-selftest - INFO - Traceback (most recent call last):
File "/OE/build/poky/meta/lib/oeqa/selftest/cases/imagefeatures.py", line 124, in test_bmap
self.assertTrue(runCmd('gzip -t %s' % gzip_path))
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/OE/build/poky/meta/lib/oeqa/utils/commands.py", line 214, in runCmd
raise AssertionError("Command '%s' returned non-zero exit status %d:\n%s" % (command, result.status, exc_output))
AssertionError: Command 'gzip -t /OE/build/poky/build/build-st-2023-03-12-todo-patch2/imagefeatures.ImageFeatures.test_bmap/build-st/tmp/deploy/images/qemux86-64/core-image-minimal-qemux86-64.rootfs.ext4.bmap.gz' returned non-zero exit status 1:
gzip: skipping: /OE/build/poky/build/build-st-2023-03-12-todo-patch2/imagefeatures.ImageFeatures.test_bmap/build-st/tmp/deploy/images/qemux86-64/core-image-minimal-qemux86-64.rootfs.ext4.bmap.gz is a symbolic link
* and "*-dbg.rootfs.tar.bz2" doesn't work if IMAGE_NAME_SUFFIX
is changed to anything else than ".rootfs" or moved into
IMAGE_LINK_NAME (like I plan in future changes where this will
need to be updated again).
Luckily we can use the symlink which currently doesn't have
IMAGE_NAME_SUFFIX nor the DATETIME, so we don't need to search
for it with glob, e.g. currently:
core-image-minimal-qemux86-64-dbg-20230313112546-dbg.rootfs.tar.bz2
core-image-minimal-qemux86-64-dbg.tar.bz2 -> core-image-minimal-qemux86-64-dbg-20230313112546-dbg.rootfs.tar.bz2
[YOCTO #12937]
(From OE-Core rev: 39285e981343930e41afe4eb8f2db675a85d54c2)
Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
92c9dfe1d3
commit
248f6f01cf
@@ -6,7 +6,7 @@
|
||||
|
||||
from oeqa.selftest.case import OESelftestTestCase
|
||||
from oeqa.core.decorator import OETestTag
|
||||
from oeqa.utils.commands import runCmd, bitbake, get_bb_var, runqemu
|
||||
from oeqa.utils.commands import runCmd, bitbake, get_bb_var, get_bb_vars, runqemu
|
||||
from oeqa.utils.sshcontrol import SSHControl
|
||||
import glob
|
||||
import os
|
||||
@@ -102,12 +102,11 @@ class ImageFeatures(OESelftestTestCase):
|
||||
features = 'IMAGE_FSTYPES += " ext4 ext4.bmap ext4.bmap.gz"'
|
||||
self.write_config(features)
|
||||
|
||||
image_name = 'core-image-minimal'
|
||||
bitbake(image_name)
|
||||
image = 'core-image-minimal'
|
||||
bitbake(image)
|
||||
bb_vars = get_bb_vars(['DEPLOY_DIR_IMAGE', 'IMAGE_LINK_NAME'], image)
|
||||
|
||||
deploy_dir_image = get_bb_var('DEPLOY_DIR_IMAGE')
|
||||
link_name = get_bb_var('IMAGE_LINK_NAME', image_name)
|
||||
image_path = os.path.join(deploy_dir_image, "%s.ext4" % link_name)
|
||||
image_path = os.path.join(bb_vars['DEPLOY_DIR_IMAGE'], "%s.ext4" % bb_vars['IMAGE_LINK_NAME'])
|
||||
bmap_path = "%s.bmap" % image_path
|
||||
gzip_path = "%s.gz" % bmap_path
|
||||
|
||||
@@ -120,8 +119,8 @@ class ImageFeatures(OESelftestTestCase):
|
||||
image_stat = os.stat(image_path)
|
||||
self.assertGreater(image_stat.st_size, image_stat.st_blocks * 512)
|
||||
|
||||
# check if the resulting gzip is valid
|
||||
self.assertTrue(runCmd('gzip -t %s' % gzip_path))
|
||||
# check if the resulting gzip is valid, --force is needed in case gzip_path is a symlink
|
||||
self.assertTrue(runCmd('gzip --test --force %s' % gzip_path))
|
||||
|
||||
def test_hypervisor_fmts(self):
|
||||
"""
|
||||
@@ -139,14 +138,13 @@ class ImageFeatures(OESelftestTestCase):
|
||||
features += 'IMAGE_FSTYPES += "ext4.%s"\n' % itype
|
||||
self.write_config(features)
|
||||
|
||||
image_name = 'core-image-minimal'
|
||||
bitbake(image_name)
|
||||
image = 'core-image-minimal'
|
||||
bitbake(image)
|
||||
bb_vars = get_bb_vars(['DEPLOY_DIR_IMAGE', 'IMAGE_LINK_NAME'], image)
|
||||
|
||||
deploy_dir_image = get_bb_var('DEPLOY_DIR_IMAGE')
|
||||
link_name = get_bb_var('IMAGE_LINK_NAME', image_name)
|
||||
for itype in img_types:
|
||||
image_path = os.path.join(deploy_dir_image, "%s.ext4.%s" %
|
||||
(link_name, itype))
|
||||
image_path = os.path.join(bb_vars['DEPLOY_DIR_IMAGE'], "%s.ext4.%s" %
|
||||
(bb_vars['IMAGE_LINK_NAME'], itype))
|
||||
|
||||
# check if result image file is in deploy directory
|
||||
self.assertTrue(os.path.exists(image_path))
|
||||
@@ -177,13 +175,11 @@ class ImageFeatures(OESelftestTestCase):
|
||||
features = 'IMAGE_FSTYPES += "%s %s.sha256sum"' % (conv, conv)
|
||||
self.write_config(features)
|
||||
|
||||
image_name = 'core-image-minimal'
|
||||
bitbake(image_name)
|
||||
|
||||
deploy_dir_image = get_bb_var('DEPLOY_DIR_IMAGE')
|
||||
link_name = get_bb_var('IMAGE_LINK_NAME', image_name)
|
||||
image_path = os.path.join(deploy_dir_image, "%s.%s" %
|
||||
(link_name, conv))
|
||||
image = 'core-image-minimal'
|
||||
bitbake(image)
|
||||
bb_vars = get_bb_vars(['DEPLOY_DIR_IMAGE', 'IMAGE_LINK_NAME'], image)
|
||||
image_path = os.path.join(bb_vars['DEPLOY_DIR_IMAGE'], "%s.%s" %
|
||||
(bb_vars['IMAGE_LINK_NAME'], conv))
|
||||
|
||||
# check if resulting image is in the deploy directory
|
||||
self.assertTrue(os.path.exists(image_path))
|
||||
@@ -191,7 +187,7 @@ class ImageFeatures(OESelftestTestCase):
|
||||
|
||||
# check if the resulting sha256sum agrees
|
||||
self.assertTrue(runCmd('cd %s;sha256sum -c %s.%s.sha256sum' %
|
||||
(deploy_dir_image, link_name, conv)))
|
||||
(bb_vars['DEPLOY_DIR_IMAGE'], bb_vars['IMAGE_LINK_NAME'], conv)))
|
||||
|
||||
def test_image_fstypes(self):
|
||||
"""
|
||||
@@ -200,9 +196,9 @@ class ImageFeatures(OESelftestTestCase):
|
||||
Product: oe-core
|
||||
Author: Ed Bartosh <ed.bartosh@linux.intel.com>
|
||||
"""
|
||||
image_name = 'core-image-minimal'
|
||||
image = 'core-image-minimal'
|
||||
|
||||
all_image_types = set(get_bb_var("IMAGE_TYPES", image_name).split())
|
||||
all_image_types = set(get_bb_var("IMAGE_TYPES", image).split())
|
||||
skip_image_types = set(('container', 'elf', 'f2fs', 'multiubi', 'tar.zst', 'wic.zst', 'squashfs-lzo'))
|
||||
img_types = all_image_types - skip_image_types
|
||||
|
||||
@@ -214,12 +210,11 @@ UBINIZE_ARGS ?= "-m 2048 -p 128KiB -s 512"
|
||||
""" % ' '.join(img_types)
|
||||
self.write_config(config)
|
||||
|
||||
bitbake(image_name)
|
||||
bitbake(image)
|
||||
bb_vars = get_bb_vars(['DEPLOY_DIR_IMAGE', 'IMAGE_LINK_NAME'], image)
|
||||
|
||||
deploy_dir_image = get_bb_var('DEPLOY_DIR_IMAGE')
|
||||
link_name = get_bb_var('IMAGE_LINK_NAME', image_name)
|
||||
for itype in img_types:
|
||||
image_path = os.path.join(deploy_dir_image, "%s.%s" % (link_name, itype))
|
||||
image_path = os.path.join(bb_vars['DEPLOY_DIR_IMAGE'], "%s.%s" % (bb_vars['IMAGE_LINK_NAME'], itype))
|
||||
# check if result image is in deploy directory
|
||||
self.assertTrue(os.path.exists(image_path),
|
||||
"%s image %s doesn't exist" % (itype, image_path))
|
||||
@@ -271,19 +266,20 @@ SKIP_RECIPE[busybox] = "Don't build this"
|
||||
Yeoh Ee Peng <ee.peng.yeoh@intel.com>
|
||||
"""
|
||||
|
||||
image_name = 'core-image-minimal'
|
||||
image = 'core-image-minimal'
|
||||
image_fstypes_debugfs = 'tar.bz2'
|
||||
features = 'IMAGE_GEN_DEBUGFS = "1"\n'
|
||||
features += 'IMAGE_FSTYPES_DEBUGFS = "tar.bz2"\n'
|
||||
features += 'IMAGE_FSTYPES_DEBUGFS = "%s"\n' % image_fstypes_debugfs
|
||||
self.write_config(features)
|
||||
|
||||
bitbake(image_name)
|
||||
deploy_dir_image = get_bb_var('DEPLOY_DIR_IMAGE')
|
||||
dbg_tar_file = os.path.join(deploy_dir_image, "*-dbg.rootfs.tar.bz2")
|
||||
debug_files = glob.glob(dbg_tar_file)
|
||||
self.assertNotEqual(len(debug_files), 0, 'debug filesystem not generated at %s' % dbg_tar_file)
|
||||
result = runCmd('cd %s; tar xvf %s' % (deploy_dir_image, dbg_tar_file))
|
||||
bitbake(image)
|
||||
bb_vars = get_bb_vars(['DEPLOY_DIR_IMAGE', 'IMAGE_LINK_NAME'], image)
|
||||
|
||||
dbg_tar_file = os.path.join(bb_vars['DEPLOY_DIR_IMAGE'], "%s-dbg.%s" % (bb_vars['IMAGE_LINK_NAME'], image_fstypes_debugfs))
|
||||
self.assertTrue(os.path.exists(dbg_tar_file), 'debug filesystem not generated at %s' % dbg_tar_file)
|
||||
result = runCmd('cd %s; tar xvf %s' % (bb_vars['DEPLOY_DIR_IMAGE'], dbg_tar_file))
|
||||
self.assertEqual(result.status, 0, msg='Failed to extract %s: %s' % (dbg_tar_file, result.output))
|
||||
result = runCmd('find %s -name %s' % (deploy_dir_image, "udevadm"))
|
||||
result = runCmd('find %s -name %s' % (bb_vars['DEPLOY_DIR_IMAGE'], "udevadm"))
|
||||
self.assertTrue("udevadm" in result.output, msg='Failed to find udevadm: %s' % result.output)
|
||||
dbg_symbols_targets = result.output.splitlines()
|
||||
self.assertTrue(dbg_symbols_targets, msg='Failed to split udevadm: %s' % dbg_symbols_targets)
|
||||
@@ -293,11 +289,13 @@ SKIP_RECIPE[busybox] = "Don't build this"
|
||||
|
||||
def test_empty_image(self):
|
||||
"""Test creation of image with no packages"""
|
||||
bitbake('test-empty-image')
|
||||
res_dir = get_bb_var('DEPLOY_DIR_IMAGE')
|
||||
images = os.path.join(res_dir, "test-empty-image-*.manifest")
|
||||
result = glob.glob(images)
|
||||
with open(result[1],"r") as f:
|
||||
image = 'test-empty-image'
|
||||
bitbake(image)
|
||||
bb_vars = get_bb_vars(['DEPLOY_DIR_IMAGE', 'IMAGE_LINK_NAME'], image)
|
||||
manifest = os.path.join(bb_vars['DEPLOY_DIR_IMAGE'], "%s.manifest" % bb_vars['IMAGE_LINK_NAME'])
|
||||
self.assertTrue(os.path.exists(manifest))
|
||||
|
||||
with open(manifest, "r") as f:
|
||||
self.assertEqual(len(f.read().strip()),0)
|
||||
|
||||
def test_mandb(self):
|
||||
|
||||
Reference in New Issue
Block a user