Merge branch 'ps/upgrade-clar'
Buildfix and upgrade of Clar to a newer version. * ps/upgrade-clar: cmake: set up proper dependencies for generated clar headers cmake: fix compilation of clar-based unit tests Makefile: extract script to generate clar declarations Makefile: adjust sed command for generating "clar-decls.h" t/unit-tests: update clar to 206accb
This commit is contained in:
4
Makefile
4
Makefile
@ -3905,9 +3905,7 @@ GIT-TEST-SUITES: FORCE
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
$(UNIT_TEST_DIR)/clar-decls.h: $(patsubst %,$(UNIT_TEST_DIR)/%.c,$(CLAR_TEST_SUITES)) GIT-TEST-SUITES
|
$(UNIT_TEST_DIR)/clar-decls.h: $(patsubst %,$(UNIT_TEST_DIR)/%.c,$(CLAR_TEST_SUITES)) GIT-TEST-SUITES
|
||||||
$(QUIET_GEN)for suite in $(CLAR_TEST_SUITES); do \
|
$(QUIET_GEN)$(SHELL_PATH) $(UNIT_TEST_DIR)/generate-clar-decls.sh "$@" $(filter %.c,$^)
|
||||||
sed -ne "s/^\(void test_$${suite}__[a-zA-Z_0-9][a-zA-Z_0-9]*(void)$$\)/extern \1;/p" $(UNIT_TEST_DIR)/$$suite.c; \
|
|
||||||
done >$@
|
|
||||||
$(UNIT_TEST_DIR)/clar.suite: $(UNIT_TEST_DIR)/clar-decls.h
|
$(UNIT_TEST_DIR)/clar.suite: $(UNIT_TEST_DIR)/clar-decls.h
|
||||||
$(QUIET_GEN)awk -f $(UNIT_TEST_DIR)/clar-generate.awk $< >$(UNIT_TEST_DIR)/clar.suite
|
$(QUIET_GEN)awk -f $(UNIT_TEST_DIR)/clar-generate.awk $< >$(UNIT_TEST_DIR)/clar.suite
|
||||||
$(UNIT_TEST_DIR)/clar/clar.o: $(UNIT_TEST_DIR)/clar.suite
|
$(UNIT_TEST_DIR)/clar/clar.o: $(UNIT_TEST_DIR)/clar.suite
|
||||||
|
@ -1002,47 +1002,21 @@ foreach(unit_test ${unit_test_PROGRAMS})
|
|||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
parse_makefile_for_scripts(clar_test_SUITES "CLAR_TEST_SUITES" "")
|
parse_makefile_for_scripts(clar_test_SUITES "CLAR_TEST_SUITES" "")
|
||||||
|
|
||||||
set(clar_decls "")
|
|
||||||
set(clar_cbs "")
|
|
||||||
set(clar_cbs_count 0)
|
|
||||||
set(clar_suites "static struct clar_suite _clar_suites[] = {\n")
|
|
||||||
list(LENGTH clar_test_SUITES clar_suites_count)
|
|
||||||
foreach(suite ${clar_test_SUITES})
|
|
||||||
file(STRINGS "${CMAKE_SOURCE_DIR}/t/unit-tests/${suite}.c" decls
|
|
||||||
REGEX "^void test_${suite}__[a-zA-Z_0-9][a-zA-Z_0-9]*\\(void\\)$")
|
|
||||||
|
|
||||||
list(LENGTH decls decls_count)
|
|
||||||
string(REGEX REPLACE "void (test_${suite}__([a-zA-Z_0-9]*))\\(void\\)" " { \"\\2\", &\\1 },\n" cbs ${decls})
|
|
||||||
string(JOIN "" cbs ${cbs})
|
|
||||||
list(TRANSFORM decls PREPEND "extern ")
|
|
||||||
string(JOIN ";\n" decls ${decls})
|
|
||||||
|
|
||||||
string(APPEND clar_decls "${decls};\n")
|
|
||||||
string(APPEND clar_cbs
|
|
||||||
"static const struct clar_func _clar_cb_${suite}[] = {\n"
|
|
||||||
${cbs}
|
|
||||||
"};\n")
|
|
||||||
string(APPEND clar_suites
|
|
||||||
" {\n"
|
|
||||||
" \"${suite}\",\n"
|
|
||||||
" { NULL, NULL },\n"
|
|
||||||
" { NULL, NULL },\n"
|
|
||||||
" _clar_cb_${suite}, ${decls_count}, 1\n"
|
|
||||||
" },\n")
|
|
||||||
math(EXPR clar_cbs_count "${clar_cbs_count}+${decls_count}")
|
|
||||||
endforeach()
|
|
||||||
string(APPEND clar_suites
|
|
||||||
"};\n"
|
|
||||||
"static const size_t _clar_suite_count = ${clar_suites_count};\n"
|
|
||||||
"static const size_t _clar_callback_count = ${clar_cbs_count};\n")
|
|
||||||
file(WRITE "${CMAKE_BINARY_DIR}/t/unit-tests/clar-decls.h" "${clar_decls}")
|
|
||||||
file(WRITE "${CMAKE_BINARY_DIR}/t/unit-tests/clar.suite" "${clar_decls}" "${clar_cbs}" "${clar_suites}")
|
|
||||||
|
|
||||||
list(TRANSFORM clar_test_SUITES PREPEND "${CMAKE_SOURCE_DIR}/t/unit-tests/")
|
list(TRANSFORM clar_test_SUITES PREPEND "${CMAKE_SOURCE_DIR}/t/unit-tests/")
|
||||||
list(TRANSFORM clar_test_SUITES APPEND ".c")
|
list(TRANSFORM clar_test_SUITES APPEND ".c")
|
||||||
add_library(unit-tests-lib ${clar_test_SUITES} "${CMAKE_SOURCE_DIR}/t/unit-tests/clar/clar.c")
|
add_custom_command(OUTPUT "${CMAKE_BINARY_DIR}/t/unit-tests/clar-decls.h"
|
||||||
target_include_directories(unit-tests-lib PRIVATE "${CMAKE_SOURCE_DIR}/t/unit-tests")
|
COMMAND ${CMAKE_SOURCE_DIR}/t/unit-tests/generate-clar-decls.sh "${CMAKE_BINARY_DIR}/t/unit-tests/clar-decls.h" ${clar_test_SUITES}
|
||||||
|
DEPENDS ${CMAKE_SOURCE_DIR}/t/unit-tests/generate-clar-decls.sh ${clar_test_SUITES})
|
||||||
|
add_custom_command(OUTPUT "${CMAKE_BINARY_DIR}/t/unit-tests/clar.suite"
|
||||||
|
COMMAND awk -f "${CMAKE_SOURCE_DIR}/t/unit-tests/clar-generate.awk" "${CMAKE_BINARY_DIR}/t/unit-tests/clar-decls.h" > "${CMAKE_BINARY_DIR}/t/unit-tests/clar.suite"
|
||||||
|
DEPENDS "${CMAKE_SOURCE_DIR}/t/unit-tests/clar-generate.awk" "${CMAKE_BINARY_DIR}/t/unit-tests/clar-decls.h")
|
||||||
|
|
||||||
|
add_library(unit-tests-lib ${clar_test_SUITES}
|
||||||
|
"${CMAKE_SOURCE_DIR}/t/unit-tests/clar/clar.c"
|
||||||
|
"${CMAKE_BINARY_DIR}/t/unit-tests/clar-decls.h"
|
||||||
|
"${CMAKE_BINARY_DIR}/t/unit-tests/clar.suite"
|
||||||
|
)
|
||||||
|
target_include_directories(unit-tests-lib PUBLIC "${CMAKE_BINARY_DIR}/t/unit-tests")
|
||||||
add_executable(unit-tests "${CMAKE_SOURCE_DIR}/t/unit-tests/unit-test.c")
|
add_executable(unit-tests "${CMAKE_SOURCE_DIR}/t/unit-tests/unit-test.c")
|
||||||
target_link_libraries(unit-tests unit-tests-lib common-main)
|
target_link_libraries(unit-tests unit-tests-lib common-main)
|
||||||
set_target_properties(unit-tests
|
set_target_properties(unit-tests
|
||||||
|
13
t/unit-tests/clar/.editorconfig
Normal file
13
t/unit-tests/clar/.editorconfig
Normal file
@ -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
|
20
t/unit-tests/clar/.github/workflows/ci.yml
vendored
20
t/unit-tests/clar/.github/workflows/ci.yml
vendored
@ -10,14 +10,26 @@ jobs:
|
|||||||
build:
|
build:
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
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:
|
steps:
|
||||||
- name: Check out
|
- name: Check out
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
- name: Build
|
- name: Build
|
||||||
run: |
|
run: |
|
||||||
cd test
|
mkdir build
|
||||||
make
|
cd build
|
||||||
|
cmake .. -G "${{matrix.platform.generator}}"
|
||||||
|
cmake --build .
|
||||||
|
1
t/unit-tests/clar/.gitignore
vendored
Normal file
1
t/unit-tests/clar/.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
/build/
|
28
t/unit-tests/clar/CMakeLists.txt
Normal file
28
t/unit-tests/clar/CMakeLists.txt
Normal file
@ -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()
|
@ -4,7 +4,12 @@
|
|||||||
* This file is part of clar, distributed under the ISC license.
|
* This file is part of clar, distributed under the ISC license.
|
||||||
* For full terms see the included COPYING file.
|
* 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 <setjmp.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@ -13,11 +18,22 @@
|
|||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <wchar.h>
|
#include <wchar.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
#include <inttypes.h>
|
||||||
|
|
||||||
/* required for sandboxing */
|
/* required for sandboxing */
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.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
|
#ifdef _WIN32
|
||||||
# define WIN32_LEAN_AND_MEAN
|
# define WIN32_LEAN_AND_MEAN
|
||||||
# include <windows.h>
|
# include <windows.h>
|
||||||
@ -28,6 +44,9 @@
|
|||||||
|
|
||||||
# ifndef stat
|
# ifndef stat
|
||||||
# define stat(path, st) _stat(path, st)
|
# define stat(path, st) _stat(path, st)
|
||||||
|
typedef struct _stat STAT_T;
|
||||||
|
# else
|
||||||
|
typedef struct stat STAT_T;
|
||||||
# endif
|
# endif
|
||||||
# ifndef mkdir
|
# ifndef mkdir
|
||||||
# define mkdir(path, mode) _mkdir(path)
|
# define mkdir(path, mode) _mkdir(path)
|
||||||
@ -60,30 +79,11 @@
|
|||||||
# else
|
# else
|
||||||
# define p_snprintf snprintf
|
# define p_snprintf snprintf
|
||||||
# endif
|
# 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
|
#else
|
||||||
# include <sys/wait.h> /* waitpid(2) */
|
# include <sys/wait.h> /* waitpid(2) */
|
||||||
# include <unistd.h>
|
# include <unistd.h>
|
||||||
# define _MAIN_CC
|
# define _MAIN_CC
|
||||||
# define p_snprintf snprintf
|
# define p_snprintf snprintf
|
||||||
# ifndef PRIuZ
|
|
||||||
# define PRIuZ "zu"
|
|
||||||
# endif
|
|
||||||
# ifndef PRIxZ
|
|
||||||
# define PRIxZ "zx"
|
|
||||||
# endif
|
|
||||||
typedef struct stat STAT_T;
|
typedef struct stat STAT_T;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -102,7 +102,7 @@ fixture_path(const char *base, const char *fixture_name);
|
|||||||
struct clar_error {
|
struct clar_error {
|
||||||
const char *file;
|
const char *file;
|
||||||
const char *function;
|
const char *function;
|
||||||
size_t line_number;
|
uintmax_t line_number;
|
||||||
const char *error_msg;
|
const char *error_msg;
|
||||||
char *description;
|
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_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_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_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, ...);
|
static void clar_print_onabort(const char *msg, ...);
|
||||||
|
|
||||||
/* From clar_sandbox.c */
|
/* From clar_sandbox.c */
|
||||||
static void clar_unsandbox(void);
|
static void clar_unsandbox(void);
|
||||||
static int clar_sandbox(void);
|
static void clar_sandbox(void);
|
||||||
|
|
||||||
/* From summary.h */
|
/* From summary.h */
|
||||||
static struct clar_summary *clar_summary_init(const char *filename);
|
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); \
|
_clar.trace_payload); \
|
||||||
} while (0)
|
} 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)
|
void cl_trace_register(cl_trace_cb *cb, void *payload)
|
||||||
{
|
{
|
||||||
_clar.pfn_trace_cb = cb;
|
_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)
|
static void clar_time_now(clar_time *out)
|
||||||
{
|
{
|
||||||
struct timezone tz;
|
gettimeofday(out, NULL);
|
||||||
|
|
||||||
gettimeofday(out, &tz);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static double clar_time_diff(clar_time *start, clar_time *end)
|
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;
|
_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->suite = _clar.active_suite;
|
||||||
report->test = _clar.active_test;
|
report->test = _clar.active_test;
|
||||||
report->test_number = _clar.tests_ran;
|
report->test_number = _clar.tests_ran;
|
||||||
@ -479,9 +488,10 @@ clar_parse_args(int argc, char **argv)
|
|||||||
|
|
||||||
switch (action) {
|
switch (action) {
|
||||||
case 's': {
|
case 's': {
|
||||||
struct clar_explicit *explicit =
|
struct clar_explicit *explicit;
|
||||||
calloc(1, sizeof(struct clar_explicit));
|
|
||||||
assert(explicit);
|
if ((explicit = calloc(1, sizeof(*explicit))) == NULL)
|
||||||
|
clar_abort("Failed to allocate explicit test.\n");
|
||||||
|
|
||||||
explicit->suite_idx = j;
|
explicit->suite_idx = j;
|
||||||
explicit->filter = argument;
|
explicit->filter = argument;
|
||||||
@ -505,10 +515,8 @@ clar_parse_args(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!found) {
|
if (!found)
|
||||||
clar_print_onabort("No suite matching '%s' found.\n", argument);
|
clar_abort("No suite matching '%s' found.\n", argument);
|
||||||
exit(-1);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -540,11 +548,17 @@ clar_parse_args(int argc, char **argv)
|
|||||||
case 'r':
|
case 'r':
|
||||||
_clar.write_summary = 1;
|
_clar.write_summary = 1;
|
||||||
free(_clar.summary_filename);
|
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;
|
break;
|
||||||
|
|
||||||
default:
|
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 &&
|
if (!_clar.summary_filename &&
|
||||||
(summary_env = getenv("CLAR_SUMMARY")) != NULL) {
|
(summary_env = getenv("CLAR_SUMMARY")) != NULL) {
|
||||||
_clar.write_summary = 1;
|
_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)
|
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 &&
|
if (_clar.write_summary)
|
||||||
!(_clar.summary = clar_summary_init(_clar.summary_filename))) {
|
_clar.summary = clar_summary_init(_clar.summary_filename);
|
||||||
clar_print_onabort("Failed to open the summary file\n");
|
|
||||||
exit(-1);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (clar_sandbox() < 0) {
|
clar_sandbox();
|
||||||
clar_print_onabort("Failed to sandbox the test runner.\n");
|
|
||||||
exit(-1);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
@ -615,10 +625,9 @@ clar_test_shutdown(void)
|
|||||||
|
|
||||||
clar_unsandbox();
|
clar_unsandbox();
|
||||||
|
|
||||||
if (_clar.write_summary && clar_summary_shutdown(_clar.summary) < 0) {
|
if (_clar.write_summary && clar_summary_shutdown(_clar.summary) < 0)
|
||||||
clar_print_onabort("Failed to write the summary file\n");
|
clar_abort("Failed to write the summary file '%s: %s.\n",
|
||||||
exit(-1);
|
_clar.summary_filename, strerror(errno));
|
||||||
}
|
|
||||||
|
|
||||||
for (explicit = _clar.explicit; explicit; explicit = explicit_next) {
|
for (explicit = _clar.explicit; explicit; explicit = explicit_next) {
|
||||||
explicit_next = explicit->next;
|
explicit_next = explicit->next;
|
||||||
@ -649,7 +658,7 @@ static void abort_test(void)
|
|||||||
{
|
{
|
||||||
if (!_clar.trampoline_enabled) {
|
if (!_clar.trampoline_enabled) {
|
||||||
clar_print_onabort(
|
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);
|
clar_report_errors(_clar.last_report);
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
@ -673,7 +682,10 @@ void clar__fail(
|
|||||||
const char *description,
|
const char *description,
|
||||||
int should_abort)
|
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)
|
if (_clar.last_report->errors == NULL)
|
||||||
_clar.last_report->errors = error;
|
_clar.last_report->errors = error;
|
||||||
@ -688,8 +700,9 @@ void clar__fail(
|
|||||||
error->line_number = line;
|
error->line_number = line;
|
||||||
error->error_msg = error_msg;
|
error->error_msg = error_msg;
|
||||||
|
|
||||||
if (description != NULL)
|
if (description != NULL &&
|
||||||
error->description = strdup(description);
|
(error->description = strdup(description)) == NULL)
|
||||||
|
clar_abort("Failed to allocate description.\n");
|
||||||
|
|
||||||
_clar.total_errors++;
|
_clar.total_errors++;
|
||||||
_clar.last_report->status = CL_TEST_FAILURE;
|
_clar.last_report->status = CL_TEST_FAILURE;
|
||||||
@ -763,6 +776,7 @@ void clar__assert_equal(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#ifdef CLAR_HAVE_WCHAR
|
||||||
else if (!strcmp("%ls", fmt)) {
|
else if (!strcmp("%ls", fmt)) {
|
||||||
const wchar_t *wcs1 = va_arg(args, const wchar_t *);
|
const wchar_t *wcs1 = va_arg(args, const wchar_t *);
|
||||||
const wchar_t *wcs2 = 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)) {
|
#endif /* CLAR_HAVE_WCHAR */
|
||||||
size_t sz1 = va_arg(args, size_t), sz2 = va_arg(args, size_t);
|
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);
|
is_equal = (sz1 == sz2);
|
||||||
if (!is_equal) {
|
if (!is_equal) {
|
||||||
int offset = p_snprintf(buf, sizeof(buf), fmt, sz1);
|
int offset = p_snprintf(buf, sizeof(buf), fmt, sz1);
|
||||||
|
@ -21,7 +21,7 @@ static void clar_print_clap_error(int num, const struct clar_report *report, con
|
|||||||
{
|
{
|
||||||
printf(" %d) Failure:\n", num);
|
printf(" %d) Failure:\n", num);
|
||||||
|
|
||||||
printf("%s::%s [%s:%"PRIuZ"]\n",
|
printf("%s::%s [%s:%"PRIuMAX"]\n",
|
||||||
report->suite,
|
report->suite,
|
||||||
report->test,
|
report->test,
|
||||||
error->file,
|
error->file,
|
||||||
@ -136,7 +136,7 @@ static void clar_print_tap_ontest(const char *suite_name, const char *test_name,
|
|||||||
|
|
||||||
printf(" at:\n");
|
printf(" at:\n");
|
||||||
printf(" file: '"); print_escaped(error->file); printf("'\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(" function: '%s'\n", error->function);
|
||||||
printf(" ---\n");
|
printf(" ---\n");
|
||||||
|
|
||||||
@ -202,10 +202,15 @@ static void clar_print_onsuite(const char *suite_name, int suite_index)
|
|||||||
PRINT(onsuite, suite_name, 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, ...)
|
static void clar_print_onabort(const char *msg, ...)
|
||||||
{
|
{
|
||||||
va_list argp;
|
va_list argp;
|
||||||
va_start(argp, msg);
|
va_start(argp, msg);
|
||||||
PRINT(onabort, msg, argp);
|
clar_print_onabortv(msg, argp);
|
||||||
va_end(argp);
|
va_end(argp);
|
||||||
}
|
}
|
||||||
|
@ -122,14 +122,14 @@ static int build_sandbox_path(void)
|
|||||||
|
|
||||||
if (mkdir(_clar_path, 0700) != 0)
|
if (mkdir(_clar_path, 0700) != 0)
|
||||||
return -1;
|
return -1;
|
||||||
#elif defined(__TANDEM)
|
#elif defined(_WIN32)
|
||||||
if (mktemp(_clar_path) == NULL)
|
if (_mktemp_s(_clar_path, sizeof(_clar_path)) != 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (mkdir(_clar_path, 0700) != 0)
|
if (mkdir(_clar_path, 0700) != 0)
|
||||||
return -1;
|
return -1;
|
||||||
#elif defined(_WIN32)
|
#elif defined(__sun) || defined(__TANDEM)
|
||||||
if (_mktemp_s(_clar_path, sizeof(_clar_path)) != 0)
|
if (mktemp(_clar_path) == NULL)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (mkdir(_clar_path, 0700) != 0)
|
if (mkdir(_clar_path, 0700) != 0)
|
||||||
@ -142,15 +142,14 @@ static int build_sandbox_path(void)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int clar_sandbox(void)
|
static void clar_sandbox(void)
|
||||||
{
|
{
|
||||||
if (_clar_path[0] == '\0' && build_sandbox_path() < 0)
|
if (_clar_path[0] == '\0' && build_sandbox_path() < 0)
|
||||||
return -1;
|
clar_abort("Failed to build sandbox path.\n");
|
||||||
|
|
||||||
if (chdir(_clar_path) != 0)
|
if (chdir(_clar_path) != 0)
|
||||||
return -1;
|
clar_abort("Failed to change into sandbox directory '%s': %s.\n",
|
||||||
|
_clar_path, strerror(errno));
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *clar_sandbox_path(void)
|
const char *clar_sandbox_path(void)
|
||||||
|
@ -66,16 +66,12 @@ struct clar_summary *clar_summary_init(const char *filename)
|
|||||||
struct clar_summary *summary;
|
struct clar_summary *summary;
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
|
|
||||||
if ((fp = fopen(filename, "w")) == NULL) {
|
if ((fp = fopen(filename, "w")) == NULL)
|
||||||
perror("fopen");
|
clar_abort("Failed to open the summary file '%s': %s.\n",
|
||||||
return NULL;
|
filename, strerror(errno));
|
||||||
}
|
|
||||||
|
|
||||||
if ((summary = malloc(sizeof(struct clar_summary))) == NULL) {
|
if ((summary = malloc(sizeof(struct clar_summary))) == NULL)
|
||||||
perror("malloc");
|
clar_abort("Failed to allocate summary.\n");
|
||||||
fclose(fp);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
summary->filename = filename;
|
summary->filename = filename;
|
||||||
summary->fp = fp;
|
summary->fp = fp;
|
||||||
|
4
t/unit-tests/clar/test/.gitignore
vendored
4
t/unit-tests/clar/test/.gitignore
vendored
@ -1,4 +0,0 @@
|
|||||||
clar.suite
|
|
||||||
.clarcache
|
|
||||||
clar_test
|
|
||||||
*.o
|
|
39
t/unit-tests/clar/test/CMakeLists.txt
Normal file
39
t/unit-tests/clar/test/CMakeLists.txt
Normal file
@ -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)
|
@ -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
|
|
16
t/unit-tests/generate-clar-decls.sh
Executable file
16
t/unit-tests/generate-clar-decls.sh
Executable file
@ -0,0 +1,16 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
if test $# -lt 2
|
||||||
|
then
|
||||||
|
echo "USAGE: $0 <OUTPUT> <SUITE>..." 2>&1
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
OUTPUT="$1"
|
||||||
|
shift
|
||||||
|
|
||||||
|
for suite in "$@"
|
||||||
|
do
|
||||||
|
sed -ne "s/^\(void test_$(basename "${suite%.c}")__[a-zA-Z_0-9][a-zA-Z_0-9]*(void)\)$/extern \1;/p" "$suite" ||
|
||||||
|
exit 1
|
||||||
|
done >"$OUTPUT"
|
Reference in New Issue
Block a user