Skip to main content

runner Class

The test runner for the µTest++ framework. More...

Declaration

class micro_os_plus::micro_test_plus::runner { ... }

Included Headers

Base class

classtest_node

Base class for runners and runable tests. More...

Derived Classes

classstatic_runner

A runner variant that also manages statically-registered test suites. More...

Public Constructors Index

runner (const char *top_suite_name)

Deprecated constructor for the runner class. More...

runner (const runner &)=delete

Deleted copy constructor to prevent copying. More...

runner (runner &&)=delete

Deleted move constructor to prevent moving. More...

runner (void)

Constructor for the runner class. More...

Public Destructor Index

~runner () override

Destructor for the runner class. More...

Public Operators Index

runner &operator= (const runner &)=delete

Deleted copy assignment operator to prevent copying. More...

runner &operator= (runner &&)=delete

Deleted move assignment operator to prevent moving. More...

Public Member Functions Index

voidabort (const reflection::source_location &sl=reflection::source_location::current())

Aborts test execution immediately. More...

intexit_code (void)

Returns 0 if all tests were successful, 1 otherwise. More...

class suite &initialise (int argc, char *argv[], const char *top_suite_name="")

Initialises the test runner with command-line arguments. More...

const char *name (void) const noexcept

Gets the node name. More...

class reporter &reporter (void) const noexcept

Returns a reference to the test reporter. More...

template <typename Callable_T, typename... Args_T>
voidsuite (const char *name, Callable_T &&callable, Args_T &&... arguments)

Adds a test suite to the runner. More...

size_tsuites_count (void) const noexcept

Returns the count of test suites. More...

const detail::timestamps &timings () const noexcept

Gets the timings for this runner (const overload). More...

detail::timestamps &timings () noexcept

Gets the timings for this runner. More...

size_ttotal_suites_count (void) const noexcept

Returns the total count of registered test suites. More...

const runner_totals &totals () const noexcept

Gets the totals for the test (const overload). More...

runner_totals &totals () noexcept

Gets the totals for the test. More...

Protected Member Functions Index

voidregister_suite_ (std::unique_ptr< class suite > suite)

Registers a test suite with the runner. More...

voidrun_suites_ (void)

Runs all registered test suites. More...

Protected Member Attributes Index

std::vector< std::unique_ptr< class suite > >children_suites_

Owning collection of dynamically registered child suites. More...

const char *name_

The test node name. More...

std::unique_ptr< class reporter >reporter_

Pointer to the test reporter used for outputting test results. More...

detail::timestampstimings_

Timings for this runner. More...

class { ... }top_suite_

The implicit top-level suite; always present and executed first. More...

std::stringtop_suite_name_

Owned storage for the implicit top-suite name. More...

runner_totalstotals_

Totals for the test node, including nested cases. More...

Description

The test runner for the µTest++ framework.

The runner class is responsible for managing the registration and execution of test suites within the µTest++ framework. It maintains a collection of test suites, each of which registers itself automatically upon construction, enabling seamless integration and execution of tests across different components and folders of a project.

The test runner provides methods for initialising the test environment, registering test suites, retrieving the runner's name, and determining the overall test result via an exit code. It also offers an abort mechanism for terminating test execution in exceptional circumstances.

All members and methods are defined within the micro_os_plus::micro_test_plus namespace, ensuring clear separation from user code and minimising the risk of naming conflicts.

Definition at line 110 of file runner.h.

Public Constructors

runner()

micro_os_plus::micro_test_plus::runner::runner (const char * top_suite_name)

Deprecated constructor for the runner class.

Parameters
[in] top_suite_name

The name given to the implicit top suite. Defaults to an empty string.

Deprecated

Use the anonymous constructor.

The constructor initialises a new runner instance together with its top suite (top_suite_). If tracing is enabled, it outputs the function signature for diagnostic purposes.

Declaration at line 129 of file runner.h, definition at line 130 of file runner.cpp.

130 runner::runner (const char* top_suite_name)
131 : test_node{ "runner" }, top_suite_{ top_suite_name, *this }
132 {
133#if defined(MICRO_OS_PLUS_TRACE) \
134 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS_CONSTRUCTORS)
135#if defined(__GNUC__)
136#pragma GCC diagnostic push
137#if defined(__clang__)
138#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
139#endif
140#endif
141 trace::printf ("%s '%s'\n", __PRETTY_FUNCTION__, name ());
142#if defined(__GNUC__)
143#pragma GCC diagnostic pop
144#endif
145#endif // MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS_CONSTRUCTORS
146 }

