libcheck: add ghetto automake output

(From OE-Core rev: e1bf4c24697c72e9d3f58d6fa6f6f0d6fde982f6)

Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
Ross Burton 2023-05-19 15:38:44 +01:00 committed by Richard Purdie
parent 08c4b7f46d
commit 16b0f2d54e
2 changed files with 83 additions and 1 deletions

View File

@ -0,0 +1,82 @@
Add optional output in automake style, for integration with ptest.
Export CK_AUTOMAKE=1 when running a test suite and you'll get
PASS/FAIL lines on standard output.
Marking this as Inappropriate right now as it's a little rough on the
edges. Filed https://github.com/libcheck/check/issues/349 to discuss
with upstream.
Upstream-Status: Inappropriate
Signed-off-by: Ross Burton <ross.burton@arm.com>
diff --git a/src/check_log.c b/src/check_log.c
index 0844661..ad23c65 100644
--- a/src/check_log.c
+++ b/src/check_log.c
@@ -26,6 +26,7 @@
#if ENABLE_SUBUNIT
#include <subunit/child.h>
#endif
+#include <libgen.h>
#include "check_error.h"
#include "check_list.h"
@@ -381,6 +382,34 @@ void tap_lfun(SRunner * sr CK_ATTRIBUTE_UNUSED, FILE * file,
}
}
+void am_lfun(SRunner * sr CK_ATTRIBUTE_UNUSED, FILE * file,
+ enum print_output printmode CK_ATTRIBUTE_UNUSED, void *obj,
+ enum cl_event evt)
+{
+ TestResult *tr;
+ const char* types[] = { "INVALID", "PASS", "FAIL", "ERROR"};
+
+ switch (evt)
+ {
+ case CLINITLOG_SR:
+ case CLENDLOG_SR:
+ case CLSTART_SR:
+ case CLSTART_S:
+ case CLEND_SR:
+ case CLEND_S:
+ case CLSTART_T:
+ break;
+ case CLEND_T:
+ tr = (TestResult *)obj;
+ fprintf(file, "%s: %s:%s:%s %s\n",
+ types[tr->rtype], basename(tr->file), tr->tcname, tr->tname, tr->msg);
+ fflush(file);
+ break;
+ default:
+ eprintf("Bad event type received in am_lfun", __FILE__, __LINE__);
+ }
+}
+
#if ENABLE_SUBUNIT
void subunit_lfun(SRunner * sr, FILE * file, enum print_output printmode,
void *obj, enum cl_event evt)
@@ -527,6 +556,9 @@ void srunner_init_logging(SRunner * sr, enum print_output print_mode)
{
srunner_register_lfun(sr, f, f != stdout, tap_lfun, print_mode);
}
+ if (getenv("CK_AUTOMAKE"))
+ srunner_register_lfun(sr, stdout, 0, am_lfun, print_mode);
+
srunner_send_evt(sr, NULL, CLINITLOG_SR);
}
diff --git a/src/check_log.h b/src/check_log.h
index 7223b98..bfe1de3 100644
--- a/src/check_log.h
+++ b/src/check_log.h
@@ -40,6 +40,9 @@ void xml_lfun(SRunner * sr, FILE * file, enum print_output,
void tap_lfun(SRunner * sr, FILE * file, enum print_output,
void *obj, enum cl_event evt);
+void am_lfun(SRunner * sr, FILE * file, enum print_output,
+ void *obj, enum cl_event evt);
+
void subunit_lfun(SRunner * sr, FILE * file, enum print_output,
void *obj, enum cl_event evt);

View File

@ -11,6 +11,7 @@ LICENSE = "LGPL-2.1-or-later"
LIC_FILES_CHKSUM = "file://COPYING.LESSER;md5=2d5025d4aa3495befef8f17206a5b0a1"
SRC_URI = "${GITHUB_BASE_URI}/download/${PV}/check-${PV}.tar.gz \
file://automake-output.patch \
file://not-echo-compiler-info-to-check_stdint.h.patch"
SRC_URI[sha256sum] = "a8de4e0bacfb4d76dd1c618ded263523b53b85d92a146d8835eb1a52932fa20a"
GITHUB_BASE_URI = "https://github.com/libcheck/check/releases/"
@ -33,4 +34,3 @@ PACKAGES =+ "checkmk"
FILES:checkmk = "${bindir}/checkmk"
RDEPENDS:checkmk = "gawk"