mirror of
git://git.yoctoproject.org/poky.git
synced 2025-07-19 12:59:02 +02:00
oeqa/selftest: Add test for conflicting sysroot provider
sysroot-test depends on virtual/sysroot-test which we build for one machine, switch machine, switch provider of virtual/sysroot-test and check that the sysroot is correctly cleaned up. The files in the two providers overlap so can cause errors if the sysroot code doesn't function correctly. Yes, sysroot-test should be machine specific really to avoid this, however the sysroot cleanup should also work. This adds a test for bug: [YOCTO #13702] (From OE-Core rev: 24ca62b3c1fd404b67d549b29aeeacf913e6dc86) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
parent
d645fe38d3
commit
f135cb3659
|
@ -0,0 +1,14 @@
|
|||
LICENSE = "CLOSED"
|
||||
|
||||
PROVIDES = "virtual/sysroot-test"
|
||||
INHIBIT_DEFAULT_DEPS = "1"
|
||||
PACKAGE_ARCH = "${MACHINE_ARCH}"
|
||||
|
||||
TESTSTRING ?= "1"
|
||||
|
||||
do_install() {
|
||||
install -d ${D}${includedir}
|
||||
echo "# test ${TESTSTRING}" > ${D}${includedir}/sysroot-test.h
|
||||
}
|
||||
|
||||
EXCLUDE_FROM_WORLD = "1"
|
|
@ -0,0 +1,14 @@
|
|||
LICENSE = "CLOSED"
|
||||
|
||||
PROVIDES = "virtual/sysroot-test"
|
||||
INHIBIT_DEFAULT_DEPS = "1"
|
||||
PACKAGE_ARCH = "${MACHINE_ARCH}"
|
||||
|
||||
TESTSTRING ?= "2"
|
||||
|
||||
do_install() {
|
||||
install -d ${D}${includedir}
|
||||
echo "# test ${TESTSTRING}" > ${D}${includedir}/sysroot-test.h
|
||||
}
|
||||
|
||||
EXCLUDE_FROM_WORLD = "1"
|
|
@ -0,0 +1,6 @@
|
|||
SUMMARY = "Virtual provider sysroot test"
|
||||
LICENSE = "CLOSED"
|
||||
INHIBIT_DEFAULT_DEPS = "1"
|
||||
DEPENDS = "virtual/sysroot-test"
|
||||
|
||||
EXCLUDE_FROM_WORLD = "1"
|
37
meta/lib/oeqa/selftest/cases/sysroot.py
Normal file
37
meta/lib/oeqa/selftest/cases/sysroot.py
Normal file
|
@ -0,0 +1,37 @@
|
|||
#
|
||||
# SPDX-License-Identifier: MIT
|
||||
#
|
||||
|
||||
import uuid
|
||||
|
||||
from oeqa.selftest.case import OESelftestTestCase
|
||||
from oeqa.utils.commands import bitbake
|
||||
|
||||
class SysrootTests(OESelftestTestCase):
|
||||
def test_sysroot_cleanup(self):
|
||||
"""
|
||||
Build sysroot test which depends on virtual/sysroot-test for one machine,
|
||||
switch machine, switch provider of virtual/sysroot-test and check that the
|
||||
sysroot is correctly cleaned up. The files in the two providers overlap
|
||||
so can cause errors if the sysroot code doesn't function correctly.
|
||||
Yes, sysroot-test should be machine specific really to avoid this, however
|
||||
the sysroot cleanup should also work [YOCTO #13702].
|
||||
"""
|
||||
|
||||
uuid1 = uuid.uuid4()
|
||||
uuid2 = uuid.uuid4()
|
||||
|
||||
self.write_config("""
|
||||
PREFERRED_PROVIDER_virtual/sysroot-test = "sysroot-test-arch1"
|
||||
MACHINE = "qemux86"
|
||||
TESTSTRING_pn-sysroot-test-arch1 = "%s"
|
||||
TESTSTRING_pn-sysroot-test-arch2 = "%s"
|
||||
""" % (uuid1, uuid2))
|
||||
bitbake("sysroot-test")
|
||||
self.write_config("""
|
||||
PREFERRED_PROVIDER_virtual/sysroot-test = "sysroot-test-arch2"
|
||||
MACHINE = "qemux86copy"
|
||||
TESTSTRING_pn-sysroot-test-arch1 = "%s"
|
||||
TESTSTRING_pn-sysroot-test-arch2 = "%s"
|
||||
""" % (uuid1, uuid2))
|
||||
bitbake("sysroot-test")
|
Loading…
Reference in New Issue
Block a user