2019-04-28 12:12:40 -05:00
|
|
|
// 28 april 2019
|
2019-06-01 08:27:17 -05:00
|
|
|
#include <errno.h>
|
|
|
|
#include <inttypes.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
2019-04-28 12:12:40 -05:00
|
|
|
#include "../ui.h"
|
2019-05-26 14:41:22 -05:00
|
|
|
#include "../common/testhooks.h"
|
2019-05-04 15:53:54 -05:00
|
|
|
#include "lib/testing.h"
|
2019-06-01 08:27:17 -05:00
|
|
|
#include "lib/thread.h"
|
2019-05-04 15:53:54 -05:00
|
|
|
#include "lib/timer.h"
|
2019-04-28 12:12:40 -05:00
|
|
|
|
2019-06-02 00:59:08 -05:00
|
|
|
#define diff(fmt) "\ngot " fmt "\nwant " fmt
|
2019-05-04 20:13:47 -05:00
|
|
|
|
2019-04-28 12:12:40 -05:00
|
|
|
// main.c
|
2019-05-03 09:32:31 -05:00
|
|
|
extern void timeoutMain(void *data);
|
2019-05-03 01:02:20 -05:00
|
|
|
#define timeout_uiMain(t, d) { \
|
|
|
|
timerSysError err; \
|
2019-05-30 21:09:45 -05:00
|
|
|
bool timedOut; \
|
2019-05-03 01:02:20 -05:00
|
|
|
err = timerRunWithTimeout(d, timeoutMain, NULL, &timedOut); \
|
|
|
|
if (err != 0) \
|
|
|
|
testingTErrorf(t, "error running uiMain() in timeout: " timerSysErrorFmt, timerSysErrorFmtArg(err)); \
|
|
|
|
if (timedOut) { \
|
|
|
|
char timeoutstr[timerDurationStringLen]; \
|
|
|
|
timerDurationString(d, timeoutstr); \
|
|
|
|
testingTErrorf(t, "uiMain() timed out (%s)", timeoutstr); \
|
|
|
|
} \
|
|
|
|
}
|
2019-05-26 19:19:02 -05:00
|
|
|
struct errorParams {
|
|
|
|
testingT *t;
|
2019-06-02 00:36:53 -05:00
|
|
|
const char *file;
|
|
|
|
long line;
|
2019-05-26 19:19:02 -05:00
|
|
|
const char *exprstr;
|
|
|
|
const char *msgWant;
|
|
|
|
bool caught;
|
|
|
|
};
|
2019-06-09 17:08:50 -05:00
|
|
|
extern void catchProgrammerError(const char *msg, void *data);
|
2019-05-26 19:19:02 -05:00
|
|
|
#define testProgrammerError(tt, expr, mw) { \
|
2019-06-09 17:08:50 -05:00
|
|
|
struct errorParams errorParams; \
|
2019-05-26 19:19:02 -05:00
|
|
|
testingTLogf(t, "*** %s", #expr); \
|
2019-06-09 17:08:50 -05:00
|
|
|
uiprivTestHookReportProgrammerError(catchProgrammerError, &errorParams); \
|
2019-05-26 19:19:02 -05:00
|
|
|
errorParams.t = tt; \
|
2019-06-02 00:36:53 -05:00
|
|
|
errorParams.file = __FILE__; \
|
|
|
|
errorParams.line = __LINE__; \
|
2019-06-02 00:51:40 -05:00
|
|
|
errorParams.exprstr = #expr; \
|
2019-05-26 19:19:02 -05:00
|
|
|
errorParams.msgWant = mw; \
|
|
|
|
errorParams.caught = false; \
|
|
|
|
expr; \
|
|
|
|
if (!errorParams.caught) \
|
2019-06-02 00:36:53 -05:00
|
|
|
testingTErrorfFull(t, errorParams.file, errorParams.line, "%s did not throw a programmer error; should have", #expr); \
|
2019-06-09 17:08:50 -05:00
|
|
|
uiprivTestHookReportProgrammerError(NULL, NULL); \
|
2019-05-26 19:19:02 -05:00
|
|
|
}
|
2019-05-10 20:16:29 -05:00
|
|
|
|
|
|
|
// init.c
|
|
|
|
extern testingSet *beforeTests;
|