diff mbox series

[v2] pango: Restore the install tests for pango

Message ID 20250121024503.433749-1-jiaying.song.cn@windriver.com
State New
Headers show
Series [v2] pango: Restore the install tests for pango | expand

Commit Message

Song, Jiaying (CN) Jan. 21, 2025, 2:45 a.m. UTC
From: Jiaying Song <jiaying.song.cn@windriver.com>

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 <jiaying.song.cn@windriver.com>
---
 .../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

Comments

patchtest@automation.yoctoproject.org Jan. 21, 2025, 3:01 a.m. UTC | #1
Thank you for your submission. Patchtest identified one
or more issues with the patch. Please see the log below for
more information:

---
Testing patch /home/patchtest/share/mboxes/v2-pango-Restore-the-install-tests-for-pango.patch

FAIL: test Upstream-Status presence: Upstream-Status is in incorrect format (test_patch.TestPatch.test_upstream_status_presence_format)

PASS: pretest src uri left files (test_metadata.TestMetadata.pretest_src_uri_left_files)
PASS: test CVE check ignore (test_metadata.TestMetadata.test_cve_check_ignore)
PASS: test CVE tag format (test_patch.TestPatch.test_cve_tag_format)
PASS: test Signed-off-by presence (test_mbox.TestMbox.test_signed_off_by_presence)
PASS: test Signed-off-by presence (test_patch.TestPatch.test_signed_off_by_presence)
PASS: test author valid (test_mbox.TestMbox.test_author_valid)
PASS: test commit message presence (test_mbox.TestMbox.test_commit_message_presence)
PASS: test commit message user tags (test_mbox.TestMbox.test_commit_message_user_tags)
PASS: test lic files chksum modified not mentioned (test_metadata.TestMetadata.test_lic_files_chksum_modified_not_mentioned)
PASS: test max line length (test_metadata.TestMetadata.test_max_line_length)
PASS: test mbox format (test_mbox.TestMbox.test_mbox_format)
PASS: test non-AUH upgrade (test_mbox.TestMbox.test_non_auh_upgrade)
PASS: test shortlog format (test_mbox.TestMbox.test_shortlog_format)
PASS: test shortlog length (test_mbox.TestMbox.test_shortlog_length)
PASS: test src uri left files (test_metadata.TestMetadata.test_src_uri_left_files)
PASS: test target mailing list (test_mbox.TestMbox.test_target_mailing_list)

SKIP: pretest pylint: No python related patches, skipping test (test_python_pylint.PyLint.pretest_pylint)
SKIP: test bugzilla entry format: No bug ID found (test_mbox.TestMbox.test_bugzilla_entry_format)
SKIP: test lic files chksum presence: No added recipes, skipping test (test_metadata.TestMetadata.test_lic_files_chksum_presence)
SKIP: test license presence: No added recipes, skipping test (test_metadata.TestMetadata.test_license_presence)
SKIP: test pylint: No python related patches, skipping test (test_python_pylint.PyLint.test_pylint)
SKIP: test series merge on head: Merge test is disabled for now (test_mbox.TestMbox.test_series_merge_on_head)
SKIP: test summary presence: No added recipes, skipping test (test_metadata.TestMetadata.test_summary_presence)

---

Please address the issues identified and
submit a new revision of the patch, or alternatively, reply to this
email with an explanation of why the patch should be accepted. If you
believe these results are due to an error in patchtest, please submit a
bug at https://bugzilla.yoctoproject.org/ (use the 'Patchtest' category
under 'Yocto Project Subprojects'). For more information on specific
failures, see: https://wiki.yoctoproject.org/wiki/Patchtest. Thank
you!
diff mbox series

Patch

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?= <jeremy.bicha@canonical.com>
+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 <jiaying.song.cn@windriver.com>
+---
+ 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<pver>\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"