References micro_os_plus::micro_test_plus::detail::test_node::test_node, micro_os_plus::micro_test_plus::detail::test_node::name and top_suite_.

runner()

micro_os_plus::micro_test_plus::runner::runner (const runner &)
delete

Deleted copy constructor to prevent copying.

Definition at line 134 of file runner.h.

Reference runner.

runner()

micro_os_plus::micro_test_plus::runner::runner (runner &&)
delete

Deleted move constructor to prevent moving.

Definition at line 139 of file runner.h.

Reference runner.

runner()

micro_os_plus::micro_test_plus::runner::runner (void)

Constructor for the runner class.

Parameters

None.

The constructor initialises a new runner instance together with its top suite (top_suite_). If tracing is enabled, it outputs the function signature for diagnostic purposes.

Declaration at line 119 of file runner.h, definition at line 107 of file runner.cpp.

107 runner::runner (void) : test_node{ "runner" }, top_suite_{ "", *this }
108 {
109#if defined(MICRO_OS_PLUS_TRACE) \
110 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS_CONSTRUCTORS)
111#if defined(__GNUC__)
112#pragma GCC diagnostic push
113#if defined(__clang__)
114#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
115#endif
116#endif
117 trace::printf ("%s '%s'\n", __PRETTY_FUNCTION__, name ());
118#if defined(__GNUC__)
119#pragma GCC diagnostic pop
120#endif
121#endif // MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS_CONSTRUCTORS
122 }

References micro_os_plus::micro_test_plus::detail::test_node::test_node, micro_os_plus::micro_test_plus::detail::test_node::name and top_suite_.

Referenced by runner, runner, micro_os_plus::micro_test_plus::static_runner::static_runner, micro_os_plus::micro_test_plus::static_runner::static_runner, operator=, operator=, micro_os_plus::micro_test_plus::static_runner::operator= and micro_os_plus::micro_test_plus::static_runner::register_static_suite.

Public Destructor

~runner()

micro_os_plus::micro_test_plus::runner::~runner ()
virtual

Destructor for the runner class.

The reporter_ unique pointer is released automatically. If tracing is enabled, the function signature is output for diagnostic purposes.

Declaration at line 158 of file runner.h, definition at line 153 of file runner.cpp.

154 {
155#if defined(MICRO_OS_PLUS_TRACE) \
156 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS_CONSTRUCTORS)
157 trace::printf ("%s\n", __PRETTY_FUNCTION__);
158#endif // MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS_CONSTRUCTORS
159
160 // reporter_ is a unique_ptr; destroyed automatically.
161 }

Public Operators

operator=()

runner & micro_os_plus::micro_test_plus::runner::operator= (const runner &)
delete

Deleted copy assignment operator to prevent copying.

Definition at line 145 of file runner.h.

Reference runner.

operator=()

runner & micro_os_plus::micro_test_plus::runner::operator= (runner &&)
delete

Public Member Functions

abort()

void micro_os_plus::micro_test_plus::runner::abort (const reflection::source_location & sl=reflection::source_location::current())

Aborts test execution immediately.

Parameters
sl

The source location from which the abort is triggered.

Returns

Nothing.

Prints the source location of the fatal error to stderr and then terminates the process via ::abort().

Declaration at line 210 of file runner.h, definition at line 431 of file runner.cpp.

432 {
433#if defined(MICRO_OS_PLUS_TRACE) \
434 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS)
435 trace::printf ("%s\n", __PRETTY_FUNCTION__);
436#endif // MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS
437
438#if defined(__GNUC__)
439#pragma GCC diagnostic push
440#if defined(__clang__)
441#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
442#endif
443#endif
444 fprintf (stderr, "\nerror: test execution aborted at %s:%u\n",
446#if defined(__GNUC__)
447#pragma GCC diagnostic pop
448#endif
449
450 ::abort ();
451 }

References abort, micro_os_plus::micro_test_plus::reflection::source_location::file_name, micro_os_plus::micro_test_plus::reflection::source_location::line and micro_os_plus::micro_test_plus::reflection::short_name.

