VirtualBox

source: vbox/trunk/include/iprt/test.h@ 20554

Last change on this file since 20554 was 20374, checked in by vboxsync, 16 years ago

*: s/RT_\(BEGIN|END\)_DECLS/RT_C_DECLS_\1/g

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 30.1 KB
Line 
1/** @file
2 * IPRT - Testcase Framework.
3 */
4
5/*
6 * Copyright (C) 2009 Sun Microsystems, Inc.
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 *
25 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
26 * Clara, CA 95054 USA or visit http://www.sun.com if you need
27 * additional information or have any questions.
28 */
29
30#ifndef ___iprt_test_h
31#define ___iprt_test_h
32
33#include <iprt/cdefs.h>
34#include <iprt/types.h>
35#include <iprt/stdarg.h>
36
37RT_C_DECLS_BEGIN
38
39/** @defgroup grp_rt_test RTTest - Testcase Framework.
40 * @ingroup grp_rt
41 * @{
42 */
43
44/** A test handle. */
45typedef struct RTTESTINT *RTTEST;
46/** A pointer to a test handle. */
47typedef RTTEST *PRTTEST;
48/** A const pointer to a test handle. */
49typedef RTTEST const *PCRTTEST;
50
51/** A NIL Test handle. */
52#define NIL_RTTEST ((RTTEST)0)
53
54/**
55 * Test message importance level.
56 */
57typedef enum RTTESTLVL
58{
59 /** Invalid 0. */
60 RTTESTLVL_INVALID = 0,
61 /** Message should always be printed. */
62 RTTESTLVL_ALWAYS,
63 /** Failure message. */
64 RTTESTLVL_FAILURE,
65 /** Sub-test banner. */
66 RTTESTLVL_SUB_TEST,
67 /** Info message. */
68 RTTESTLVL_INFO,
69 /** Debug message. */
70 RTTESTLVL_DEBUG,
71 /** The last (invalid). */
72 RTTESTLVL_END
73} RTTESTLVL;
74
75
76/**
77 * Creates a test instance.
78 *
79 * @returns IPRT status code.
80 * @param pszTest The test name.
81 * @param phTest Where to store the test instance handle.
82 */
83RTR3DECL(int) RTTestCreate(const char *pszTest, PRTTEST phTest);
84
85/**
86 * Destroys a test instance previously created by RTTestCreate.
87 *
88 * @returns IPRT status code.
89 * @param hTest The test handle. NIL_RTTEST is ignored.
90 */
91RTR3DECL(int) RTTestDestroy(RTTEST hTest);
92
93/**
94 * Allocate a block of guarded memory.
95 *
96 * @returns IPRT status code.
97 * @param hTest The test handle. If NIL_RTTEST we'll use the one
98 * associated with the calling thread.
99 * @param cb The amount of memory to allocate.
100 * @param cbAlign The alignment of the returned block.
101 * @param fHead Head or tail optimized guard.
102 * @param ppvUser Where to return the pointer to the block.
103 */
104RTR3DECL(int) RTTestGuardedAlloc(RTTEST hTest, size_t cb, uint32_t cbAlign, bool fHead, void **ppvUser);
105
106/**
107 * Allocates a block of guarded memory where the guarded is immediately after
108 * the user memory.
109 *
110 * @returns Pointer to the allocated memory. NULL on failure.
111 * @param hTest The test handle. If NIL_RTTEST we'll use the one
112 * associated with the calling thread.
113 * @param cb The amount of memory to allocate.
114 */
115RTR3DECL(void *) RTTestGuardedAllocTail(RTTEST hTest, size_t cb);
116
117/**
118 * Allocates a block of guarded memory where the guarded is right in front of
119 * the user memory.
120 *
121 * @returns Pointer to the allocated memory. NULL on failure.
122 * @param hTest The test handle. If NIL_RTTEST we'll use the one
123 * associated with the calling thread.
124 * @param cb The amount of memory to allocate.
125 */
126RTR3DECL(void *) RTTestGuardedAllocHead(RTTEST hTest, size_t cb);
127
128/**
129 * Frees a block of guarded memory.
130 *
131 * @returns IPRT status code.
132 * @param hTest The test handle. If NIL_RTTEST we'll use the one
133 * associated with the calling thread.
134 * @param pv The memory. NULL is ignored.
135 */
136RTR3DECL(int) RTTestGuardedFree(RTTEST hTest, void *pv);
137
138/**
139 * Test vprintf making sure the output starts on a new line.
140 *
141 * @returns Number of chars printed.
142 * @param hTest The test handle. If NIL_RTTEST we'll use the one
143 * associated with the calling thread.
144 * @param enmLevel Message importance level.
145 * @param pszFormat The message.
146 * @param va Arguments.
147 */
148RTR3DECL(int) RTTestPrintfNlV(RTTEST hTest, RTTESTLVL enmLevel, const char *pszFormat, va_list va);
149
150/**
151 * Test printf making sure the output starts on a new line.
152 *
153 * @returns Number of chars printed.
154 * @param hTest The test handle. If NIL_RTTEST we'll use the one
155 * associated with the calling thread.
156 * @param enmLevel Message importance level.
157 * @param pszFormat The message.
158 * @param ... Arguments.
159 */
160RTR3DECL(int) RTTestPrintfNl(RTTEST hTest, RTTESTLVL enmLevel, const char *pszFormat, ...);
161
162/**
163 * Test vprintf, makes sure lines are prefixed and so forth.
164 *
165 * @returns Number of chars printed.
166 * @param hTest The test handle. If NIL_RTTEST we'll use the one
167 * associated with the calling thread.
168 * @param enmLevel Message importance level.
169 * @param pszFormat The message.
170 * @param va Arguments.
171 */
172RTR3DECL(int) RTTestPrintfV(RTTEST hTest, RTTESTLVL enmLevel, const char *pszFormat, va_list va);
173
174/**
175 * Test printf, makes sure lines are prefixed and so forth.
176 *
177 * @returns Number of chars printed.
178 * @param hTest The test handle. If NIL_RTTEST we'll use the one
179 * associated with the calling thread.
180 * @param enmLevel Message importance level.
181 * @param pszFormat The message.
182 * @param ... Arguments.
183 */
184RTR3DECL(int) RTTestPrintf(RTTEST hTest, RTTESTLVL enmLevel, const char *pszFormat, ...);
185
186/**
187 * Prints the test banner.
188 *
189 * @returns Number of chars printed.
190 * @param hTest The test handle. If NIL_RTTEST we'll use the one
191 * associated with the calling thread.
192 */
193RTR3DECL(int) RTTestBanner(RTTEST hTest);
194
195/**
196 * Summaries the test, destroys the test instance and return an exit code.
197 *
198 * @returns Test program exit code.
199 * @param hTest The test handle. If NIL_RTTEST we'll use the one
200 * associated with the calling thread.
201 */
202RTR3DECL(int) RTTestSummaryAndDestroy(RTTEST hTest);
203
204/**
205 * Skips the test, destroys the test instance and return an exit code.
206 *
207 * @returns Test program exit code.
208 * @param hTest The test handle. If NIL_RTTEST we'll use the one
209 * associated with the calling thread.
210 * @param pszReasonFmt Text explaining why, optional (NULL).
211 * @param va Arguments for the reason format string.
212 */
213RTR3DECL(int) RTTestSkipAndDestroyV(RTTEST hTest, const char *pszReason, va_list va);
214
215/**
216 * Skips the test, destroys the test instance and return an exit code.
217 *
218 * @returns Test program exit code.
219 * @param hTest The test handle. If NIL_RTTEST we'll use the one
220 * associated with the calling thread.
221 * @param pszReasonFmt Text explaining why, optional (NULL).
222 * @param va Arguments for the reason format string.
223 */
224RTR3DECL(int) RTTestSkipAndDestroy(RTTEST hTest, const char *pszReason, ...);
225
226/**
227 * Starts a sub-test.
228 *
229 * This will perform an implicit RTTestSubDone() call if that has not been done
230 * since the last RTTestSub call.
231 *
232 * @returns Number of chars printed.
233 * @param hTest The test handle. If NIL_RTTEST we'll use the one
234 * associated with the calling thread.
235 * @param pszSubTest The sub-test name.
236 */
237RTR3DECL(int) RTTestSub(RTTEST hTest, const char *pszSubTest);
238
239/**
240 * Format string version of RTTestSub.
241 *
242 * See RTTestSub for details.
243 *
244 * @returns Number of chars printed.
245 * @param hTest The test handle. If NIL_RTTEST we'll use the one
246 * associated with the calling thread.
247 * @param pszSubTestFmt The sub-test name format string.
248 * @param ... Arguments.
249 */
250RTR3DECL(int) RTTestSubF(RTTEST hTest, const char *pszSubTestFmt, ...);
251
252/**
253 * Format string version of RTTestSub.
254 *
255 * See RTTestSub for details.
256 *
257 * @returns Number of chars printed.
258 * @param hTest The test handle. If NIL_RTTEST we'll use the one
259 * associated with the calling thread.
260 * @param pszSubTestFmt The sub-test name format string.
261 * @param ... Arguments.
262 */
263RTR3DECL(int) RTTestSubV(RTTEST hTest, const char *pszSubTestFmt, va_list va);
264
265/**
266 * Completes a sub-test.
267 *
268 * @returns Number of chars printed.
269 * @param hTest The test handle. If NIL_RTTEST we'll use the one
270 * associated with the calling thread.
271 */
272RTR3DECL(int) RTTestSubDone(RTTEST hTest);
273
274/**
275 * Prints an extended PASSED message, optional.
276 *
277 * This does not conclude the sub-test, it could be used to report the passing
278 * of a sub-sub-to-the-power-of-N-test.
279 *
280 * @returns IPRT status code.
281 * @param hTest The test handle. If NIL_RTTEST we'll use the one
282 * associated with the calling thread.
283 * @param pszFormat The message. No trailing newline.
284 * @param va The arguments.
285 */
286RTR3DECL(int) RTTestPassedV(RTTEST hTest, const char *pszFormat, va_list va);
287
288/**
289 * Prints an extended PASSED message, optional.
290 *
291 * This does not conclude the sub-test, it could be used to report the passing
292 * of a sub-sub-to-the-power-of-N-test.
293 *
294 * @returns IPRT status code.
295 * @param hTest The test handle. If NIL_RTTEST we'll use the one
296 * associated with the calling thread.
297 * @param pszFormat The message. No trailing newline.
298 * @param ... The arguments.
299 */
300RTR3DECL(int) RTTestPassed(RTTEST hTest, const char *pszFormat, ...);
301
302
303/**
304 * Increments the error counter.
305 *
306 * @returns IPRT status code.
307 * @param hTest The test handle. If NIL_RTTEST we'll use the one
308 * associated with the calling thread.
309 */
310RTR3DECL(int) RTTestErrorInc(RTTEST hTest);
311
312/**
313 * Increments the error counter and prints a failure message.
314 *
315 * @returns IPRT status code.
316 * @param hTest The test handle. If NIL_RTTEST we'll use the one
317 * associated with the calling thread.
318 * @param pszFormat The message. No trailing newline.
319 * @param va The arguments.
320 */
321RTR3DECL(int) RTTestFailedV(RTTEST hTest, const char *pszFormat, va_list va);
322
323/**
324 * Increments the error counter and prints a failure message.
325 *
326 * @returns IPRT status code.
327 * @param hTest The test handle. If NIL_RTTEST we'll use the one
328 * associated with the calling thread.
329 * @param pszFormat The message. No trailing newline.
330 * @param ... The arguments.
331 */
332RTR3DECL(int) RTTestFailed(RTTEST hTest, const char *pszFormat, ...);
333
334/**
335 * Same as RTTestPrintfV with RTTESTLVL_FAILURE.
336 *
337 * @returns Number of chars printed.
338 * @param hTest The test handle. If NIL_RTTEST we'll use the one
339 * associated with the calling thread.
340 * @param enmLevel Message importance level.
341 * @param pszFormat The message.
342 * @param va Arguments.
343 */
344RTR3DECL(int) RTTestFailureDetailsV(RTTEST hTest, const char *pszFormat, va_list va);
345
346/**
347 * Same as RTTestPrintf with RTTESTLVL_FAILURE.
348 *
349 * @returns Number of chars printed.
350 * @param hTest The test handle. If NIL_RTTEST we'll use the one
351 * associated with the calling thread.
352 * @param enmLevel Message importance level.
353 * @param pszFormat The message.
354 * @param ... Arguments.
355 */
356RTR3DECL(int) RTTestFailureDetails(RTTEST hTest, const char *pszFormat, ...);
357
358
359/** @def RTTEST_CHECK
360 * Check whether a boolean expression holds true.
361 *
362 * If the expression is false, call RTTestFailed giving the line number and expression.
363 *
364 * @param hTest The test handle.
365 * @param expr The expression to evaluate.
366 */
367#define RTTEST_CHECK(hTest, expr) \
368 do { if (!(expr)) { \
369 RTTestFailed((hTest), "line %u: %s", __LINE__, #expr); \
370 } \
371 } while (0)
372/** @def RTTEST_CHECK_RET
373 * Check whether a boolean expression holds true, returns on false.
374 *
375 * If the expression is false, call RTTestFailed giving the line number and expression.
376 *
377 * @param hTest The test handle.
378 * @param expr The expression to evaluate.
379 * @param rcRet What to return on failure.
380 */
381#define RTTEST_CHECK_RET(hTest, expr, rcRet) \
382 do { if (!(expr)) { \
383 RTTestFailed((hTest), "line %u: %s", __LINE__, #expr); \
384 return (rcRet); \
385 } \
386 } while (0)
387/** @def RTTEST_CHECK_RETV
388 * Check whether a boolean expression holds true, returns void on false.
389 *
390 * If the expression is false, call RTTestFailed giving the line number and expression.
391 *
392 * @param hTest The test handle.
393 * @param expr The expression to evaluate.
394 */
395#define RTTEST_CHECK_RETV(hTest, expr) \
396 do { if (!(expr)) { \
397 RTTestFailed((hTest), "line %u: %s", __LINE__, #expr); \
398 return; \
399 } \
400 } while (0)
401
402
403/** @def RTTEST_CHECK_MSG
404 * Check whether a boolean expression holds true.
405 *
406 * If the expression is false, call RTTestFailed giving the line number and expression.
407 *
408 * @param hTest The test handle.
409 * @param expr The expression to evaluate.
410 * @param DetailsArgs Argument list for RTTestFailureDetails, including
411 * parenthesis.
412 */
413#define RTTEST_CHECK_MSG(hTest, expr, DetailsArgs) \
414 do { if (!(expr)) { \
415 RTTestFailed((hTest), "line %u: %s", __LINE__, #expr); \
416 RTTestFailureDetails DetailsArgs; \
417 } \
418 } while (0)
419/** @def RTTEST_CHECK_MSG_RET
420 * Check whether a boolean expression holds true, returns on false.
421 *
422 * If the expression is false, call RTTestFailed giving the line number and expression.
423 *
424 * @param hTest The test handle.
425 * @param expr The expression to evaluate.
426 * @param DetailsArgs Argument list for RTTestFailureDetails, including
427 * parenthesis.
428 * @param rcRet What to return on failure.
429 */
430#define RTTEST_CHECK_MSG_RET(hTest, expr, DetailsArgs, rcRet) \
431 do { if (!(expr)) { \
432 RTTestFailed((hTest), "line %u: %s", __LINE__, #expr); \
433 RTTestFailureDetails DetailsArgs; \
434 return (rcRet); \
435 } \
436 } while (0)
437/** @def RTTEST_CHECK_MSG_RET
438 * Check whether a boolean expression holds true, returns void on false.
439 *
440 * If the expression is false, call RTTestFailed giving the line number and expression.
441 *
442 * @param hTest The test handle.
443 * @param expr The expression to evaluate.
444 * @param DetailsArgs Argument list for RTTestFailureDetails, including
445 * parenthesis.
446 */
447#define RTTEST_CHECK_MSG_RETV(hTest, expr, DetailsArgs) \
448 do { if (!(expr)) { \
449 RTTestFailed((hTest), "line %u: %s", __LINE__, #expr); \
450 RTTestFailureDetails DetailsArgs; \
451 return; \
452 } \
453 } while (0)
454
455
456/** @def RTTEST_CHECK_RC
457 * Check whether an expression returns a specific IPRT style status code.
458 *
459 * If a different status code is return, call RTTestFailed giving the line
460 * number, expression, actual and expected status codes.
461 *
462 * @param hTest The test handle.
463 * @param rcExpr The expression resulting an IPRT status code.
464 * @param rcExpect The expected return code. This may be referenced
465 * more than once by the macro.
466 */
467#define RTTEST_CHECK_RC(hTest, rcExpr, rcExpect) \
468 do { \
469 int rcCheck = (rcExpr); \
470 if (rcCheck != (rcExpect)) { \
471 RTTestFailed((hTest), "line %u: %s: expected %Rrc, got %Rrc", __LINE__, #rcExpr, (rcExpect), rcCheck); \
472 } \
473 } while (0)
474/** @def RTTEST_CHECK_RC_RET
475 * Check whether an expression returns a specific IPRT style status code.
476 *
477 * If a different status code is return, call RTTestFailed giving the line
478 * number, expression, actual and expected status codes, then return.
479 *
480 * @param hTest The test handle.
481 * @param rcExpr The expression resulting an IPRT status code.
482 * @param rcExpect The expected return code. This may be referenced
483 * more than once by the macro.
484 * @param rcRet The return code.
485 */
486#define RTTEST_CHECK_RC_RET(hTest, rcExpr, rcExpect, rcRet) \
487 do { \
488 int rcCheck = (rcExpr); \
489 if (rcCheck != (rcExpect)) { \
490 RTTestFailed((hTest), "line %u: %s: expected %Rrc, got %Rrc", __LINE__, #rcExpr, (rcExpect), rcCheck); \
491 return (rcRet); \
492 } \
493 } while (0)
494/** @def RTTEST_CHECK_RC_RETV
495 * Check whether an expression returns a specific IPRT style status code.
496 *
497 * If a different status code is return, call RTTestFailed giving the line
498 * number, expression, actual and expected status codes, then return.
499 *
500 * @param hTest The test handle.
501 * @param rcExpr The expression resulting an IPRT status code.
502 * @param rcExpect The expected return code. This may be referenced
503 * more than once by the macro.
504 */
505#define RTTEST_CHECK_RC_RETV(hTest, rcExpr, rcExpect) \
506 do { \
507 int rcCheck = (rcExpr); \
508 if (rcCheck != (rcExpect)) { \
509 RTTestFailed((hTest), "line %u: %s: expected %Rrc, got %Rrc", __LINE__, #rcExpr, (rcExpect), rcCheck); \
510 return; \
511 } \
512 } while (0)
513
514
515/** @def RTTEST_CHECK_RC_OK
516 * Check whether a IPRT style status code indicates success.
517 *
518 * If the status indicates failure, call RTTestFailed giving the line number,
519 * expression and status code.
520 *
521 * @param hTest The test handle.
522 * @param rcExpr The expression resulting an IPRT status code.
523 */
524#define RTTEST_CHECK_RC_OK(hTest, rcExpr) \
525 do { \
526 int rcCheck = (rcExpr); \
527 if (RT_FAILURE(rcCheck)) { \
528 RTTestFailed((hTest), "line %u: %s: %Rrc", __LINE__, #rcExpr, rc); \
529 } \
530 } while (0)
531/** @def RTTEST_CHECK_RC_OK_RET
532 * Check whether a IPRT style status code indicates success.
533 *
534 * If the status indicates failure, call RTTestFailed giving the line number,
535 * expression and status code, then return with the specified value.
536 *
537 * @param hTest The test handle.
538 * @param rcExpr The expression resulting an IPRT status code.
539 * @param rcRet The return code.
540 */
541#define RTTEST_CHECK_RC_OK_RET(hTest, rcExpr, rcRet) \
542 do { \
543 int rcCheck = (rcExpr); \
544 if (RT_FAILURE(rcCheck)) { \
545 RTTestFailed((hTest), "line %u: %s: %Rrc", __LINE__, #rcExpr, rc); \
546 return (rcRet); \
547 } \
548 } while (0)
549/** @def RTTEST_CHECK_RC_OK_RETV
550 * Check whether a IPRT style status code indicates success.
551 *
552 * If the status indicates failure, call RTTestFailed giving the line number,
553 * expression and status code, then return.
554 *
555 * @param hTest The test handle.
556 * @param rcExpr The expression resulting an IPRT status code.
557 */
558#define RTTEST_CHECK_RC_OK_RETV(hTest, rcExpr) \
559 do { \
560 int rcCheck = (rcExpr); \
561 if (RT_FAILURE(rcCheck)) { \
562 RTTestFailed((hTest), "line %u: %s: %Rrc", __LINE__, #rcExpr, rc); \
563 return; \
564 } \
565 } while (0)
566
567
568
569
570/** @name Implicit Test Handle API Variation
571 * The test handle is retrieved from the test TLS entry of the calling thread.
572 * @{
573 */
574
575/**
576 * Test vprintf, makes sure lines are prefixed and so forth.
577 *
578 * @returns Number of chars printed.
579 * @param enmLevel Message importance level.
580 * @param pszFormat The message.
581 * @param va Arguments.
582 */
583RTR3DECL(int) RTTestIPrintfV(RTTESTLVL enmLevel, const char *pszFormat, va_list va);
584
585/**
586 * Test printf, makes sure lines are prefixed and so forth.
587 *
588 * @returns Number of chars printed.
589 * @param enmLevel Message importance level.
590 * @param pszFormat The message.
591 * @param ... Arguments.
592 */
593RTR3DECL(int) RTTestIPrintf(RTTESTLVL enmLevel, const char *pszFormat, ...);
594
595/**
596 * Starts a sub-test.
597 *
598 * This will perform an implicit RTTestSubDone() call if that has not been done
599 * since the last RTTestSub call.
600 *
601 * @returns Number of chars printed.
602 * @param pszSubTest The sub-test name.
603 */
604RTR3DECL(int) RTTestISub(const char *pszSubTest);
605
606/**
607 * Format string version of RTTestSub.
608 *
609 * See RTTestSub for details.
610 *
611 * @returns Number of chars printed.
612 * @param pszSubTestFmt The sub-test name format string.
613 * @param ... Arguments.
614 */
615RTR3DECL(int) RTTestISubF(const char *pszSubTestFmt, ...);
616
617/**
618 * Format string version of RTTestSub.
619 *
620 * See RTTestSub for details.
621 *
622 * @returns Number of chars printed.
623 * @param pszSubTestFmt The sub-test name format string.
624 * @param ... Arguments.
625 */
626RTR3DECL(int) RTTestISubV(const char *pszSubTestFmt, va_list va);
627
628/**
629 * Completes a sub-test.
630 *
631 * @returns Number of chars printed.
632 */
633RTR3DECL(int) RTTestISubDone(void);
634
635/**
636 * Prints an extended PASSED message, optional.
637 *
638 * This does not conclude the sub-test, it could be used to report the passing
639 * of a sub-sub-to-the-power-of-N-test.
640 *
641 * @returns IPRT status code.
642 * @param pszFormat The message. No trailing newline.
643 * @param va The arguments.
644 */
645RTR3DECL(int) RTTestIPassedV(const char *pszFormat, va_list va);
646
647/**
648 * Prints an extended PASSED message, optional.
649 *
650 * This does not conclude the sub-test, it could be used to report the passing
651 * of a sub-sub-to-the-power-of-N-test.
652 *
653 * @returns IPRT status code.
654 * @param pszFormat The message. No trailing newline.
655 * @param ... The arguments.
656 */
657RTR3DECL(int) RTTestIPassed(const char *pszFormat, ...);
658
659/**
660 * Increments the error counter.
661 *
662 * @returns IPRT status code.
663 */
664RTR3DECL(int) RTTestIErrorInc(void);
665
666/**
667 * Increments the error counter and prints a failure message.
668 *
669 * @returns IPRT status code.
670 * @param pszFormat The message. No trailing newline.
671 * @param va The arguments.
672 */
673RTR3DECL(int) RTTestIFailedV(const char *pszFormat, va_list va);
674
675/**
676 * Increments the error counter and prints a failure message.
677 *
678 * @returns IPRT status code.
679 * @param pszFormat The message. No trailing newline.
680 * @param ... The arguments.
681 */
682RTR3DECL(int) RTTestIFailed(const char *pszFormat, ...);
683
684/**
685 * Same as RTTestIPrintfV with RTTESTLVL_FAILURE.
686 *
687 * @returns Number of chars printed.
688 * @param pszFormat The message.
689 * @param va Arguments.
690 */
691RTR3DECL(int) RTTestIFailureDetailsV(const char *pszFormat, va_list va);
692
693/**
694 * Same as RTTestIPrintf with RTTESTLVL_FAILURE.
695 *
696 * @returns Number of chars printed.
697 * @param pszFormat The message.
698 * @param ... Arguments.
699 */
700RTR3DECL(int) RTTestIFailureDetails(const char *pszFormat, ...);
701
702
703/** @def RTTESTI_CHECK
704 * Check whether a boolean expression holds true.
705 *
706 * If the expression is false, call RTTestIFailed giving the line number and
707 * expression.
708 *
709 * @param expr The expression to evaluate.
710 */
711#define RTTESTI_CHECK(expr) \
712 do { if (!(expr)) { \
713 RTTestIFailed("line %u: %s", __LINE__, #expr); \
714 } \
715 } while (0)
716/** @def RTTESTI_CHECK_RET
717 * Check whether a boolean expression holds true, returns on false.
718 *
719 * If the expression is false, call RTTestIFailed giving the line number and
720 * expression.
721 *
722 * @param expr The expression to evaluate.
723 * @param rcRet What to return on failure.
724 */
725#define RTTESTI_CHECK_RET(expr, rcRet) \
726 do { if (!(expr)) { \
727 RTTestIFailed("line %u: %s", __LINE__, #expr); \
728 return (rcRet); \
729 } \
730 } while (0)
731/** @def RTTESTI_CHECK_RETV
732 * Check whether a boolean expression holds true, returns void on false.
733 *
734 * If the expression is false, call RTTestIFailed giving the line number and
735 * expression.
736 *
737 * @param expr The expression to evaluate.
738 */
739#define RTTESTI_CHECK_RETV(expr) \
740 do { if (!(expr)) { \
741 RTTestIFailed("line %u: %s", __LINE__, #expr); \
742 return; \
743 } \
744 } while (0)
745
746
747/** @def RTTESTI_CHECK_MSG
748 * Check whether a boolean expression holds true.
749 *
750 * If the expression is false, call RTTestIFailed giving the line number and
751 * expression.
752 *
753 * @param expr The expression to evaluate.
754 * @param DetailsArgs Argument list for RTTestIFailureDetails, including
755 * parenthesis.
756 */
757#define RTTESTI_CHECK_MSG(expr, DetailsArgs) \
758 do { if (!(expr)) { \
759 RTTestIFailed("line %u: %s", __LINE__, #expr); \
760 RTTestIFailureDetails DetailsArgs; \
761 } \
762 } while (0)
763/** @def RTTESTI_CHECK_MSG_RET
764 * Check whether a boolean expression holds true, returns on false.
765 *
766 * If the expression is false, call RTTestIFailed giving the line number and
767 * expression.
768 *
769 * @param expr The expression to evaluate.
770 * @param DetailsArgs Argument list for RTTestIFailureDetails, including
771 * parenthesis.
772 * @param rcRet What to return on failure.
773 */
774#define RTTESTI_CHECK_MSG_RET(expr, DetailsArgs, rcRet) \
775 do { if (!(expr)) { \
776 RTTestIFailed("line %u: %s", __LINE__, #expr); \
777 RTTestIFailureDetails DetailsArgs; \
778 return (rcRet); \
779 } \
780 } while (0)
781/** @def RTTESTI_CHECK_MSG_RET
782 * Check whether a boolean expression holds true, returns void on false.
783 *
784 * If the expression is false, call RTTestIFailed giving the line number and
785 * expression.
786 *
787 * @param expr The expression to evaluate.
788 * @param DetailsArgs Argument list for RTTestIFailureDetails, including
789 * parenthesis.
790 */
791#define RTTESTI_CHECK_MSG_RETV(expr, DetailsArgs) \
792 do { if (!(expr)) { \
793 RTTestIFailed("line %u: %s", __LINE__, #expr); \
794 RTTestIFailureDetails DetailsArgs; \
795 return; \
796 } \
797 } while (0)
798
799
800/** @def RTTESTI_CHECK_RC
801 * Check whether an expression returns a specific IPRT style status code.
802 *
803 * If a different status code is return, call RTTestIFailed giving the line
804 * number, expression, actual and expected status codes.
805 *
806 * @param rcExpr The expression resulting an IPRT status code.
807 * @param rcExpect The expected return code. This may be referenced
808 * more than once by the macro.
809 */
810#define RTTESTI_CHECK_RC(rcExpr, rcExpect) \
811 do { \
812 int rcCheck = (rcExpr); \
813 if (rcCheck != (rcExpect)) { \
814 RTTestIFailed("line %u: %s: expected %Rrc, got %Rrc", __LINE__, #rcExpr, (rcExpect), rcCheck); \
815 } \
816 } while (0)
817/** @def RTTESTI_CHECK_RC_RET
818 * Check whether an expression returns a specific IPRT style status code.
819 *
820 * If a different status code is return, call RTTestIFailed giving the line
821 * number, expression, actual and expected status codes, then return.
822 *
823 * @param rcExpr The expression resulting an IPRT status code.
824 * @param rcExpect The expected return code. This may be referenced
825 * more than once by the macro.
826 * @param rcRet The return code.
827 */
828#define RTTESTI_CHECK_RC_RET(rcExpr, rcExpect, rcRet) \
829 do { \
830 int rcCheck = (rcExpr); \
831 if (rcCheck != (rcExpect)) { \
832 RTTestIFailed("line %u: %s: expected %Rrc, got %Rrc", __LINE__, #rcExpr, (rcExpect), rcCheck); \
833 return (rcRet); \
834 } \
835 } while (0)
836/** @def RTTESTI_CHECK_RC_RETV
837 * Check whether an expression returns a specific IPRT style status code.
838 *
839 * If a different status code is return, call RTTestIFailed giving the line
840 * number, expression, actual and expected status codes, then return.
841 *
842 * @param rcExpr The expression resulting an IPRT status code.
843 * @param rcExpect The expected return code. This may be referenced
844 * more than once by the macro.
845 */
846#define RTTESTI_CHECK_RC_RETV(rcExpr, rcExpect) \
847 do { \
848 int rcCheck = (rcExpr); \
849 if (rcCheck != (rcExpect)) { \
850 RTTestIFailed("line %u: %s: expected %Rrc, got %Rrc", __LINE__, #rcExpr, (rcExpect), rcCheck); \
851 return; \
852 } \
853 } while (0)
854
855
856/** @def RTTESTI_CHECK_RC_OK
857 * Check whether a IPRT style status code indicates success.
858 *
859 * If the status indicates failure, call RTTestIFailed giving the line number,
860 * expression and status code.
861 *
862 * @param rcExpr The expression resulting an IPRT status code.
863 */
864#define RTTESTI_CHECK_RC_OK(rcExpr) \
865 do { \
866 int rcCheck = (rcExpr); \
867 if (RT_FAILURE(rcCheck)) { \
868 RTTestIFailed("line %u: %s: %Rrc", __LINE__, #rcExpr, rcCheck); \
869 } \
870 } while (0)
871/** @def RTTESTI_CHECK_RC_OK_RET
872 * Check whether a IPRT style status code indicates success.
873 *
874 * If the status indicates failure, call RTTestIFailed giving the line number,
875 * expression and status code, then return with the specified value.
876 *
877 * @param rcExpr The expression resulting an IPRT status code.
878 * @param rcRet The return code.
879 */
880#define RTTESTI_CHECK_RC_OK_RET(rcExpr, rcRet) \
881 do { \
882 int rcCheck = (rcExpr); \
883 if (RT_FAILURE(rcCheck)) { \
884 RTTestIFailed("line %u: %s: %Rrc", __LINE__, #rcExpr, rcCheck); \
885 return (rcRet); \
886 } \
887 } while (0)
888/** @def RTTESTI_CHECK_RC_OK_RETV
889 * Check whether a IPRT style status code indicates success.
890 *
891 * If the status indicates failure, call RTTestIFailed giving the line number,
892 * expression and status code, then return.
893 *
894 * @param rcExpr The expression resulting an IPRT status code.
895 */
896#define RTTESTI_CHECK_RC_OK_RETV(rcExpr) \
897 do { \
898 int rcCheck = (rcExpr); \
899 if (RT_FAILURE(rcCheck)) { \
900 RTTestIFailed("line %u: %s: %Rrc", __LINE__, #rcExpr, rcCheck); \
901 return; \
902 } \
903 } while (0)
904
905/** @} */
906
907
908/** @} */
909
910RT_C_DECLS_END
911
912#endif
913
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette