From patchwork Wed May 13 17:08:57 2026 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Peter Marko X-Patchwork-Id: 88062 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 2FD19CD4F3D for ; Wed, 13 May 2026 17:10:36 +0000 (UTC) Received: from mta-65-226.siemens.flowmailer.net (mta-65-226.siemens.flowmailer.net [185.136.65.226]) by mx.groups.io with SMTP id smtpd.msgproc01-g2.2441.1778692234180544069 for ; Wed, 13 May 2026 10:10:34 -0700 Authentication-Results: mx.groups.io; dkim=pass header.i=peter.marko@siemens.com header.s=fm1 header.b=ZENhecJS; spf=pass (domain: rts-flowmailer.siemens.com, ip: 185.136.65.226, mailfrom: fm-256628-202605131710327733b4e826000207e2-hvm7ki@rts-flowmailer.siemens.com) Received: by mta-65-226.siemens.flowmailer.net with ESMTPSA id 202605131710327733b4e826000207e2 for ; Wed, 13 May 2026 19:10:32 +0200 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; s=fm1; d=siemens.com; i=peter.marko@siemens.com; h=Date:From:Subject:To:Message-ID:MIME-Version:Content-Type:Content-Transfer-Encoding:Cc:References:In-Reply-To; bh=BuXFSww+M9RkJAOQto9+zLwMawiPKmKiNWggxDnv1cU=; b=ZENhecJSu+RFNeB8lI42EjLgOxuwimqJ6HCs/9EjYrZa35mNySeZ2irVTKP04q+dTEFikc Uaejlp4IT1MDqHCc2U9/ksA1hux3bTIs8OQBA6uH/OmuCNgHRuEMQYQfmKGgq6mfKNLBMdl7 W2TpYndzjD468NDw2gNhOUea3B2QufrnZ/wQUAn/lICKGyeedhyd/kYIaxGpXFjVLe+Ub9DF 27+YRVSQssipGwBGhv50g/tThnn/R5lDQqTywjzCnfDDBmGAkVgexivwhGLsrkTbssYqS3g0 7kadlotAzv7SYoy5lv2zQndgqRwkmLFpiv0yBUgK9hz1pXJQThlixngg==; From: Peter Marko To: yocto-patches@lists.yoctoproject.org Cc: peter.marko@siemens.com, jose.quaresma@foundries.io Subject: [meta-lts-mixins][scarthgap/go][PATCH 3/7] go: add ptest support Date: Wed, 13 May 2026 19:08:57 +0200 Message-ID: <20260513170902.2468061-3-peter.marko@siemens.com> In-Reply-To: <20260513170902.2468061-1-peter.marko@siemens.com> References: <20260513170902.2468061-1-peter.marko@siemens.com> MIME-Version: 1.0 X-Flowmailer-Platform: Siemens Feedback-ID: 519:519-256628:519-21489:flowmailer List-Id: X-Webhook-Received: from 45-33-107-173.ip.linodeusercontent.com [45.33.107.173] by aws-us-west-2-korg-lkml-1.web.codeaurora.org with HTTPS for ; Wed, 13 May 2026 17:10:36 -0000 X-Groupsio-URL: https://lists.yoctoproject.org/g/yocto-patches/message/3985 From: Pratik Farkase Add ptest infrastructure to test the Go standard library. - Run 'go test -short std' via run-ptest script - Install source tree and pkg/include headers - Create VERSION file for architecture detection - Exclude multi-arch binary testdata to avoid QA errors Signed-off-by: Pratik Farkase Signed-off-by: Mathieu Dubois-Briand (From OE-Core rev: 9ca41405e6bca276468a3b6f67eaa328b8016485) Signed-off-by: Peter Marko --- conf/layer.conf | 2 ++ recipes-core/images/core-image-ptest.bbappend | 6 ++++ recipes-devtools/go/go-1.26.2.inc | 1 + recipes-devtools/go/go/run-ptest | 32 +++++++++++++++++++ recipes-devtools/go/go_1.26.2.bb | 27 +++++++++++++++- 5 files changed, 67 insertions(+), 1 deletion(-) create mode 100644 recipes-core/images/core-image-ptest.bbappend create mode 100755 recipes-devtools/go/go/run-ptest diff --git a/conf/layer.conf b/conf/layer.conf index 6dd3c62..f621052 100644 --- a/conf/layer.conf +++ b/conf/layer.conf @@ -15,3 +15,5 @@ LAYERDEPENDS_lts-go-mixin = " \ " GOVERSION = "1.26%" + +PTESTS_SLOW:append = " go" diff --git a/recipes-core/images/core-image-ptest.bbappend b/recipes-core/images/core-image-ptest.bbappend new file mode 100644 index 0000000..835487c --- /dev/null +++ b/recipes-core/images/core-image-ptest.bbappend @@ -0,0 +1,6 @@ +PTEST_RUNNER_TIMEOUT:virtclass-mcextend-go = "4800" + +# golang go-ptest requires extra space +IMAGE_ROOTFS_EXTRA_SPACE:virtclass-mcextend-go = "1524288" + +QB_MEM:virtclass-mcextend-go = "-m 4096" diff --git a/recipes-devtools/go/go-1.26.2.inc b/recipes-devtools/go/go-1.26.2.inc index 8bb10bc..c53e828 100644 --- a/recipes-devtools/go/go-1.26.2.inc +++ b/recipes-devtools/go/go-1.26.2.inc @@ -16,5 +16,6 @@ SRC_URI += "\ file://0009-go-Filter-build-paths-on-staticly-linked-arches.patch \ file://0010-cmd-go-clear-GOROOT-for-func-ldShared-when-trimpath-.patch \ file://0011-cmd-link-stop-forcing-binutils-gold-dependency-on-aa.patch \ + file://run-ptest \ " SRC_URI[main.sha256sum] = "2e91ebb6947a96e9436fb2b3926a8802efe63a6d375dffec4f82aa9dbd6fd43b" diff --git a/recipes-devtools/go/go/run-ptest b/recipes-devtools/go/go/run-ptest new file mode 100755 index 0000000..ac020de --- /dev/null +++ b/recipes-devtools/go/go/run-ptest @@ -0,0 +1,32 @@ +#!/bin/sh + +PTEST_DIR=/usr/lib/go/ptest +GOROOT=/usr/lib/go + +export GOROOT +export PATH=$GOROOT/bin:$PATH +export ZONEINFO=/usr/share/zoneinfo + +ln -sf $PTEST_DIR/src $GOROOT/src +mkdir -p $GOROOT/pkg/include +cp $PTEST_DIR/pkg/include/* $GOROOT/pkg/include/ +cp $PTEST_DIR/VERSION $GOROOT/VERSION + +cd $GOROOT + +SKIP_PKGS="debug/dwarf debug/elf debug/pe debug/plan9obj go/types internal/xcoff net/http runtime testing time" + +SKIP_REGEX=$(echo "$SKIP_PKGS" | sed 's/ /|/g') + +for pkg in $(go list std); do + if echo "$pkg" | grep -qE "^($SKIP_REGEX)$"; then + echo "SKIP: $pkg" + continue + fi + + if go test -short "$pkg" >/dev/null 2>&1; then + echo "PASS: $pkg" + else + echo "FAIL: $pkg" + fi +done diff --git a/recipes-devtools/go/go_1.26.2.bb b/recipes-devtools/go/go_1.26.2.bb index 46f5fbc..35a14b8 100644 --- a/recipes-devtools/go/go_1.26.2.bb +++ b/recipes-devtools/go/go_1.26.2.bb @@ -1,7 +1,7 @@ require go-${PV}.inc require go-target.inc -inherit linuxloader +inherit linuxloader ptest CGO_LDFLAGS:append = " -no-pie" @@ -16,3 +16,28 @@ python() { d.appendVar('INSANE_SKIP:%s' % d.getVar('PN'), " textrel") } +do_install_ptest() { + install -d ${D}${PTEST_PATH}/src + install -d ${D}${PTEST_PATH}/pkg/include + + cp ${S}/pkg/include/* ${D}${PTEST_PATH}/pkg/include/ + echo "go${PV}" > ${D}${PTEST_PATH}/VERSION + + cd ${S}/src + find . -type d -exec install -d ${D}${PTEST_PATH}/src/{} \; + find . -type f \ + ! -path "*/testdata/*.elf*" \ + ! -path "*/testdata/*-x86-64*" \ + ! -path "*/testdata/*.obj" \ + ! -path "*/testdata/*.syso" \ + ! -path "*/testdata/*.so" \ + ! -path "*/testdata/*.so_" \ + ! -path "*/testdata/*-exec" \ + ! -path "*/testdata/test32*" \ + ! -path "*/testdata/test64*" \ + ! -path "*/race/*.syso" \ + ! -path "*/boring/syso/*.syso" \ + -exec install -m 0644 {} ${D}${PTEST_PATH}/src/{} \; +} + +RDEPENDS:${PN}-ptest += "bash tzdata git packagegroup-core-buildessential"