|
@@ -0,0 +1,661 @@
|
|
|
|
+From ec8bd87077355207d9466b0ecef5246295ee0672 Mon Sep 17 00:00:00 2001
|
|
|
|
+From: Patrick Steinhardt <ps@pks.im>
|
|
|
|
+Date: Mon, 21 Oct 2024 12:56:33 +0200
|
|
|
|
+Subject: [PATCH] t/unit-tests: update clar to 206accb
|
|
|
|
+
|
|
|
|
+Update clar from:
|
|
|
|
+
|
|
|
|
+ - 1516124 (Merge pull request #97 from pks-t/pks-whitespace-fixes, 2024-08-15).
|
|
|
|
+
|
|
|
|
+To:
|
|
|
|
+
|
|
|
|
+ - 206accb (Merge pull request #108 from pks-t/pks-uclibc-without-wchar, 2024-10-21)
|
|
|
|
+
|
|
|
|
+This update includes a bunch of fixes and improvements that we have
|
|
|
|
+discussed in Git when initial support for clar was merged:
|
|
|
|
+
|
|
|
|
+ - There is a ".editorconfig" file now.
|
|
|
|
+
|
|
|
|
+ - Compatibility with Windows has been improved so that the clar
|
|
|
|
+ compiles on this platform without an issue. This has been tested
|
|
|
|
+ with Cygwin, MinGW and Microsoft Visual Studio.
|
|
|
|
+
|
|
|
|
+ - clar now uses CMake. This does not impact us at all as we wire up
|
|
|
|
+ the clar into our own build infrastructure anyway. This conversion
|
|
|
|
+ was done such that we can easily run CI jobs against Windows.
|
|
|
|
+
|
|
|
|
+ - Allocation failures are now checked for consistently.
|
|
|
|
+
|
|
|
|
+ - We now define feature test macros in "clar.c", which fixes
|
|
|
|
+ compilation on some platforms that didn't previously pull in
|
|
|
|
+ non-standard functions like lstat(3p) or strdup(3p). This was
|
|
|
|
+ reported by a user of OpenSUSE Leap.
|
|
|
|
+
|
|
|
|
+ - We stop using `struct timezone`, which is undefined behaviour
|
|
|
|
+ nowadays and results in a compilation error on some platforms.
|
|
|
|
+
|
|
|
|
+ - We now use the combination of mktemp(3) and mkdir(3) on SunOS, same
|
|
|
|
+ as we do on NonStop.
|
|
|
|
+
|
|
|
|
+ - We now support uClibc without support for <wchar.h>.
|
|
|
|
+
|
|
|
|
+The most important bits here are the improved platform compatibility
|
|
|
|
+with Windows, OpenSUSE, SunOS and uClibc.
|
|
|
|
+
|
|
|
|
+Signed-off-by: Patrick Steinhardt <ps@pks.im>
|
|
|
|
+Upstream: https://lore.kernel.org/r/06145a141dd3485f183bcf8248de0db61a7203db.1729506329.git.ps@pks.im
|
|
|
|
+Signed-off-by: Bagas Sanjaya <bagasdotme@gmail.com>
|
|
|
|
+---
|
|
|
|
+ t/unit-tests/clar/.editorconfig | 13 +++
|
|
|
|
+ t/unit-tests/clar/.github/workflows/ci.yml | 20 +++-
|
|
|
|
+ t/unit-tests/clar/.gitignore | 1 +
|
|
|
|
+ t/unit-tests/clar/CMakeLists.txt | 28 +++++
|
|
|
|
+ t/unit-tests/clar/clar.c | 127 ++++++++++++---------
|
|
|
|
+ t/unit-tests/clar/clar/print.h | 11 +-
|
|
|
|
+ t/unit-tests/clar/clar/sandbox.h | 17 ++-
|
|
|
|
+ t/unit-tests/clar/clar/summary.h | 14 +--
|
|
|
|
+ t/unit-tests/clar/test/.gitignore | 4 -
|
|
|
|
+ t/unit-tests/clar/test/CMakeLists.txt | 39 +++++++
|
|
|
|
+ t/unit-tests/clar/test/Makefile | 39 -------
|
|
|
|
+ 11 files changed, 189 insertions(+), 124 deletions(-)
|
|
|
|
+ create mode 100644 t/unit-tests/clar/.editorconfig
|
|
|
|
+ create mode 100644 t/unit-tests/clar/.gitignore
|
|
|
|
+ create mode 100644 t/unit-tests/clar/CMakeLists.txt
|
|
|
|
+ delete mode 100644 t/unit-tests/clar/test/.gitignore
|
|
|
|
+ create mode 100644 t/unit-tests/clar/test/CMakeLists.txt
|
|
|
|
+ delete mode 100644 t/unit-tests/clar/test/Makefile
|
|
|
|
+
|
|
|
|
+diff --git a/t/unit-tests/clar/.editorconfig b/t/unit-tests/clar/.editorconfig
|
|
|
|
+new file mode 100644
|
|
|
|
+index 0000000000..aa343a4288
|
|
|
|
+--- /dev/null
|
|
|
|
++++ b/t/unit-tests/clar/.editorconfig
|
|
|
|
+@@ -0,0 +1,13 @@
|
|
|
|
++root = true
|
|
|
|
++
|
|
|
|
++[*]
|
|
|
|
++charset = utf-8
|
|
|
|
++insert_final_newline = true
|
|
|
|
++
|
|
|
|
++[*.{c,h}]
|
|
|
|
++indent_style = tab
|
|
|
|
++tab_width = 8
|
|
|
|
++
|
|
|
|
++[CMakeLists.txt]
|
|
|
|
++indent_style = tab
|
|
|
|
++tab_width = 8
|
|
|
|
+diff --git a/t/unit-tests/clar/.github/workflows/ci.yml b/t/unit-tests/clar/.github/workflows/ci.yml
|
|
|
|
+index b1ac2de460..0065843d17 100644
|
|
|
|
+--- a/t/unit-tests/clar/.github/workflows/ci.yml
|
|
|
|
++++ b/t/unit-tests/clar/.github/workflows/ci.yml
|
|
|
|
+@@ -10,14 +10,26 @@ jobs:
|
|
|
|
+ build:
|
|
|
|
+ strategy:
|
|
|
|
+ matrix:
|
|
|
|
+- os: [ ubuntu-latest, macos-latest ]
|
|
|
|
++ platform:
|
|
|
|
++ - os: ubuntu-latest
|
|
|
|
++ generator: Unix Makefiles
|
|
|
|
++ - os: macos-latest
|
|
|
|
++ generator: Unix Makefiles
|
|
|
|
++ - os: windows-latest
|
|
|
|
++ generator: Visual Studio 17 2022
|
|
|
|
++ - os: windows-latest
|
|
|
|
++ generator: MSYS Makefiles
|
|
|
|
++ - os: windows-latest
|
|
|
|
++ generator: MinGW Makefiles
|
|
|
|
+
|
|
|
|
+- runs-on: ${{ matrix.os }}
|
|
|
|
++ runs-on: ${{ matrix.platform.os }}
|
|
|
|
+
|
|
|
|
+ steps:
|
|
|
|
+ - name: Check out
|
|
|
|
+ uses: actions/checkout@v2
|
|
|
|
+ - name: Build
|
|
|
|
+ run: |
|
|
|
|
+- cd test
|
|
|
|
+- make
|
|
|
|
++ mkdir build
|
|
|
|
++ cd build
|
|
|
|
++ cmake .. -G "${{matrix.platform.generator}}"
|
|
|
|
++ cmake --build .
|
|
|
|
+diff --git a/t/unit-tests/clar/.gitignore b/t/unit-tests/clar/.gitignore
|
|
|
|
+new file mode 100644
|
|
|
|
+index 0000000000..84c048a73c
|
|
|
|
+--- /dev/null
|
|
|
|
++++ b/t/unit-tests/clar/.gitignore
|
|
|
|
+@@ -0,0 +1 @@
|
|
|
|
++/build/
|
|
|
|
+diff --git a/t/unit-tests/clar/CMakeLists.txt b/t/unit-tests/clar/CMakeLists.txt
|
|
|
|
+new file mode 100644
|
|
|
|
+index 0000000000..12d4af114f
|
|
|
|
+--- /dev/null
|
|
|
|
++++ b/t/unit-tests/clar/CMakeLists.txt
|
|
|
|
+@@ -0,0 +1,28 @@
|
|
|
|
++cmake_minimum_required(VERSION 3.16..3.29)
|
|
|
|
++
|
|
|
|
++project(clar LANGUAGES C)
|
|
|
|
++
|
|
|
|
++option(BUILD_TESTS "Build test executable" ON)
|
|
|
|
++
|
|
|
|
++add_library(clar INTERFACE)
|
|
|
|
++target_sources(clar INTERFACE
|
|
|
|
++ clar.c
|
|
|
|
++ clar.h
|
|
|
|
++ clar/fixtures.h
|
|
|
|
++ clar/fs.h
|
|
|
|
++ clar/print.h
|
|
|
|
++ clar/sandbox.h
|
|
|
|
++ clar/summary.h
|
|
|
|
++)
|
|
|
|
++set_target_properties(clar PROPERTIES
|
|
|
|
++ C_STANDARD 90
|
|
|
|
++ C_STANDARD_REQUIRED ON
|
|
|
|
++ C_EXTENSIONS OFF
|
|
|
|
++)
|
|
|
|
++
|
|
|
|
++if(CMAKE_PROJECT_NAME STREQUAL PROJECT_NAME)
|
|
|
|
++ include(CTest)
|
|
|
|
++ if(BUILD_TESTING)
|
|
|
|
++ add_subdirectory(test)
|
|
|
|
++ endif()
|
|
|
|
++endif()
|
|
|
|
+diff --git a/t/unit-tests/clar/clar.c b/t/unit-tests/clar/clar.c
|
|
|
|
+index cef0f023c2..d54e455367 100644
|
|
|
|
+--- a/t/unit-tests/clar/clar.c
|
|
|
|
++++ b/t/unit-tests/clar/clar.c
|
|
|
|
+@@ -4,7 +4,12 @@
|
|
|
|
+ * This file is part of clar, distributed under the ISC license.
|
|
|
|
+ * For full terms see the included COPYING file.
|
|
|
|
+ */
|
|
|
|
+-#include <assert.h>
|
|
|
|
++
|
|
|
|
++#define _BSD_SOURCE
|
|
|
|
++#define _DARWIN_C_SOURCE
|
|
|
|
++#define _DEFAULT_SOURCE
|
|
|
|
++
|
|
|
|
++#include <errno.h>
|
|
|
|
+ #include <setjmp.h>
|
|
|
|
+ #include <stdlib.h>
|
|
|
|
+ #include <stdio.h>
|
|
|
|
+@@ -13,11 +18,22 @@
|
|
|
|
+ #include <stdarg.h>
|
|
|
|
+ #include <wchar.h>
|
|
|
|
+ #include <time.h>
|
|
|
|
++#include <inttypes.h>
|
|
|
|
+
|
|
|
|
+ /* required for sandboxing */
|
|
|
|
+ #include <sys/types.h>
|
|
|
|
+ #include <sys/stat.h>
|
|
|
|
+
|
|
|
|
++#if defined(__UCLIBC__) && ! defined(__UCLIBC_HAS_WCHAR__)
|
|
|
|
++ /*
|
|
|
|
++ * uClibc can optionally be built without wchar support, in which case
|
|
|
|
++ * the installed <wchar.h> is a stub that only defines the `whar_t`
|
|
|
|
++ * type but none of the functions typically declared by it.
|
|
|
|
++ */
|
|
|
|
++#else
|
|
|
|
++# define CLAR_HAVE_WCHAR
|
|
|
|
++#endif
|
|
|
|
++
|
|
|
|
+ #ifdef _WIN32
|
|
|
|
+ # define WIN32_LEAN_AND_MEAN
|
|
|
|
+ # include <windows.h>
|
|
|
|
+@@ -28,6 +44,9 @@
|
|
|
|
+
|
|
|
|
+ # ifndef stat
|
|
|
|
+ # define stat(path, st) _stat(path, st)
|
|
|
|
++ typedef struct _stat STAT_T;
|
|
|
|
++# else
|
|
|
|
++ typedef struct stat STAT_T;
|
|
|
|
+ # endif
|
|
|
|
+ # ifndef mkdir
|
|
|
|
+ # define mkdir(path, mode) _mkdir(path)
|
|
|
|
+@@ -60,30 +79,11 @@
|
|
|
|
+ # else
|
|
|
|
+ # define p_snprintf snprintf
|
|
|
|
+ # endif
|
|
|
|
+-
|
|
|
|
+-# ifndef PRIuZ
|
|
|
|
+-# define PRIuZ "Iu"
|
|
|
|
+-# endif
|
|
|
|
+-# ifndef PRIxZ
|
|
|
|
+-# define PRIxZ "Ix"
|
|
|
|
+-# endif
|
|
|
|
+-
|
|
|
|
+-# if defined(_MSC_VER) || (defined(__MINGW32__) && !defined(__MINGW64_VERSION_MAJOR))
|
|
|
|
+- typedef struct stat STAT_T;
|
|
|
|
+-# else
|
|
|
|
+- typedef struct _stat STAT_T;
|
|
|
|
+-# endif
|
|
|
|
+ #else
|
|
|
|
+ # include <sys/wait.h> /* waitpid(2) */
|
|
|
|
+ # include <unistd.h>
|
|
|
|
+ # define _MAIN_CC
|
|
|
|
+ # define p_snprintf snprintf
|
|
|
|
+-# ifndef PRIuZ
|
|
|
|
+-# define PRIuZ "zu"
|
|
|
|
+-# endif
|
|
|
|
+-# ifndef PRIxZ
|
|
|
|
+-# define PRIxZ "zx"
|
|
|
|
+-# endif
|
|
|
|
+ typedef struct stat STAT_T;
|
|
|
|
+ #endif
|
|
|
|
+
|
|
|
|
+@@ -102,7 +102,7 @@ fixture_path(const char *base, const char *fixture_name);
|
|
|
|
+ struct clar_error {
|
|
|
|
+ const char *file;
|
|
|
|
+ const char *function;
|
|
|
|
+- size_t line_number;
|
|
|
|
++ uintmax_t line_number;
|
|
|
|
+ const char *error_msg;
|
|
|
|
+ char *description;
|
|
|
|
+
|
|
|
|
+@@ -195,11 +195,12 @@ static void clar_print_shutdown(int test_count, int suite_count, int error_count
|
|
|
|
+ static void clar_print_error(int num, const struct clar_report *report, const struct clar_error *error);
|
|
|
|
+ static void clar_print_ontest(const char *suite_name, const char *test_name, int test_number, enum cl_test_status failed);
|
|
|
|
+ static void clar_print_onsuite(const char *suite_name, int suite_index);
|
|
|
|
++static void clar_print_onabortv(const char *msg, va_list argp);
|
|
|
|
+ static void clar_print_onabort(const char *msg, ...);
|
|
|
|
+
|
|
|
|
+ /* From clar_sandbox.c */
|
|
|
|
+ static void clar_unsandbox(void);
|
|
|
|
+-static int clar_sandbox(void);
|
|
|
|
++static void clar_sandbox(void);
|
|
|
|
+
|
|
|
|
+ /* From summary.h */
|
|
|
|
+ static struct clar_summary *clar_summary_init(const char *filename);
|
|
|
|
+@@ -218,6 +219,15 @@ static int clar_summary_shutdown(struct clar_summary *fp);
|
|
|
|
+ _clar.trace_payload); \
|
|
|
|
+ } while (0)
|
|
|
|
+
|
|
|
|
++static void clar_abort(const char *msg, ...)
|
|
|
|
++{
|
|
|
|
++ va_list argp;
|
|
|
|
++ va_start(argp, msg);
|
|
|
|
++ clar_print_onabortv(msg, argp);
|
|
|
|
++ va_end(argp);
|
|
|
|
++ exit(-1);
|
|
|
|
++}
|
|
|
|
++
|
|
|
|
+ void cl_trace_register(cl_trace_cb *cb, void *payload)
|
|
|
|
+ {
|
|
|
|
+ _clar.pfn_trace_cb = cb;
|
|
|
|
+@@ -271,9 +281,7 @@ static double clar_time_diff(clar_time *start, clar_time *end)
|
|
|
|
+
|
|
|
|
+ static void clar_time_now(clar_time *out)
|
|
|
|
+ {
|
|
|
|
+- struct timezone tz;
|
|
|
|
+-
|
|
|
|
+- gettimeofday(out, &tz);
|
|
|
|
++ gettimeofday(out, NULL);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ static double clar_time_diff(clar_time *start, clar_time *end)
|
|
|
|
+@@ -386,7 +394,8 @@ clar_run_suite(const struct clar_suite *suite, const char *filter)
|
|
|
|
+
|
|
|
|
+ _clar.active_test = test[i].name;
|
|
|
|
+
|
|
|
|
+- report = calloc(1, sizeof(struct clar_report));
|
|
|
|
++ if ((report = calloc(1, sizeof(*report))) == NULL)
|
|
|
|
++ clar_abort("Failed to allocate report.\n");
|
|
|
|
+ report->suite = _clar.active_suite;
|
|
|
|
+ report->test = _clar.active_test;
|
|
|
|
+ report->test_number = _clar.tests_ran;
|
|
|
|
+@@ -479,9 +488,10 @@ clar_parse_args(int argc, char **argv)
|
|
|
|
+
|
|
|
|
+ switch (action) {
|
|
|
|
+ case 's': {
|
|
|
|
+- struct clar_explicit *explicit =
|
|
|
|
+- calloc(1, sizeof(struct clar_explicit));
|
|
|
|
+- assert(explicit);
|
|
|
|
++ struct clar_explicit *explicit;
|
|
|
|
++
|
|
|
|
++ if ((explicit = calloc(1, sizeof(*explicit))) == NULL)
|
|
|
|
++ clar_abort("Failed to allocate explicit test.\n");
|
|
|
|
+
|
|
|
|
+ explicit->suite_idx = j;
|
|
|
|
+ explicit->filter = argument;
|
|
|
|
+@@ -505,10 +515,8 @@ clar_parse_args(int argc, char **argv)
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+- if (!found) {
|
|
|
|
+- clar_print_onabort("No suite matching '%s' found.\n", argument);
|
|
|
|
+- exit(-1);
|
|
|
|
+- }
|
|
|
|
++ if (!found)
|
|
|
|
++ clar_abort("No suite matching '%s' found.\n", argument);
|
|
|
|
+ break;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+@@ -540,11 +548,17 @@ clar_parse_args(int argc, char **argv)
|
|
|
|
+ case 'r':
|
|
|
|
+ _clar.write_summary = 1;
|
|
|
|
+ free(_clar.summary_filename);
|
|
|
|
+- _clar.summary_filename = *(argument + 2) ? strdup(argument + 2) : NULL;
|
|
|
|
++ if (*(argument + 2)) {
|
|
|
|
++ if ((_clar.summary_filename = strdup(argument + 2)) == NULL)
|
|
|
|
++ clar_abort("Failed to allocate summary filename.\n");
|
|
|
|
++ } else {
|
|
|
|
++ _clar.summary_filename = NULL;
|
|
|
|
++ }
|
|
|
|
+ break;
|
|
|
|
+
|
|
|
|
+ default:
|
|
|
|
+- assert(!"Unexpected commandline argument!");
|
|
|
|
++ clar_abort("Unexpected commandline argument '%s'.\n",
|
|
|
|
++ argument[1]);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+@@ -566,22 +580,18 @@ clar_test_init(int argc, char **argv)
|
|
|
|
+ if (!_clar.summary_filename &&
|
|
|
|
+ (summary_env = getenv("CLAR_SUMMARY")) != NULL) {
|
|
|
|
+ _clar.write_summary = 1;
|
|
|
|
+- _clar.summary_filename = strdup(summary_env);
|
|
|
|
++ if ((_clar.summary_filename = strdup(summary_env)) == NULL)
|
|
|
|
++ clar_abort("Failed to allocate summary filename.\n");
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (_clar.write_summary && !_clar.summary_filename)
|
|
|
|
+- _clar.summary_filename = strdup("summary.xml");
|
|
|
|
++ if ((_clar.summary_filename = strdup("summary.xml")) == NULL)
|
|
|
|
++ clar_abort("Failed to allocate summary filename.\n");
|
|
|
|
+
|
|
|
|
+- if (_clar.write_summary &&
|
|
|
|
+- !(_clar.summary = clar_summary_init(_clar.summary_filename))) {
|
|
|
|
+- clar_print_onabort("Failed to open the summary file\n");
|
|
|
|
+- exit(-1);
|
|
|
|
+- }
|
|
|
|
++ if (_clar.write_summary)
|
|
|
|
++ _clar.summary = clar_summary_init(_clar.summary_filename);
|
|
|
|
+
|
|
|
|
+- if (clar_sandbox() < 0) {
|
|
|
|
+- clar_print_onabort("Failed to sandbox the test runner.\n");
|
|
|
|
+- exit(-1);
|
|
|
|
+- }
|
|
|
|
++ clar_sandbox();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ int
|
|
|
|
+@@ -615,10 +625,9 @@ clar_test_shutdown(void)
|
|
|
|
+
|
|
|
|
+ clar_unsandbox();
|
|
|
|
+
|
|
|
|
+- if (_clar.write_summary && clar_summary_shutdown(_clar.summary) < 0) {
|
|
|
|
+- clar_print_onabort("Failed to write the summary file\n");
|
|
|
|
+- exit(-1);
|
|
|
|
+- }
|
|
|
|
++ if (_clar.write_summary && clar_summary_shutdown(_clar.summary) < 0)
|
|
|
|
++ clar_abort("Failed to write the summary file '%s: %s.\n",
|
|
|
|
++ _clar.summary_filename, strerror(errno));
|
|
|
|
+
|
|
|
|
+ for (explicit = _clar.explicit; explicit; explicit = explicit_next) {
|
|
|
|
+ explicit_next = explicit->next;
|
|
|
|
+@@ -649,7 +658,7 @@ static void abort_test(void)
|
|
|
|
+ {
|
|
|
|
+ if (!_clar.trampoline_enabled) {
|
|
|
|
+ clar_print_onabort(
|
|
|
|
+- "Fatal error: a cleanup method raised an exception.");
|
|
|
|
++ "Fatal error: a cleanup method raised an exception.\n");
|
|
|
|
+ clar_report_errors(_clar.last_report);
|
|
|
|
+ exit(-1);
|
|
|
|
+ }
|
|
|
|
+@@ -673,7 +682,10 @@ void clar__fail(
|
|
|
|
+ const char *description,
|
|
|
|
+ int should_abort)
|
|
|
|
+ {
|
|
|
|
+- struct clar_error *error = calloc(1, sizeof(struct clar_error));
|
|
|
|
++ struct clar_error *error;
|
|
|
|
++
|
|
|
|
++ if ((error = calloc(1, sizeof(*error))) == NULL)
|
|
|
|
++ clar_abort("Failed to allocate error.\n");
|
|
|
|
+
|
|
|
|
+ if (_clar.last_report->errors == NULL)
|
|
|
|
+ _clar.last_report->errors = error;
|
|
|
|
+@@ -688,8 +700,9 @@ void clar__fail(
|
|
|
|
+ error->line_number = line;
|
|
|
|
+ error->error_msg = error_msg;
|
|
|
|
+
|
|
|
|
+- if (description != NULL)
|
|
|
|
+- error->description = strdup(description);
|
|
|
|
++ if (description != NULL &&
|
|
|
|
++ (error->description = strdup(description)) == NULL)
|
|
|
|
++ clar_abort("Failed to allocate description.\n");
|
|
|
|
+
|
|
|
|
+ _clar.total_errors++;
|
|
|
|
+ _clar.last_report->status = CL_TEST_FAILURE;
|
|
|
|
+@@ -763,6 +776,7 @@ void clar__assert_equal(
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
++#ifdef CLAR_HAVE_WCHAR
|
|
|
|
+ else if (!strcmp("%ls", fmt)) {
|
|
|
|
+ const wchar_t *wcs1 = va_arg(args, const wchar_t *);
|
|
|
|
+ const wchar_t *wcs2 = va_arg(args, const wchar_t *);
|
|
|
|
+@@ -798,8 +812,9 @@ void clar__assert_equal(
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+- else if (!strcmp("%"PRIuZ, fmt) || !strcmp("%"PRIxZ, fmt)) {
|
|
|
|
+- size_t sz1 = va_arg(args, size_t), sz2 = va_arg(args, size_t);
|
|
|
|
++#endif /* CLAR_HAVE_WCHAR */
|
|
|
|
++ else if (!strcmp("%"PRIuMAX, fmt) || !strcmp("%"PRIxMAX, fmt)) {
|
|
|
|
++ uintmax_t sz1 = va_arg(args, uintmax_t), sz2 = va_arg(args, uintmax_t);
|
|
|
|
+ is_equal = (sz1 == sz2);
|
|
|
|
+ if (!is_equal) {
|
|
|
|
+ int offset = p_snprintf(buf, sizeof(buf), fmt, sz1);
|
|
|
|
+diff --git a/t/unit-tests/clar/clar/print.h b/t/unit-tests/clar/clar/print.h
|
|
|
|
+index c17e2f693b..69d0ee967e 100644
|
|
|
|
+--- a/t/unit-tests/clar/clar/print.h
|
|
|
|
++++ b/t/unit-tests/clar/clar/print.h
|
|
|
|
+@@ -21,7 +21,7 @@ static void clar_print_clap_error(int num, const struct clar_report *report, con
|
|
|
|
+ {
|
|
|
|
+ printf(" %d) Failure:\n", num);
|
|
|
|
+
|
|
|
|
+- printf("%s::%s [%s:%"PRIuZ"]\n",
|
|
|
|
++ printf("%s::%s [%s:%"PRIuMAX"]\n",
|
|
|
|
+ report->suite,
|
|
|
|
+ report->test,
|
|
|
|
+ error->file,
|
|
|
|
+@@ -136,7 +136,7 @@ static void clar_print_tap_ontest(const char *suite_name, const char *test_name,
|
|
|
|
+
|
|
|
|
+ printf(" at:\n");
|
|
|
|
+ printf(" file: '"); print_escaped(error->file); printf("'\n");
|
|
|
|
+- printf(" line: %" PRIuZ "\n", error->line_number);
|
|
|
|
++ printf(" line: %" PRIuMAX "\n", error->line_number);
|
|
|
|
+ printf(" function: '%s'\n", error->function);
|
|
|
|
+ printf(" ---\n");
|
|
|
|
+
|
|
|
|
+@@ -202,10 +202,15 @@ static void clar_print_onsuite(const char *suite_name, int suite_index)
|
|
|
|
+ PRINT(onsuite, suite_name, suite_index);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
++static void clar_print_onabortv(const char *msg, va_list argp)
|
|
|
|
++{
|
|
|
|
++ PRINT(onabort, msg, argp);
|
|
|
|
++}
|
|
|
|
++
|
|
|
|
+ static void clar_print_onabort(const char *msg, ...)
|
|
|
|
+ {
|
|
|
|
+ va_list argp;
|
|
|
|
+ va_start(argp, msg);
|
|
|
|
+- PRINT(onabort, msg, argp);
|
|
|
|
++ clar_print_onabortv(msg, argp);
|
|
|
|
+ va_end(argp);
|
|
|
|
+ }
|
|
|
|
+diff --git a/t/unit-tests/clar/clar/sandbox.h b/t/unit-tests/clar/clar/sandbox.h
|
|
|
|
+index e25057b7c4..bc960f50e0 100644
|
|
|
|
+--- a/t/unit-tests/clar/clar/sandbox.h
|
|
|
|
++++ b/t/unit-tests/clar/clar/sandbox.h
|
|
|
|
+@@ -122,14 +122,14 @@ static int build_sandbox_path(void)
|
|
|
|
+
|
|
|
|
+ if (mkdir(_clar_path, 0700) != 0)
|
|
|
|
+ return -1;
|
|
|
|
+-#elif defined(__TANDEM)
|
|
|
|
+- if (mktemp(_clar_path) == NULL)
|
|
|
|
++#elif defined(_WIN32)
|
|
|
|
++ if (_mktemp_s(_clar_path, sizeof(_clar_path)) != 0)
|
|
|
|
+ return -1;
|
|
|
|
+
|
|
|
|
+ if (mkdir(_clar_path, 0700) != 0)
|
|
|
|
+ return -1;
|
|
|
|
+-#elif defined(_WIN32)
|
|
|
|
+- if (_mktemp_s(_clar_path, sizeof(_clar_path)) != 0)
|
|
|
|
++#elif defined(__sun) || defined(__TANDEM)
|
|
|
|
++ if (mktemp(_clar_path) == NULL)
|
|
|
|
+ return -1;
|
|
|
|
+
|
|
|
|
+ if (mkdir(_clar_path, 0700) != 0)
|
|
|
|
+@@ -142,15 +142,14 @@ static int build_sandbox_path(void)
|
|
|
|
+ return 0;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+-static int clar_sandbox(void)
|
|
|
|
++static void clar_sandbox(void)
|
|
|
|
+ {
|
|
|
|
+ if (_clar_path[0] == '\0' && build_sandbox_path() < 0)
|
|
|
|
+- return -1;
|
|
|
|
++ clar_abort("Failed to build sandbox path.\n");
|
|
|
|
+
|
|
|
|
+ if (chdir(_clar_path) != 0)
|
|
|
|
+- return -1;
|
|
|
|
+-
|
|
|
|
+- return 0;
|
|
|
|
++ clar_abort("Failed to change into sandbox directory '%s': %s.\n",
|
|
|
|
++ _clar_path, strerror(errno));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ const char *clar_sandbox_path(void)
|
|
|
|
+diff --git a/t/unit-tests/clar/clar/summary.h b/t/unit-tests/clar/clar/summary.h
|
|
|
|
+index 4dd352e28b..0d0b646fe7 100644
|
|
|
|
+--- a/t/unit-tests/clar/clar/summary.h
|
|
|
|
++++ b/t/unit-tests/clar/clar/summary.h
|
|
|
|
+@@ -66,16 +66,12 @@ struct clar_summary *clar_summary_init(const char *filename)
|
|
|
|
+ struct clar_summary *summary;
|
|
|
|
+ FILE *fp;
|
|
|
|
+
|
|
|
|
+- if ((fp = fopen(filename, "w")) == NULL) {
|
|
|
|
+- perror("fopen");
|
|
|
|
+- return NULL;
|
|
|
|
+- }
|
|
|
|
++ if ((fp = fopen(filename, "w")) == NULL)
|
|
|
|
++ clar_abort("Failed to open the summary file '%s': %s.\n",
|
|
|
|
++ filename, strerror(errno));
|
|
|
|
+
|
|
|
|
+- if ((summary = malloc(sizeof(struct clar_summary))) == NULL) {
|
|
|
|
+- perror("malloc");
|
|
|
|
+- fclose(fp);
|
|
|
|
+- return NULL;
|
|
|
|
+- }
|
|
|
|
++ if ((summary = malloc(sizeof(struct clar_summary))) == NULL)
|
|
|
|
++ clar_abort("Failed to allocate summary.\n");
|
|
|
|
+
|
|
|
|
+ summary->filename = filename;
|
|
|
|
+ summary->fp = fp;
|
|
|
|
+diff --git a/t/unit-tests/clar/test/.gitignore b/t/unit-tests/clar/test/.gitignore
|
|
|
|
+deleted file mode 100644
|
|
|
|
+index a477d0c40c..0000000000
|
|
|
|
+--- a/t/unit-tests/clar/test/.gitignore
|
|
|
|
++++ /dev/null
|
|
|
|
+@@ -1,4 +0,0 @@
|
|
|
|
+-clar.suite
|
|
|
|
+-.clarcache
|
|
|
|
+-clar_test
|
|
|
|
+-*.o
|
|
|
|
+diff --git a/t/unit-tests/clar/test/CMakeLists.txt b/t/unit-tests/clar/test/CMakeLists.txt
|
|
|
|
+new file mode 100644
|
|
|
|
+index 0000000000..7f2c1dc17a
|
|
|
|
+--- /dev/null
|
|
|
|
++++ b/t/unit-tests/clar/test/CMakeLists.txt
|
|
|
|
+@@ -0,0 +1,39 @@
|
|
|
|
++find_package(Python COMPONENTS Interpreter REQUIRED)
|
|
|
|
++
|
|
|
|
++add_custom_command(OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/clar.suite"
|
|
|
|
++ COMMAND "${Python_EXECUTABLE}" "${CMAKE_SOURCE_DIR}/generate.py" --output "${CMAKE_CURRENT_BINARY_DIR}"
|
|
|
|
++ DEPENDS main.c sample.c clar_test.h
|
|
|
|
++ WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
|
|
|
|
++)
|
|
|
|
++
|
|
|
|
++add_executable(clar_test)
|
|
|
|
++set_target_properties(clar_test PROPERTIES
|
|
|
|
++ C_STANDARD 90
|
|
|
|
++ C_STANDARD_REQUIRED ON
|
|
|
|
++ C_EXTENSIONS OFF
|
|
|
|
++)
|
|
|
|
++
|
|
|
|
++# MSVC generates all kinds of warnings. We may want to fix these in the future
|
|
|
|
++# and then unconditionally treat warnings as errors.
|
|
|
|
++if(NOT MSVC)
|
|
|
|
++ set_target_properties(clar_test PROPERTIES
|
|
|
|
++ COMPILE_WARNING_AS_ERROR ON
|
|
|
|
++ )
|
|
|
|
++endif()
|
|
|
|
++
|
|
|
|
++target_sources(clar_test PRIVATE
|
|
|
|
++ main.c
|
|
|
|
++ sample.c
|
|
|
|
++ "${CMAKE_CURRENT_BINARY_DIR}/clar.suite"
|
|
|
|
++)
|
|
|
|
++target_compile_definitions(clar_test PRIVATE
|
|
|
|
++ CLAR_FIXTURE_PATH="${CMAKE_CURRENT_SOURCE_DIR}/resources/"
|
|
|
|
++)
|
|
|
|
++target_compile_options(clar_test PRIVATE
|
|
|
|
++ $<IF:$<CXX_COMPILER_ID:MSVC>,/W4,-Wall>
|
|
|
|
++)
|
|
|
|
++target_include_directories(clar_test PRIVATE
|
|
|
|
++ "${CMAKE_SOURCE_DIR}"
|
|
|
|
++ "${CMAKE_CURRENT_BINARY_DIR}"
|
|
|
|
++)
|
|
|
|
++target_link_libraries(clar_test clar)
|
|
|
|
+diff --git a/t/unit-tests/clar/test/Makefile b/t/unit-tests/clar/test/Makefile
|
|
|
|
+deleted file mode 100644
|
|
|
|
+index 93c6b2ad32..0000000000
|
|
|
|
+--- a/t/unit-tests/clar/test/Makefile
|
|
|
|
++++ /dev/null
|
|
|
|
+@@ -1,39 +0,0 @@
|
|
|
|
+-#
|
|
|
|
+-# Copyright (c) Vicent Marti. All rights reserved.
|
|
|
|
+-#
|
|
|
|
+-# This file is part of clar, distributed under the ISC license.
|
|
|
|
+-# For full terms see the included COPYING file.
|
|
|
|
+-#
|
|
|
|
+-
|
|
|
|
+-#
|
|
|
|
+-# Set up the path to the clar sources and to the fixtures directory
|
|
|
|
+-#
|
|
|
|
+-# The fixture path needs to be an absolute path so it can be used
|
|
|
|
+-# even after we have chdir'ed into the test directory while testing.
|
|
|
|
+-#
|
|
|
|
+-CURRENT_MAKEFILE := $(word $(words $(MAKEFILE_LIST)),$(MAKEFILE_LIST))
|
|
|
|
+-TEST_DIRECTORY := $(abspath $(dir $(CURRENT_MAKEFILE)))
|
|
|
|
+-CLAR_PATH := $(dir $(TEST_DIRECTORY))
|
|
|
|
+-CLAR_FIXTURE_PATH := $(TEST_DIRECTORY)/resources/
|
|
|
|
+-
|
|
|
|
+-CFLAGS=-g -I.. -I. -Wall -DCLAR_FIXTURE_PATH=\"$(CLAR_FIXTURE_PATH)\"
|
|
|
|
+-
|
|
|
|
+-.PHONY: clean
|
|
|
|
+-
|
|
|
|
+-# list the objects that go into our test
|
|
|
|
+-objects = main.o sample.o
|
|
|
|
+-
|
|
|
|
+-# build the test executable itself
|
|
|
|
+-clar_test: $(objects) clar_test.h clar.suite $(CLAR_PATH)clar.c
|
|
|
|
+- $(CC) $(CFLAGS) -o $@ "$(CLAR_PATH)clar.c" $(objects)
|
|
|
|
+-
|
|
|
|
+-# test object files depend on clar macros
|
|
|
|
+-$(objects) : $(CLAR_PATH)clar.h
|
|
|
|
+-
|
|
|
|
+-# build the clar.suite file of test metadata
|
|
|
|
+-clar.suite:
|
|
|
|
+- python "$(CLAR_PATH)generate.py" .
|
|
|
|
+-
|
|
|
|
+-# remove all generated files
|
|
|
|
+-clean:
|
|
|
|
+- $(RM) -rf *.o clar.suite .clarcache clar_test clar_test.dSYM
|
|
|
|
+
|
|
|
|
+base-commit: 777489f9e09c8d0dd6b12f9d90de6376330577a2
|
|
|
|
+--
|
|
|
|
+An old man doll... just what I always wanted! - Clara
|
|
|
|
+
|