Referenced by abort.

exit_code()

int micro_os_plus::micro_test_plus::runner::exit_code (void)

Returns 0 if all tests were successful, 1 otherwise.

Parameters

None.

Returns

Integer exit code representing the overall test result.

Finalises the top suite by recording its end timestamp and notifying the reporter, then accumulates its totals into the runner totals. Subsequently invokes run_suites_() to sort, execute, and accumulate all registered child suites. Finally, records the session end timestamp, notifies the reporter, and returns 0 if all checks passed or 1 otherwise.

Declaration at line 180 of file runner.h, definition at line 384 of file runner.cpp.

385 {
386#if defined(MICRO_OS_PLUS_TRACE) \
387 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS)
388 trace::printf ("%s\n", __PRETTY_FUNCTION__);
389#endif // MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS
390
391 if (reporter_ == nullptr)
392 {
393 fprintf (stderr, "error: test runner not initialised\n");
394 return 1;
395 }
396
397 top_suite_.timings ().timestamp_end ();
398 reporter_->end_suite (top_suite_);
399 totals_ += top_suite_.totals ();
400
401 run_suites_ ();
402
403 timings_.timestamp_end ();
404 reporter_->end_session (*this);
405
406 const int result = totals_.was_successful () ? 0 : 1;
407
408#if defined(MICRO_OS_PLUS_TRACE) \
409 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS)
410#if defined(__GNUC__)
411#pragma GCC diagnostic push
412#if defined(__clang__)
413#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
414#endif
415#endif
416 trace::printf ("%s -> %d\n", __PRETTY_FUNCTION__, result);
417#if defined(__GNUC__)
418#pragma GCC diagnostic pop
419#endif
420#endif // MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS
421
422 return result;
423 }

References reporter_, run_suites_, timings_, top_suite_ and micro_os_plus::micro_test_plus::detail::test_node::totals_.

initialise()

suite & micro_os_plus::micro_test_plus::runner::initialise (int argc, char * argv=[], const char * top_suite_name="")

Initialises the test runner with command-line arguments.

Parameters
argc

The argument count from main().

argv

The argument vector from main().

top_suite_name

The name given to the implicit top suite. Defaults to an empty string.

Returns

Reference to the top-level test suite.

Captures command-line arguments, selects the reporter implementation (human or tap), starts session timing, and emits the initial reporter notifications for the session and top suite.

If the top suite name is not provided, it attempts to derive a name from argv[0] or defaults to "default suite".

If tracing is enabled, the command-line arguments are also logged for diagnostic purposes.

Declaration at line 170 of file runner.h, definition at line 182 of file runner.cpp.

