diff options
Diffstat (limited to 'meta/classes/ptest.bbclass')
-rw-r--r-- | meta/classes/ptest.bbclass | 142 |
1 files changed, 0 insertions, 142 deletions
diff --git a/meta/classes/ptest.bbclass b/meta/classes/ptest.bbclass deleted file mode 100644 index 0383206a6d..0000000000 --- a/meta/classes/ptest.bbclass +++ /dev/null @@ -1,142 +0,0 @@ -# -# Copyright OpenEmbedded Contributors -# -# SPDX-License-Identifier: MIT -# - -SUMMARY:${PN}-ptest ?= "${SUMMARY} - Package test files" -DESCRIPTION:${PN}-ptest ?= "${DESCRIPTION} \ -This package contains a test directory ${PTEST_PATH} for package test purposes." - -PTEST_PATH ?= "${libdir}/${BPN}/ptest" -PTEST_BUILD_HOST_FILES ?= "Makefile" -PTEST_BUILD_HOST_PATTERN ?= "" -PTEST_PARALLEL_MAKE ?= "${PARALLEL_MAKE}" -PTEST_PARALLEL_MAKEINST ?= "${PARALLEL_MAKEINST}" -EXTRA_OEMAKE:prepend:task-compile-ptest-base = "${PTEST_PARALLEL_MAKE} " -EXTRA_OEMAKE:prepend:task-install-ptest-base = "${PTEST_PARALLEL_MAKEINST} " - -FILES:${PN}-ptest += "${PTEST_PATH}" -SECTION:${PN}-ptest = "devel" -ALLOW_EMPTY:${PN}-ptest = "1" -PTEST_ENABLED = "${@bb.utils.contains('DISTRO_FEATURES', 'ptest', '1', '0', d)}" -PTEST_ENABLED:class-native = "" -PTEST_ENABLED:class-nativesdk = "" -PTEST_ENABLED:class-cross-canadian = "" -RDEPENDS:${PN}-ptest += "${PN}" -RDEPENDS:${PN}-ptest:class-native = "" -RDEPENDS:${PN}-ptest:class-nativesdk = "" -RRECOMMENDS:${PN}-ptest += "ptest-runner" - -PACKAGES =+ "${@bb.utils.contains('PTEST_ENABLED', '1', '${PN}-ptest', '', d)}" - -require conf/distro/include/ptest-packagelists.inc - -do_configure_ptest() { - : -} - -do_configure_ptest_base() { - do_configure_ptest -} - -do_compile_ptest() { - : -} - -do_compile_ptest_base() { - do_compile_ptest -} - -do_install_ptest() { - : -} - -do_install_ptest_base() { - if [ -f ${WORKDIR}/run-ptest ]; then - install -D ${WORKDIR}/run-ptest ${D}${PTEST_PATH}/run-ptest - fi - if grep -q install-ptest: Makefile; then - oe_runmake DESTDIR=${D}${PTEST_PATH} install-ptest - fi - do_install_ptest - chown -R root:root ${D}${PTEST_PATH} - - # Strip build host paths from any installed Makefile - for filename in ${PTEST_BUILD_HOST_FILES}; do - for installed_ptest_file in $(find ${D}${PTEST_PATH} -type f -name $filename); do - bbnote "Stripping host paths from: $installed_ptest_file" - sed -e 's#${HOSTTOOLS_DIR}/*##g' \ - -e 's#${WORKDIR}/*=#.=#g' \ - -e 's#${WORKDIR}/*##g' \ - -i $installed_ptest_file - if [ -n "${PTEST_BUILD_HOST_PATTERN}" ]; then - sed -E '/${PTEST_BUILD_HOST_PATTERN}/d' \ - -i $installed_ptest_file - fi - done - done -} - -PTEST_BINDIR_PKGD_PATH = "${PKGD}${PTEST_PATH}/bin" - -# This function needs to run after apply_update_alternative_renames because the -# aforementioned function will update the ALTERNATIVE_LINK_NAME flag. Append is -# used here to make this function to run as late as possible. -PACKAGE_PREPROCESS_FUNCS:append = "${@bb.utils.contains('PTEST_BINDIR', '1', \ - bb.utils.contains('PTEST_ENABLED', '1', ' ptest_update_alternatives', '', d), '', d)}" - -python ptest_update_alternatives() { - """ - This function will generate the symlinks in the PTEST_BINDIR_PKGD_PATH - to match the renamed binaries by update-alternatives. - """ - - if not bb.data.inherits_class('update-alternatives', d) \ - or not update_alternatives_enabled(d): - return - - bb.note("Generating symlinks for ptest") - bin_paths = { d.getVar("bindir"), d.getVar("base_bindir"), - d.getVar("sbindir"), d.getVar("base_sbindir") } - ptest_bindir = d.getVar("PTEST_BINDIR_PKGD_PATH") - os.mkdir(ptest_bindir) - for pkg in (d.getVar('PACKAGES') or "").split(): - alternatives = update_alternatives_alt_targets(d, pkg) - for alt_name, alt_link, alt_target, _ in alternatives: - # Some alternatives are for man pages, - # check if the alternative is in PATH - if os.path.dirname(alt_link) in bin_paths: - os.symlink(alt_target, os.path.join(ptest_bindir, alt_name)) -} - -do_configure_ptest_base[dirs] = "${B}" -do_compile_ptest_base[dirs] = "${B}" -do_install_ptest_base[dirs] = "${B}" -do_install_ptest_base[cleandirs] = "${D}${PTEST_PATH}" - -addtask configure_ptest_base after do_configure before do_compile -addtask compile_ptest_base after do_compile before do_install -addtask install_ptest_base after do_install before do_package do_populate_sysroot - -python () { - if not bb.data.inherits_class('native', d) and not bb.data.inherits_class('cross', d): - d.setVarFlag('do_install_ptest_base', 'fakeroot', '1') - d.setVarFlag('do_install_ptest_base', 'umask', '022') - - # Remove all '*ptest_base' tasks when ptest is not enabled - if not(d.getVar('PTEST_ENABLED') == "1"): - for i in ['do_configure_ptest_base', 'do_compile_ptest_base', 'do_install_ptest_base']: - bb.build.deltask(i, d) -} - -QARECIPETEST[missing-ptest] = "package_qa_check_missing_ptest" -def package_qa_check_missing_ptest(pn, d, messages): - # This checks that ptest package is actually included - # in standard oe-core ptest images - only for oe-core recipes - if not 'meta/recipes' in d.getVar('FILE') or not(d.getVar('PTEST_ENABLED') == "1"): - return - - enabled_ptests = " ".join([d.getVar('PTESTS_FAST'), d.getVar('PTESTS_SLOW'), d.getVar('PTESTS_PROBLEMS')]).split() - if (pn + "-ptest").replace(d.getVar('MLPREFIX'), '') not in enabled_ptests: - oe.qa.handle_error("missing-ptest", "supports ptests but is not included in oe-core's ptest-packagelists.inc", d) |