micro-test-plus 4.1.0
µTest++ Testing Framework
Loading...
Searching...
No Matches
micro_os_plus::micro_test_plus::runner Class Reference

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

#include <micro-os-plus/micro-test-plus.h>

Inheritance diagram for micro_os_plus::micro_test_plus::runner:

Public Member Functions

 runner (const char *top_suite_name)
 Deprecated constructor for the runner class.
 runner (const runner &)=delete
 Deleted copy constructor to prevent copying.
 runner (runner &&)=delete
 Deleted move constructor to prevent moving.
 runner (void)
 Constructor for the runner class.
virtual ~runner () override
 Destructor for the runner class.
void abort (const reflection::source_location &sl=reflection::source_location::current())
 Aborts test execution immediately.
int exit_code (void)
 Returns 0 if all tests were successful, 1 otherwise.
class suiteinitialise (int argc, char *argv[], const char *top_suite_name="")
 Initialises the test runner with command-line arguments.
const char * name (void) const noexcept
 Gets the node name.
runneroperator= (const runner &)=delete
 Deleted copy assignment operator to prevent copying.
runneroperator= (runner &&)=delete
 Deleted move assignment operator to prevent moving.
class reporter & reporter (void) const noexcept
 Returns a reference to the test reporter.
template<typename Callable_T, typename... Args_T>
void suite (const char *name, Callable_T &&callable, Args_T &&... arguments)
 Adds a test suite to the runner.
size_t suites_count (void) const noexcept
 Returns the count of test suites.
const detail::timestampstimings () const noexcept
 Gets the timings for this runner (const overload).
detail::timestampstimings () noexcept
 Gets the timings for this runner.
virtual size_t total_suites_count (void) const noexcept
 Returns the total count of registered test suites.
const runner_totals & totals () const noexcept
 Gets the totals for the test (const overload).
runner_totals & totals () noexcept
 Gets the totals for the test.

Protected Member Functions

void register_suite_ (std::unique_ptr< class suite > suite)
 Registers a test suite with the runner.
virtual void run_suites_ (void)
 Runs all registered test suites.

Protected Attributes

std::vector< std::unique_ptr< class suite > > children_suites_
 Owning collection of dynamically registered child suites.
const char * name_
 The test node name.
std::unique_ptr< class reporterreporter_
 Pointer to the test reporter used for outputting test results.
detail::timestamps timings_
 Timings for this runner.
class top_suite top_suite_
 The implicit top-level suite; always present and executed first.
std::string top_suite_name_
 Owned storage for the implicit top-suite name.
runner_totals totals_
 Totals for the test node, including nested cases.

Detailed Description

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.

Constructor & Destructor Documentation

◆ runner() [1/4]

micro_os_plus::micro_test_plus::runner::runner ( void )
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.

Definition at line 107 of file runner.cpp.

107 : 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 }
const char * name(void) const noexcept
Gets the node name.
test_node(const char *name)
Constructs a test node.
Definition test.cpp:84
class top_suite top_suite_
The implicit top-level suite; always present and executed first.
Definition runner.h:291

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().

◆ runner() [2/4]

micro_os_plus::micro_test_plus::runner::runner ( const char * top_suite_name)
Parameters
[in]top_suite_nameThe 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.

Definition at line 130 of file runner.cpp.

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() [3/4]

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

References runner().

◆ runner() [4/4]

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

References runner().

◆ ~runner()

micro_os_plus::micro_test_plus::runner::~runner ( )
overridevirtual

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

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 }

Member Function Documentation

◆ abort()

void micro_os_plus::micro_test_plus::runner::abort ( const reflection::source_location & sl = reflection::source_location::current ())
Parameters
slThe 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().

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",
445 reflection::short_name (sl.file_name ()), sl.line ());
446#if defined(__GNUC__)
447#pragma GCC diagnostic pop
448#endif
449
450 ::abort ();
451 }
void abort(const reflection::source_location &sl=reflection::source_location::current())
Aborts test execution immediately.
Definition runner.cpp:431
const char * short_name(const char *name) noexcept
Extract a short type or function name from a fully qualified name.

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 )
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.

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 }
runner_totals totals_
Totals for the test node, including nested cases.
Definition test.h:229
detail::timestamps timings_
Timings for this runner.
Definition runner.h:311
std::unique_ptr< class reporter > reporter_
Pointer to the test reporter used for outputting test results.
Definition runner.h:306
virtual void run_suites_(void)
Runs all registered test suites.
Definition runner.cpp:337

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 = "" )
Parameters
argcThe argument count from main().
argvThe argument vector from main().
top_suite_nameThe 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.