182 runner::initialise (int argc, char* argv[], const char* top_suite_name)
183 {
184#if defined(MICRO_OS_PLUS_TRACE) \
185 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS)
186 trace::printf ("%s\n", __PRETTY_FUNCTION__);
187#endif // MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS
188
189#if !(defined(MICRO_OS_PLUS_INCLUDE_STARTUP) && defined(MICRO_OS_PLUS_TRACE))
190#if defined(MICRO_OS_PLUS_DEBUG)
191 trace::printf ("argv[");
192 for (int i = 0; i < argc; ++i)
193 {
194 if (i > 0)
195 {
196 trace::printf (", ");
197 }
198 trace::printf ("'%s'", argv[i]);
199 }
200 trace::puts ("]");
201#endif // defined(MICRO_OS_PLUS_DEBUG)
202#endif // !defined(MICRO_OS_PLUS_INCLUDE_STARTUP)
203
204 if (strlen (top_suite_name) > 0)
205 {
206 // If provided by this call, use it, possibly override the
207 // deprecated constructor.
208 top_suite_name_ = top_suite_name;
209 top_suite_.name (top_suite_name_.c_str ());
210 }
211 else if (strlen (top_suite_.name ()) == 0)
212 {
213 // If not provided by the constructor or by this call, try to extract a
214 // name from argv[0], which is commonly the executable name. If that
215 // fails, use a default name.
216 if (argc > 0 && argv != nullptr && argv[0] != nullptr)
217 {
218 std::string_view top_suite_name_view{ utility::extract_file_name (
219 argv[0]) };
220
221 const auto dot_pos = top_suite_name_view.rfind ('.');
222 if (dot_pos != std::string_view::npos)
223 {
224 top_suite_name_view = top_suite_name_view.substr (0, dot_pos);
225 }
226
227 top_suite_name_ = top_suite_name_view;
228 }
229 else
230 {
231 top_suite_name_ = "default suite";
232 }
233 top_suite_.name (top_suite_name_.c_str ());
234 }
235
236 std::vector<std::string_view> argvs (argv, argv + argc);
237
238 std::string_view reporter_name{ "tap" };
239 static constexpr std::string_view reporter_prefix{ "--reporter=" };
240 for (size_t i = 0; i < argvs.size (); ++i)
241 {
242 if (argvs[i].starts_with (reporter_prefix))
243 {
244 reporter_name = argvs[i].substr (reporter_prefix.size ());
245 }
246 else if (argvs[i]
247 == reporter_prefix.substr (0, reporter_prefix.size () - 1))
248 {
249 if (i + 1 < argvs.size ())
250 {
251 reporter_name = argvs[++i];
252 }
253 else
254 {
255 fprintf (stderr, "error: --reporter option requires a "
256 "reporter name argument\n");
257 exit (1);
258 }
259 }
260 }
261
262 // Initialise and configure the reporter.
263 if (reporter_name == "human")
264 {
265 reporter_ = std::make_unique<reporter_human> (
266 std::make_unique<std::vector<std::string_view>> (
267 std::move (argvs)));
268 }
269 else if (reporter_name == "tap")
270 {
271 reporter_ = std::make_unique<reporter_tap> (
272 std::make_unique<std::vector<std::string_view>> (
273 std::move (argvs)));
274 }
275 else
276 {
277 fprintf (stderr, "error: unknown reporter '%.*s'\n",
278 static_cast<int> (reporter_name.size ()),
279 reporter_name.data ());
280 exit (1);
281 }
282
283 // ------------------------------------------------------------------------
284
285 timings_.timestamp_begin ();
286 reporter_->begin_session (*this);
287
288 top_suite_.timings ().timestamp_begin ();
289 reporter_->begin_suite (top_suite_);
290
291 return top_suite_;
292 }

References micro_os_plus::micro_test_plus::utility::extract_file_name, reporter_, timings_, top_suite_ and top_suite_name_.

name()

reporter()

class reporter & micro_os_plus::micro_test_plus::runner::reporter (void)
inline nodiscard noexcept

Returns a reference to the test reporter.

Parameters

None.

Returns

Reference to the test reporter.

Returns a reference to the reporter object stored in the unique pointer.

Declaration at line 234 of file runner.h, definition at line 76 of file runner-inlines.h.

76 runner::reporter (void) const noexcept
77 {
78 return *reporter_;
79 }

Reference reporter_.

Referenced by operator=.

suite()

template <typename Callable_T, typename... Args_T>
void micro_os_plus::micro_test_plus::runner::suite (const char * name, Callable_T && callable, Args_T &&... arguments)

Adds a test suite to the runner.

Template Parameters
Callable_T

The type of a callable object.

Args_T

The types of the callable arguments.

Parameters
[in] name

The test suite name or description, used in reports.

[in] callable

A generic callable object, usually a lambda, invoked to perform the test suite.

[in] arguments

A possibly empty list of arguments to be passed to the callable.

Returns

Nothing.

Constructs a suite object on the heap, binding the callable and any additional arguments, then transfers ownership to the runner via register_suite_(). The suite runs immediately as part of the registration process.

Declaration at line 198 of file runner.h, definition at line 112 of file runner-inlines.h.

112 runner::suite (const char* name, Callable_T&& callable,
113 Args_T&&... arguments)
114 {
115#if defined(MICRO_OS_PLUS_TRACE) \
116 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS)
117#if defined(__GNUC__)
118#pragma GCC diagnostic push
119#if defined(__clang__)
120#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
121#endif
122#endif
123 trace::printf ("%s '%s'\n", __PRETTY_FUNCTION__, name);
124#if defined(__GNUC__)
125#pragma GCC diagnostic pop
126#endif
127#endif // MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS
128
129 auto child_suite = std::make_unique<class suite> (
130 name, *this, std::forward<Callable_T> (callable),
131 std::forward<Args_T> (arguments)...);
132
133 register_suite_ (std::move (child_suite));
134 }

