42#if defined(__APPLE__) || defined(__linux__) || defined(__unix__)
47#if defined(MICRO_OS_PLUS_INCLUDE_CONFIG_H)
48#include <micro-os-plus/config.h>
51#if defined(MICRO_OS_PLUS_TRACE)
52#include <micro-os-plus/diag/trace.h>
62#pragma GCC diagnostic ignored "-Waggregate-return"
64#pragma clang diagnostic ignored "-Wunknown-warning-option"
65#pragma clang diagnostic ignored "-Wc++98-compat"
66#pragma clang diagnostic ignored "-Wc++98-compat-pedantic"
85 std::unique_ptr<std::vector<std::string_view>> argvs)
88#if defined(MICRO_OS_PLUS_TRACE) \
89 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS_CONSTRUCTORS)
90 trace::printf (
"%s\n", __PRETTY_FUNCTION__);
93#if defined(__APPLE__) || defined(__linux__) || defined(__unix__)
94 if (isatty (fileno (stdout)))
109#if defined(MICRO_OS_PLUS_TRACE) \
110 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS_CONSTRUCTORS)
111 trace::printf (
"%s\n", __PRETTY_FUNCTION__);
153#if defined(MICRO_OS_PLUS_TRACE) \
154 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS)
155 trace::printf (
"%s\n", __PRETTY_FUNCTION__);
159#pragma GCC diagnostic push
160#if defined(__clang__)
161#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
172 const char* message =
"µTest++ human report";
180 printf (
"%s\n", message);
188#pragma GCC diagnostic pop
204#if defined(MICRO_OS_PLUS_TRACE) \
205 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS)
206 trace::printf (
"%s\n", __PRETTY_FUNCTION__);
210#pragma GCC diagnostic push
211#if defined(__clang__)
212#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
225 uint32_t milliseconds = 0;
226 uint32_t microseconds = 0;
233 char message_totals[300];
234 snprintf (message_totals,
sizeof (message_totals),
235 "Total: %zu check%s passed, %zu failed, in %zu test "
236 "case%s, %zu test suite%s",
242 total_suites_count, total_suites_count == 1 ?
"" :
"s");
244 char message_time[120] =
"";
245 if (milliseconds > 0 || microseconds > 0)
247 snprintf (message_time,
sizeof (message_time),
248 ", time: %" PRIu32
".%03" PRIu32
" ms", milliseconds,
261 message_totals, message_time);
272 message_totals, message_time);
279#pragma GCC diagnostic pop
298#if defined(MICRO_OS_PLUS_TRACE) \
299 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS)
300#pragma GCC diagnostic push
301#if defined(__clang__)
302#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
304 trace::printf (
"%s '%s'\n", __PRETTY_FUNCTION__,
suite.
name ());
305#pragma GCC diagnostic pop
309#pragma GCC diagnostic push
310#if defined(__clang__)
311#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
335#pragma GCC diagnostic pop
354#if defined(MICRO_OS_PLUS_TRACE) \
355 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS)
357#pragma GCC diagnostic push
358#if defined(__clang__)
359#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
362 trace::printf (
"%s '%s'\n", __PRETTY_FUNCTION__,
suite.
name ());
364#pragma GCC diagnostic pop
369#pragma GCC diagnostic push
370#if defined(__clang__)
371#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
375 uint32_t milliseconds = 0;
376 uint32_t microseconds = 0;
382 char message_time[120] =
"";
383 if (milliseconds > 0 || microseconds > 0)
385 snprintf (message_time,
sizeof (message_time),
386 ", time: %" PRIu32
".%03" PRIu32
" ms", milliseconds,
405 char message_totals[300];
406 snprintf (message_totals,
sizeof (message_totals),
407 "(%zu check%s in %zu test case%s)",
418 message_totals, message_time);
429 suite.
name (), message_totals, message_time);
435 char message_totals[300];
436 snprintf (message_totals,
sizeof (message_totals),
437 "(%zu check%s passed, %zu "
438 "failed, in %zu test case%s)",
450 message_totals, message_time);
457 printf (
"%s✗%s %s - %sFAILED%s %s%s\n",
colours_.fail,
459 message_totals, message_time);
471#pragma GCC diagnostic pop
491#if defined(MICRO_OS_PLUS_TRACE) \
492 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS)
494#pragma GCC diagnostic push
495#if defined(__clang__)
496#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
499 trace::printf (
"%s '%s'\n", __PRETTY_FUNCTION__,
subtest.
name ());
501#pragma GCC diagnostic pop
506#pragma GCC diagnostic push
507#if defined(__clang__)
508#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
516 "Buffer not empty at the beginning of a test case:\n%s\n",
544#pragma GCC diagnostic pop
563#if defined(MICRO_OS_PLUS_TRACE) \
564 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS)
566#pragma GCC diagnostic push
567#if defined(__clang__)
568#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
571 trace::printf (
"%s '%s' i%zu\n", __PRETTY_FUNCTION__,
subtest.
name (),
574#pragma GCC diagnostic pop
579#pragma GCC diagnostic push
580#if defined(__clang__)
581#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
602 char message_totals[300];
603 snprintf (message_totals,
sizeof (message_totals),
638 char message_totals[300];
639 snprintf (message_totals,
sizeof (message_totals),
640 "(%zu check%s passed, %zu failed)",
669 printf (
"%s%s✗%s %s - %sFAILED%s %s\n",
indent.c_str (),
683#pragma GCC diagnostic pop
717 *
this <<
indent (level + 1);
719 if (!message.empty ())
721 *
this << message.c_str ();
754 std::string& message,
const bool has_expression,
758#pragma GCC diagnostic push
759#if defined(__clang__)
760#pragma clang diagnostic ignored "-Wsign-conversion"
761#elif defined(__GNUC__)
762#pragma GCC diagnostic ignored "-Wnarrowing"
763#pragma GCC diagnostic ignored "-Wsign-conversion"
769 *
this <<
indent (level + 1);
771 if (!message.empty ())
773 *
this << message.c_str ();
785#pragma GCC diagnostic pop
806 *
this <<
" aborted...";
size_t executed_subtests() const noexcept
Returns the number of subtests that were executed.
size_t successful_checks() const noexcept
Returns the number of checks that passed.
bool was_successful(void) const noexcept
Checks whether all executed checks were successful.
size_t failed_checks() const noexcept
Returns the number of checks that failed.
const char * name(void) const noexcept
Gets the node name.
runner_totals & totals() noexcept
Gets the totals for the test.
bool has_timestamps(void) const noexcept
Returns true if both begin and end timestamps are available.
void compute_elapsed_time(uint32_t &milliseconds, uint32_t µseconds) const
Computes the elapsed time between begin and end timestamps.
Local implementation of source location information for diagnostics.
constexpr auto file_name(void) const noexcept
Retrieve the file name associated with this source location.
constexpr auto line(void) const noexcept
Retrieve the line number associated with this source location.
virtual void end_subtest(subtest &subtest) override
Mark the end of a subtest.
virtual void begin_suite(suite &suite) override
Mark the beginning of a suite.
void output_fail_prefix_(std::string &message, const bool has_expression, const reflection::source_location &location, subtest &subtest) override
Outputs the prefix for a failing condition.
void end_session(runner &runner) override
Mark the end of a test session.
reporter_human(std::unique_ptr< std::vector< std::string_view > > argvs)
Constructor for the reporter_human class.
virtual void begin_subtest(subtest &subtest) override
Mark the beginning of a subtest.
reporter_human & operator<<(detail::indent_t m)
Output operator for the indent_t manipulator.
void begin_session(runner &runner) override
Mark the beginning of a test session.
virtual void end_suite(suite &suite) override
Mark the end of a test suite.
void output_pass_suffix_(subtest &subtest) override
Outputs the suffix for a passing condition.
virtual const char * get_comment_prefix(void) override
Returns an empty comment prefix string.
void output_pass_prefix_(std::string &message, subtest &subtest) override
Outputs the prefix for a passing condition.
void output_fail_suffix_(const reflection::source_location &location, bool abort, subtest &subtest) override
Outputs the suffix for a failing condition.
~reporter_human() override
Destructor for the reporter_human class.
reporter(std::unique_ptr< std::vector< std::string_view > > argvs)
Constructor for the reporter class.
FILE * output_file_
Optional output file for redirecting test report output.
void write_buffer_to_stdout(void)
Output the current buffered content.
bool add_empty_line_
Controls whether to add an empty line between successful test cases.
std::string buffer_
Output accumulation buffer.
void write_info_(void)
Appends informational (non-result) text to the output buffer.
detail::colours colours_
ANSI colour codes for output formatting.
void write_buffer_to_file_(void)
void flush(void)
Flush the current buffered content.
enum verbosity verbosity_
The verbosity level for test reporting.
The test runner for the µTest++ framework.
detail::timestamps & timings() noexcept
Gets the timings for this runner.
virtual size_t total_suites_count(void) const noexcept
Returns the total count of registered test suites.
A named, runnable test case that lives inside a suite.
size_t nesting_depth() const noexcept
Returns the nesting depth of this subtest.
A named, runnable test suite registered with the test runner.
detail::timestamps & timings() noexcept
Gets the timings for this suite.
constexpr colours colours_red_green
const char * short_name(const char *name) noexcept
Extract a short type or function name from a fully qualified name.
Primary namespace for the µTest++ testing framework.
constexpr size_t indent_size
Number of spaces per indentation level.
detail::indent_t indent(size_t level)
Factory function that creates an indent_t manipulator.
reporter & endl(reporter &stream)
Output stream manipulator for ending a line in test reports.
C++ header file with declarations for the µTest++ human test reporter.
C++ header file with declarations for the µTest++ test runner.
Parameterised stream manipulator for outputting indentation.
size_t level
Number of four-space indentation levels.
C++ header file with declarations for the µTest++ test suite.