Definition at line 182 of file runner.cpp.

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 }
std::string top_suite_name_
Owned storage for the implicit top-suite name.
Definition runner.h:316
const char * extract_file_name(const char *path) noexcept
Extracts the file name component from a full path.
Definition utility.cpp:85

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

◆ name()

const char * micro_os_plus::micro_test_plus::detail::test_node::name ( void ) const
inlinenodiscardnoexceptinherited

◆ operator=() [1/2]

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

References runner().

◆ operator=() [2/2]

◆ register_suite_()

void micro_os_plus::micro_test_plus::runner::register_suite_ ( std::unique_ptr< class suite > suite)
protected
Parameters
[in]suiteOwning 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.

Definition at line 307 of file runner.cpp.

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 }
void suite(const char *name, Callable_T &&callable, Args_T &&... arguments)
Adds a test suite to the runner.
std::vector< std::unique_ptr< class suite > > children_suites_
Owning collection of dynamically registered child suites.
Definition runner.h:301

References children_suites_, and suite().

Referenced by operator=(), and suite().

◆ reporter()

class reporter & micro_os_plus::micro_test_plus::runner::reporter ( void ) const
inlinenodiscardnoexcept
Parameters
None.
Returns
Reference to the test reporter.

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

Definition at line 76 of file runner-inlines.h.

77 {
78 return *reporter_;
79 }

References reporter_.

Referenced by operator=().

◆ run_suites_()

void micro_os_plus::micro_test_plus::runner::run_suites_ ( void )
protectedvirtual
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.

Reimplemented in micro_os_plus::micro_test_plus::static_runner.

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_().

◆ 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 )
Template Parameters
Callable_TThe type of a callable object.
Args_TThe types of the callable arguments.
Parameters
[in]nameThe test suite name or description, used in reports.
[in]callableA generic callable object, usually a lambda, invoked to perform the test suite.
[in]argumentsA 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.

Definition at line 112 of file runner-inlines.h.

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 }
void register_suite_(std::unique_ptr< class suite > suite)
Registers a test suite with the runner.
Definition runner.cpp:307

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 ) const
nodiscardnoexcept
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.

Definition at line 459 of file runner.cpp.

460 {
461 return children_suites_.size () + 1;
462 }

References 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() [1/2]

const detail::timestamps & micro_os_plus::micro_test_plus::runner::timings ( ) const
inlinenodiscardnoexcept
Parameters
None.
Returns
A const reference to the timestamps instance.

Returns a const reference to the timestamps member.

Definition at line 96 of file runner-inlines.h.

97 {
98 return timings_;
99 }

References timings_.

◆ timings() [2/2]

detail::timestamps & micro_os_plus::micro_test_plus::runner::timings ( )
inlinenodiscardnoexcept
Parameters
None.
Returns
A reference to the timestamps instance.

Returns a reference to the timestamps member.

Definition at line 86 of file runner-inlines.h.

87 {
88 return timings_;
89 }

References 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 ) const
nodiscardvirtualnoexcept
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.

Reimplemented in micro_os_plus::micro_test_plus::static_runner.

Definition at line 470 of file runner.cpp.

471 {
472 return suites_count ();
473 }
size_t suites_count(void) const noexcept
Returns the count of test suites.
Definition runner.cpp:459

References 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() [1/2]

const runner_totals & micro_os_plus::micro_test_plus::detail::test_node::totals ( ) const
inlinenodiscardnoexceptinherited
Parameters
None.
Returns
A const reference to the runner_totals instance.

Returns a const reference to the runner_totals member.

Definition at line 111 of file test-inlines.h.

112 {
113 return totals_;
114 }

References totals_.

◆ totals() [2/2]

runner_totals & micro_os_plus::micro_test_plus::detail::test_node::totals ( )
inlinenodiscardnoexceptinherited

Member Data Documentation

◆ children_suites_

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

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.

Referenced by register_suite_(), run_suites_(), and suites_count().

◆ name_

const char* micro_os_plus::micro_test_plus::detail::test_node::name_
protectedinherited
Note
Derived classes may access this member directly in addition to the public name() getter.

Definition at line 224 of file test.h.

Referenced by test_node(), micro_os_plus::micro_test_plus::detail::runnable< Self_T >::~runnable(), micro_os_plus::micro_test_plus::detail::runnable_base::~runnable_base(), ~test_node(), and name().

◆ reporter_

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

Definition at line 306 of file runner.h.

Referenced by exit_code(), initialise(), and reporter().

◆ timings_

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

Definition at line 311 of file runner.h.

Referenced by exit_code(), initialise(), timings(), and timings().

◆ top_suite_

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

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

Definition at line 316 of file runner.h.

Referenced by initialise().

◆ totals_

runner_totals micro_os_plus::micro_test_plus::detail::test_node::totals_
protectedinherited

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