References micro_os_plus::micro_test_plus::detail::test_node::name and register_suite_.

Referenced by operator=, micro_os_plus::micro_test_plus::static_runner::operator=, micro_os_plus::micro_test_plus::static_runner::register_static_suite and register_suite_.

suites_count()

size_t micro_os_plus::micro_test_plus::runner::suites_count (void)
nodiscard noexcept

Returns the count of test suites.

Parameters

None.

Returns

The number of test suites, including the top one.

Returns the number of registered child suites plus one, accounting for the top suite.

Declaration at line 264 of file runner.h, definition at line 459 of file runner.cpp.

459 runner::suites_count (void) const noexcept
460 {
461 return children_suites_.size () + 1;
462 }

Reference children_suites_.

Referenced by operator=, micro_os_plus::micro_test_plus::static_runner::run_suites_, total_suites_count and micro_os_plus::micro_test_plus::static_runner::total_suites_count.

timings()

const detail::timestamps & micro_os_plus::micro_test_plus::runner::timings ()
inline nodiscard noexcept

Gets the timings for this runner (const overload).

Parameters

None.

Returns

A const reference to the timestamps instance.

Returns a const reference to the timestamps member.

Declaration at line 254 of file runner.h, definition at line 96 of file runner-inlines.h.

96 runner::timings () const noexcept
97 {
98 return timings_;
99 }

Reference timings_.

timings()

detail::timestamps & micro_os_plus::micro_test_plus::runner::timings ()
inline nodiscard noexcept

Gets the timings for this runner.

Parameters

None.

Returns

A reference to the timestamps instance.

Returns a reference to the timestamps member.

Declaration at line 244 of file runner.h, definition at line 86 of file runner-inlines.h.

86 runner::timings () noexcept
87 {
88 return timings_;
89 }

Reference timings_.

Referenced by micro_os_plus::micro_test_plus::reporter_human::end_session, micro_os_plus::micro_test_plus::reporter_tap::end_session and operator=.

total_suites_count()

size_t micro_os_plus::micro_test_plus::runner::total_suites_count (void)
nodiscard noexcept virtual

Returns the total count of registered test suites.

Parameters

None.

Returns

The total number of test suites managed by this runner.

For the base runner, the total suite count equals suites_count(), as there are no additional static suites.

Declaration at line 224 of file runner.h, definition at line 470 of file runner.cpp.

470 runner::total_suites_count (void) const noexcept
471 {
472 return suites_count ();
473 }

Reference suites_count.

Referenced by micro_os_plus::micro_test_plus::reporter_human::end_session and micro_os_plus::micro_test_plus::reporter_tap::end_session.

totals()

const runner_totals & micro_os_plus::micro_test_plus::detail::test_node::totals ()
inline nodiscard noexcept

Gets the totals for the test (const overload).

Parameters

None.

Returns

A const reference to the runner_totals instance.

Returns a const reference to the runner_totals member.

Declaration at line 215 of file test.h, definition at line 111 of file test-inlines.h.

111 test_node::totals () const noexcept
112 {
113 return totals_;
114 }

Reference micro_os_plus::micro_test_plus::detail::test_node::totals_.

totals()

Protected Member Functions

register_suite_()

void micro_os_plus::micro_test_plus::runner::register_suite_ (std::unique_ptr< class suite > suite)
protected

Registers a test suite with the runner.

Parameters
[in] suite

Owning pointer to the test suite to register.

Returns

Nothing.

Takes ownership of the supplied suite unique pointer and appends it to the internal children_suites_ vector, deferring execution until run_suites_() is called. If tracing is enabled, the suite name is logged for diagnostic purposes.

Declaration at line 284 of file runner.h, definition at line 307 of file runner.cpp.

307 runner::register_suite_ (std::unique_ptr<class suite> suite)
308 {
309#if defined(MICRO_OS_PLUS_TRACE) \
310 && defined(MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS)
311#if defined(__GNUC__)
312#pragma GCC diagnostic push
313#if defined(__clang__)
314#pragma clang diagnostic ignored "-Wunsafe-buffer-usage-in-libc-call"
315#endif
316#endif
317 trace::printf ("%s '%s'\n", __PRETTY_FUNCTION__, suite->name ());
318#if defined(__GNUC__)
319#pragma GCC diagnostic pop
320#endif
321#endif // MICRO_OS_PLUS_TRACE_MICRO_TEST_PLUS
322
323 children_suites_.push_back (std::move (suite));
324 }

