From patchwork Tue Jan 21 02:45:03 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Song, Jiaying (CN)" X-Patchwork-Id: 55878 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from aws-us-west-2-korg-lkml-1.web.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.lore.kernel.org (Postfix) with ESMTP id E06E3C02181 for ; Tue, 21 Jan 2025 02:45:09 +0000 (UTC) Received: from mx0b-0064b401.pphosted.com (mx0b-0064b401.pphosted.com [205.220.178.238]) by mx.groups.io with SMTP id smtpd.web11.7622.1737427508146028418 for ; Mon, 20 Jan 2025 18:45:08 -0800 Authentication-Results: mx.groups.io; dkim=none (message not signed); spf=permerror, err=parse error for token &{10 18 %{ir}.%{v}.%{d}.spf.has.pphosted.com}: invalid domain name (domain: windriver.com, ip: 205.220.178.238, mailfrom: prvs=3116417f34=jiaying.song.cn@windriver.com) Received: from pps.filterd (m0250811.ppops.net [127.0.0.1]) by mx0a-0064b401.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 50L2DkUx004237; Tue, 21 Jan 2025 02:45:06 GMT Received: from ala-exchng01.corp.ad.wrs.com (ala-exchng01.wrs.com [147.11.82.252]) by mx0a-0064b401.pphosted.com (PPS) with ESMTPS id 4481h0tch6-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT); Tue, 21 Jan 2025 02:45:06 +0000 (GMT) Received: from ala-exchng01.corp.ad.wrs.com (147.11.82.252) by ala-exchng01.corp.ad.wrs.com (147.11.82.252) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.43; Mon, 20 Jan 2025 18:45:05 -0800 Received: from pek-lpg-core1.wrs.com (128.224.156.132) by ala-exchng01.corp.ad.wrs.com (147.11.82.252) with Microsoft SMTP Server id 15.1.2507.43 via Frontend Transport; Mon, 20 Jan 2025 18:45:04 -0800 From: To: , Subject: [PATCH v2] pango: Restore the install tests for pango Date: Tue, 21 Jan 2025 10:45:03 +0800 Message-ID: <20250121024503.433749-1-jiaying.song.cn@windriver.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 X-Proofpoint-GUID: qP6PvdvPVD5M2DFs1NRiKt074UfqhFUn X-Authority-Analysis: v=2.4 cv=Oua1yz/t c=1 sm=1 tr=0 ts=678f0a32 cx=c_pps a=/ZJR302f846pc/tyiSlYyQ==:117 a=/ZJR302f846pc/tyiSlYyQ==:17 a=VdSt8ZQiCzkA:10 a=xNf9USuDAAAA:8 a=GHR8O2WEAAAA:20 a=t7CeM3EgAAAA:8 a=DfNHnWVPAAAA:8 a=woYHl-Inc-TQh9fTz6gA:9 a=FdTzh2GWekK77mhwV6Dw:22 a=rjTVMONInIDnV1a_A2c_:22 X-Proofpoint-ORIG-GUID: qP6PvdvPVD5M2DFs1NRiKt074UfqhFUn X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1057,Hydra:6.0.680,FMLib:17.12.68.34 definitions=2025-01-21_01,2025-01-20_03,2024-11-22_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 adultscore=0 malwarescore=0 mlxlogscore=999 spamscore=0 priorityscore=1501 clxscore=1011 mlxscore=0 suspectscore=0 bulkscore=0 phishscore=0 impostorscore=0 lowpriorityscore=0 classifier=spam authscore=0 adjust=0 reason=mlx scancount=1 engine=8.21.0-2411120000 definitions=main-2501210020 List-Id: X-Webhook-Received: from li982-79.members.linode.com [45.33.32.79] by aws-us-west-2-korg-lkml-1.web.codeaurora.org with HTTPS for ; Tue, 21 Jan 2025 02:45:09 -0000 X-Groupsio-URL: https://lists.openembedded.org/g/openembedded-core/message/210066 From: Jiaying Song Due to our use of multiple architectures, removing the install-test option severely impacts our ability to validate Pango correctly across different platforms. Moreover, the build tests provided cannot be executed in our cross-build environment. Therefore, the install-test is restored using the patch provided by upstream: https://salsa.debian.org/gnome-team/pango/-/blob/debian/latest/debian/patches/Revert-build-Drop-the-install-tests-option.patch Related discussions and commits: https://gitlab.gnome.org/GNOME/pango/-/issues/799 https://gitlab.gnome.org/GNOME/pango/-/commit/2c637453aa1ece7daa9c477b95b20d993c70ab4e https://gitlab.gnome.org/GNOME/pango/-/commit/927abccf371cd823b185a6df98d871d12601220a Partial test log: # Start of break tests ok 1 /text/break/grapheme ok 2 /text/break/word ok 3 /text/break/sentence ok 4 /text/break/line # SKIP Test file not found ok 5 /text/break/emoji ok 6 /text/break/char # End of break tests # End of text tests PASS: pango/testboundaries_ucd.test SUMMARY: total=27; passed=27; skipped=0; failed=0; user=29.6s; system=18.0s; maxrss=35328 Signed-off-by: Jiaying Song --- .../distro/include/ptest-packagelists.inc | 1 + ...-build-Drop-the-install-tests-option.patch | 316 ++++++++++++++++++ meta/recipes-graphics/pango/pango/run-ptest | 6 + meta/recipes-graphics/pango/pango_1.55.5.bb | 16 +- 4 files changed, 337 insertions(+), 2 deletions(-) create mode 100644 meta/recipes-graphics/pango/pango/0001-Revert-build-Drop-the-install-tests-option.patch create mode 100644 meta/recipes-graphics/pango/pango/run-ptest diff --git a/meta/conf/distro/include/ptest-packagelists.inc b/meta/conf/distro/include/ptest-packagelists.inc index e2a90c1c2ef..e01b7a3c346 100644 --- a/meta/conf/distro/include/ptest-packagelists.inc +++ b/meta/conf/distro/include/ptest-packagelists.inc @@ -85,6 +85,7 @@ PTESTS_FAST = "\ wayland \ xz \ zlib \ + pango \ " PTESTS_FAST:append:libc-glibc = " glibc-y2038-tests" PTESTS_PROBLEMS:remove:libc-glibc = "glibc-y2038-tests" diff --git a/meta/recipes-graphics/pango/pango/0001-Revert-build-Drop-the-install-tests-option.patch b/meta/recipes-graphics/pango/pango/0001-Revert-build-Drop-the-install-tests-option.patch new file mode 100644 index 00000000000..d79ab13dabe --- /dev/null +++ b/meta/recipes-graphics/pango/pango/0001-Revert-build-Drop-the-install-tests-option.patch @@ -0,0 +1,316 @@ +From 2e8c8aee4dc7cc069afaec3a2caaeeaa73d5b0ce Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Jeremy=20B=C3=ADcha?= +Date: Mon, 10 Jun 2024 08:52:56 -0400 +Subject: [PATCH] Revert "build: Drop the install-tests option" + +This reverts commit 2c637453aa1ece7daa9c477b95b20d993c70ab4e. + +Closes: https://gitlab.gnome.org/GNOME/pango/-/issues/799 + +Upstream-Status: Rejected [https://salsa.debian.org/gnome-team/pango/-/blob/debian/latest/debian/patches/Revert-build-Drop-the-install-tests-option.patch] +Signed-off-by: Jiaying Song +--- + meson.build | 1 + + meson.options | 5 + + tests/gen-installed-test.py | 25 +++++ + tests/meson.build | 208 +++++++++++++++++++++++++++++++++++- + 4 files changed, 237 insertions(+), 2 deletions(-) + create mode 100755 tests/gen-installed-test.py + +diff --git a/meson.build b/meson.build +index dd358fe..32bcf97 100644 +--- a/meson.build ++++ b/meson.build +@@ -590,6 +590,7 @@ summary('Introspection', gir.found(), section: 'Build') + summary('Documentation', get_option('documentation'), section: 'Build') + summary('Build Testsuite', get_option('build-testsuite'), section: 'Build') + summary('Build Examples', get_option('build-examples'), section: 'Build') ++summary('Install tests', get_option('install-tests'), section: 'Build') + + summary('prefix', pango_prefix, section: 'Directories') + summary('includedir', pango_includedir, section: 'Directories') +diff --git a/meson.options b/meson.options +index 1cf039b..72b07ee 100644 +--- a/meson.options ++++ b/meson.options +@@ -25,6 +25,11 @@ option('build-examples', + type: 'boolean', + value: true) + ++option('install-tests', ++ description : 'Install tests', ++ type: 'boolean', ++ value: false) ++ + option('fontconfig', + description : 'Build with FontConfig support. Passing \'auto\' or \'disabled\' disables fontconfig where it is optional, i.e. on Windows and macOS. Passing \'disabled\' on platforms where fontconfig is required results in error.', + type: 'feature', +diff --git a/tests/gen-installed-test.py b/tests/gen-installed-test.py +new file mode 100755 +index 0000000..eeb4abe +--- /dev/null ++++ b/tests/gen-installed-test.py +@@ -0,0 +1,25 @@ ++#!/usr/bin/env python3 ++ ++import sys ++import argparse ++import os ++ ++template = '''[Test] ++Type=session ++Exec={} ++''' ++ ++def build_template(test_dir, test_name): ++ return template.format(os.path.join(test_dir, test_name)) ++ ++if __name__ == '__main__': ++ argparser = argparse.ArgumentParser(description='Generate installed-test description file') ++ argparser.add_argument('installed_test_dir', help='Path for installed test binaries') ++ argparser.add_argument('test_name', help='Name of the test unit') ++ argparser.add_argument('out_dir', help='Path for the output') ++ ++ args = argparser.parse_args() ++ ++ outfile = os.path.join(args.out_dir, args.test_name + '.test') ++ with open(outfile, 'w') as f: ++ f.write(build_template(args.installed_test_dir, args.test_name)) +diff --git a/tests/meson.build b/tests/meson.build +index 72ea8be..c288d44 100644 +--- a/tests/meson.build ++++ b/tests/meson.build +@@ -90,24 +90,228 @@ if cairo_dep.found() + endif + endif + ++installed_test_data = [ ++ 'boundaries.utf8', ++ 'GraphemeBreakTest.txt', ++ 'WordBreakTest.txt', ++ 'SentenceBreakTest.txt', ++ 'EmojiBreakTest.txt', ++ 'CharBreakTest.txt', ++] ++ ++installed_test_layouts_data = [ ++ 'layouts/bratwurst2.layout', ++ 'layouts/bratwurst3.layout', ++ 'layouts/bratwurst4.layout', ++ 'layouts/bratwurst.layout', ++ 'layouts/effigy.layout', ++ 'layouts/kebab.layout', ++ 'layouts/tabs.layout', ++ 'layouts/tabs-nowrap.layout', ++ 'layouts/valid-1.layout', ++ 'layouts/valid-2.layout', ++ 'layouts/valid-3.layout', ++ 'layouts/valid-4.layout', ++ 'layouts/valid-5.layout', ++ 'layouts/valid-6.layout', ++ 'layouts/valid-7.layout', ++ 'layouts/valid-8.layout', ++ 'layouts/valid-9.layout', ++ 'layouts/valid-10.layout', ++ 'layouts/valid-11.layout', ++ 'layouts/valid-12.layout', ++ 'layouts/valid-13.layout', ++ 'layouts/valid-14.layout', ++ 'layouts/valid-15.layout', ++ 'layouts/valid-16.layout', ++ 'layouts/valid-17.layout', ++ 'layouts/valid-18.layout', ++ 'layouts/valid-19.layout', ++ 'layouts/valid-20.layout', ++ 'layouts/valid-21.layout', ++ 'layouts/valid-22.layout', ++ 'layouts/tab-crash.layout', ++ 'layouts/tab-assert.layout', ++ 'layouts/arabic-format.layout', ++ 'layouts/no-space.layout', ++ 'layouts/aaa.layout', ++ 'layouts/letterspacing.layout', ++ 'layouts/screaming.layout', ++] ++ ++installed_test_fontsets_data = [ ++ 'fontsets/cantarell', ++ 'fontsets/cantarell2', ++ 'fontsets/mono', ++ 'fontsets/mono2', ++] ++ ++installed_test_fonts_data = [ ++ 'fonts/amiri-06dd.ttf', ++ 'fonts/Cantarell-VF.otf', ++ 'fonts/DejaVuSans-Bold.ttf', ++ 'fonts/DejaVuSansMono.ttf', ++ 'fonts/DejaVuSans.ttf', ++ 'fonts/droid-sans-subset.ttf', ++ 'fonts/emoji-subset.ttf', ++ 'fonts/fa-regular-f2db.ttf', ++ 'fonts/fa-solid-f2db.ttf', ++ 'fonts/fonts.conf', ++ 'fonts/noto-sans-cjk.ttf', ++] ++ ++test_markups_data = [ ++ 'markups/fail-1', ++ 'markups/fail-2', ++ 'markups/fail-3', ++ 'markups/fail-4', ++ 'markups/fail-5', ++ 'markups/fail-6', ++ 'markups/fail-7', ++ 'markups/fail-8', ++ 'markups/fail-9', ++ 'markups/fail-10', ++ 'markups/fail-11', ++ 'markups/fail-12', ++ 'markups/fail-13', ++ 'markups/fail-14', ++ 'markups/fail-15', ++ 'markups/fail-16', ++ 'markups/fail-17', ++ 'markups/fail-20', ++ 'markups/fail-21', ++ 'markups/fail-22', ++ 'markups/fail-23', ++ 'markups/fail-24', ++ 'markups/fail-25', ++ 'markups/fail-26', ++ 'markups/fail-27', ++ 'markups/fail-28', ++ 'markups/fail-29', ++ 'markups/fail-30', ++ 'markups/fail-31', ++ 'markups/fail-32', ++ 'markups/fail-33', ++ 'markups/fail-34', ++ 'markups/fail-35', ++ 'markups/fail-36', ++ 'markups/fail-37', ++ 'markups/fail-38', ++ 'markups/fail-39', ++ 'markups/valid-1', ++ 'markups/valid-2', ++ 'markups/valid-3', ++ 'markups/valid-4', ++ 'markups/valid-5', ++ 'markups/valid-6', ++ 'markups/valid-7', ++ 'markups/valid-8', ++ 'markups/valid-9', ++ 'markups/valid-10', ++ 'markups/valid-11', ++ 'markups/valid-12', ++ 'markups/valid-13', ++ 'markups/valid-14', ++ 'markups/valid-15', ++ 'markups/valid-16', ++ 'markups/valid-17', ++ 'markups/valid-18', ++ 'markups/valid-19', ++ 'markups/valid-20', ++ 'markups/valid-21', ++ 'markups/valid-22', ++ 'markups/valid-23', ++ 'markups/valid-24', ++] ++ ++test_breaks_data = [ ++ 'breaks/one', ++ 'breaks/two', ++ 'breaks/three', ++ 'breaks/nine', ++ 'breaks/ten', ++ 'breaks/eleven', ++] ++ ++if thai_dep.found() ++ test_breaks_data += [ 'breaks/four', ] ++endif ++ ++test_items_data = [ ++ 'itemize/one', ++ 'itemize/two', ++] ++ ++installed_test_markups_data = [] ++foreach d: test_markups_data ++ installed_test_markups_data += d + '.markup' ++ installed_test_markups_data += d + '.expected' ++endforeach ++ ++installed_test_breaks_data = [] ++foreach d: test_breaks_data ++ installed_test_breaks_data += d + '.break' ++ installed_test_breaks_data += d + '.expected' ++endforeach ++ ++installed_test_items_data = [] ++foreach d: test_items_data ++ installed_test_items_data += d + '.items' ++ installed_test_items_data += d + '.expected' ++endforeach ++ ++installed_test_nofonts_data = [ ++ 'nofonts/fonts.conf', ++] ++ ++installed_test_datadir = join_paths(pango_datadir, 'installed-tests', 'pango') ++installed_test_bindir = join_paths(pango_libexecdir, 'installed-tests', 'pango') ++ ++if get_option('install-tests') ++ install_data(installed_test_data, install_dir: installed_test_bindir) ++ install_data(installed_test_fonts_data, install_dir: join_paths(installed_test_bindir, 'fonts')) ++ install_data(installed_test_layouts_data, install_dir: join_paths(installed_test_bindir, 'layouts')) ++ install_data(installed_test_markups_data, install_dir: join_paths(installed_test_bindir, 'markups')) ++ install_data(installed_test_breaks_data, install_dir: join_paths(installed_test_bindir, 'breaks')) ++ install_data(installed_test_items_data, install_dir: join_paths(installed_test_bindir, 'itemize')) ++ install_data(installed_test_fontsets_data, install_dir: join_paths(installed_test_bindir, 'fontsets')) ++ install_data(installed_test_nofonts_data, install_dir: join_paths(installed_test_bindir, 'nofonts')) ++endif ++ ++gen_installed_test = files([ 'gen-installed-test.py' ]) + gen_all_unicode = files([ 'gen-all-unicode.py' ]) + + custom_target('all-unicode', + output: 'all-unicode.txt', + command: [ + gen_all_unicode, '@OUTPUT@' +- ]) ++ ], ++ install: get_option('install-tests'), ++ install_dir: installed_test_bindir) + + foreach t: tests + name = t[0] + src = t.get(1, [ '@0@.c'.format(name) ]) + deps = t.get(2, [ libpango_dep ]) + ++ custom_target(name + '.test', ++ output: name + '.test', ++ command: [ ++ gen_installed_test, ++ installed_test_bindir, ++ name, ++ '@OUTDIR@', ++ ], ++ install: get_option('install-tests'), ++ install_dir: installed_test_datadir) ++ + bin = executable(name, src, + dependencies: deps, + include_directories: root_inc, + c_args: common_cflags + pango_debug_cflags + test_cflags, +- cpp_args: common_cppflags + pango_debug_cflags + test_cflags) ++ cpp_args: common_cppflags + pango_debug_cflags + test_cflags, ++ install: get_option('install-tests'), ++ install_dir: installed_test_bindir) + + test(name, bin, + args: ['-k', '--tap'], +-- +2.25.1 + diff --git a/meta/recipes-graphics/pango/pango/run-ptest b/meta/recipes-graphics/pango/pango/run-ptest new file mode 100644 index 00000000000..e1fab050ef9 --- /dev/null +++ b/meta/recipes-graphics/pango/pango/run-ptest @@ -0,0 +1,6 @@ +#! /bin/sh + +# workaround for https://gitlab.gnome.org/GNOME/pango/-/issues/668 +mkdir -p /usr/share/fonts/pango-private +cp -rf /usr/libexec/installed-tests/pango/fonts/* /usr/share/fonts/pango-private +gnome-desktop-testing-runner pango diff --git a/meta/recipes-graphics/pango/pango_1.55.5.bb b/meta/recipes-graphics/pango/pango_1.55.5.bb index 6c7242274f8..3025fe5e972 100644 --- a/meta/recipes-graphics/pango/pango_1.55.5.bb +++ b/meta/recipes-graphics/pango/pango_1.55.5.bb @@ -11,29 +11,41 @@ LICENSE = "LGPL-2.0-or-later" LIC_FILES_CHKSUM = "file://COPYING;md5=3bf50002aefd002f49e7bb854063f7e7" -inherit gnomebase gi-docgen upstream-version-is-even gobject-introspection +inherit gnomebase gi-docgen upstream-version-is-even gobject-introspection ptest-gnome UPSTREAM_CHECK_REGEX = "pango-(?P\d+\.(?!9\d+)\d+\.\d+)" GIR_MESON_ENABLE_FLAG = "enabled" GIR_MESON_DISABLE_FLAG = "disabled" +SRC_URI += "file://run-ptest \ + file://0001-Revert-build-Drop-the-install-tests-option.patch \ + " + SRC_URI[archive.sha256sum] = "e396126ea08203cbd8ef12638e6222e2e1fd8aa9cac6743072fedc5f2d820dd8" DEPENDS = "glib-2.0 glib-2.0-native fontconfig freetype virtual/libiconv cairo harfbuzz fribidi" -PACKAGECONFIG ??= "${@bb.utils.filter('DISTRO_FEATURES', 'x11', d)}" +PACKAGECONFIG ??= "${@bb.utils.filter('DISTRO_FEATURES', 'x11', d)} \ + ${@bb.utils.contains('PTEST_ENABLED', '1', 'tests', '', d)}" PACKAGECONFIG[x11] = ",,virtual/libx11 libxft" PACKAGECONFIG[thai] = "-Dlibthai=enabled,-Dlibthai=disabled,libthai" +PACKAGECONFIG[tests] = "-Dinstall-tests=true, -Dinstall-tests=false" GIR_MESON_OPTION = 'introspection' GIDOCGEN_MESON_OPTION = 'documentation' +do_configure:prepend() { + chmod +x ${S}/tests/*.py +} + LEAD_SONAME = "libpango-1.0*" FILES:${PN} = "${bindir}/* ${libdir}/libpango*${SOLIBS}" +RDEPENDS:${PN}-ptest:append:libc-glibc = " locale-base-en-us" + RPROVIDES:${PN} += "pango-modules pango-module-indic-lang \ pango-module-basic-fc pango-module-arabic-lang"