References children_suites_ and suite.

Referenced by operator= and suite.

run_suites_()

void micro_os_plus::micro_test_plus::runner::run_suites_ (void)
protected virtual

Runs all registered test suites.

Parameters

None.

Sorts children_suites_ alphabetically by suite name using a selection sort on unique_ptr::swap, avoiding the -Waggregate-return diagnostic that std::sort would trigger on unique-pointer iterators. Each suite is assigned a 1-based index offset by the top-suite index, executed via suite::run(), and its totals are accumulated into the runner totals. The executed-subtest counter is not incremented; suites are not counted as subtests.

Declaration at line 274 of file runner.h, definition at line 337 of file runner.cpp.

338 {
339 // Use selection sort with unique_ptr::swap (returns void) to avoid
340 // std::sort triggering -Waggregate-return via std::move_backward,
341 // which returns a class-type iterator when operating on unique_ptr
342 // elements.
343 const size_t n = children_suites_.size ();
344 for (size_t i = 0; i < n; ++i)
345 {
346 size_t min_idx = i;
347 for (size_t j = i + 1; j < n; ++j)
348 {
349 if (std::string_view{ children_suites_[j]->name () }
350 < std::string_view{ children_suites_[min_idx]->name () })
351 min_idx = j;
352 }
353 if (min_idx != i)
354 children_suites_[i].swap (children_suites_[min_idx]);
355 }
356
357 for (size_t i = 0; i < n; ++i)
358 {
359 auto* suite_ptr = children_suites_[i].get ();
360
361 // 1 for 1-based index, 1 for top suite
362 suite_ptr->own_index (i + 1 + 1);
363
364 // Run the child suite immediately.
365 suite_ptr->run ();
366
367 // Accumulate the totals from the child suite into the runner
368 // totals.
369 // DO NOT increment executed_subtests here.
370 totals_ += suite_ptr->totals ();
371 }
372 }

References children_suites_ and micro_os_plus::micro_test_plus::detail::test_node::totals_.

Referenced by exit_code, operator= and micro_os_plus::micro_test_plus::static_runner::run_suites_.

Protected Member Attributes

children_suites_

std::vector<std::unique_ptr<class suite> > micro_os_plus::micro_test_plus::runner::children_suites_
protected

Owning collection of dynamically registered child suites.

Each call to runner::suite() appends a new suite to this vector and runs it immediately. The vector retains ownership of all suites for the lifetime of the runner.

Definition at line 301 of file runner.h.

301 std::vector<std::unique_ptr<class suite>> children_suites_;

Referenced by register_suite_, run_suites_ and suites_count.

name_

const char* micro_os_plus::micro_test_plus::detail::test_node::name_
protected

reporter_

std::unique_ptr<class reporter> micro_os_plus::micro_test_plus::runner::reporter_
protected

Pointer to the test reporter used for outputting test results.

Definition at line 306 of file runner.h.

306 std::unique_ptr<class reporter> reporter_;

Referenced by exit_code, initialise and reporter.

timings_

detail::timestamps micro_os_plus::micro_test_plus::runner::timings_
protected

Timings for this runner.

Definition at line 311 of file runner.h.

311 detail::timestamps timings_;

Referenced by exit_code, initialise, timings and timings.

top_suite_

class top_suite micro_os_plus::micro_test_plus::runner::top_suite_
protected

The implicit top-level suite; always present and executed first.

Definition at line 291 of file runner.h.

Referenced by runner, runner, exit_code and initialise.

top_suite_name_

std::string micro_os_plus::micro_test_plus::runner::top_suite_name_
protected

Owned storage for the implicit top-suite name.

Definition at line 316 of file runner.h.

316 std::string top_suite_name_;

Referenced by initialise.

totals_

runner_totals micro_os_plus::micro_test_plus::detail::test_node::totals_
protected

The documentation for this class was generated from the following files:


Generated via doxygen2docusaurus 2.2.0 by Doxygen 1.17.0.