Compare commits
5 Commits
0ad79ea3b0
...
6c191d8405
Author | SHA1 | Date | |
---|---|---|---|
|
6c191d8405 | ||
|
37ce34b160 | ||
|
5d67b7aeb8 | ||
|
7818e3d646 | ||
|
a7351b5667 |
104
9unit.c
104
9unit.c
@ -27,11 +27,18 @@
|
|||||||
|
|
||||||
// Internal Types
|
// Internal Types
|
||||||
|
|
||||||
// data required by the context management functions
|
typedef struct RunTestWith RunTestWith;
|
||||||
typedef struct ContextData ContextData;
|
typedef struct ContextData ContextData;
|
||||||
|
|
||||||
// data required to run a single test with a label
|
|
||||||
typedef struct SingleTestContext SingleTestContext;
|
typedef struct SingleTestContext SingleTestContext;
|
||||||
|
typedef struct TestContextWith TestContextWith;
|
||||||
|
typedef struct CheckValue CheckValue;
|
||||||
|
|
||||||
|
struct RunTestWith
|
||||||
|
{
|
||||||
|
void *ptr; // state's prevoius ptr value
|
||||||
|
TestResult (*test)(TestState *, void *); // the test
|
||||||
|
void *val; // the value being passed in
|
||||||
|
};
|
||||||
|
|
||||||
struct ContextData
|
struct ContextData
|
||||||
{
|
{
|
||||||
@ -47,6 +54,20 @@ struct SingleTestContext
|
|||||||
TestResult (*test)(TestState *); // the test to run
|
TestResult (*test)(TestState *); // the test to run
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct TestContextWith
|
||||||
|
{
|
||||||
|
void *ptr; // state's original ptr value
|
||||||
|
void *val; // the value being passed in
|
||||||
|
void (*test)(TestState *, void *); // the test function
|
||||||
|
};
|
||||||
|
|
||||||
|
struct CheckValue
|
||||||
|
{
|
||||||
|
void *chk_val; // the value being checked
|
||||||
|
void *ref_val; // the reference value
|
||||||
|
void (*test)(TestState *, void *, void *); // the test
|
||||||
|
};
|
||||||
|
|
||||||
// Internal Prototypes
|
// Internal Prototypes
|
||||||
|
|
||||||
static void init_TestState(TestState *);
|
static void init_TestState(TestState *);
|
||||||
@ -54,10 +75,13 @@ static void print_log(TestState *);
|
|||||||
static void clear_log(TestState *);
|
static void clear_log(TestState *);
|
||||||
static void reindex(TestState *);
|
static void reindex(TestState *);
|
||||||
static void report(const char *);
|
static void report(const char *);
|
||||||
|
static TestResult run_test_with_test(TestState *);
|
||||||
static void build_new_context(TestState *, ContextData *);
|
static void build_new_context(TestState *, ContextData *);
|
||||||
static void display_context(TestState *);
|
static void display_context(TestState *);
|
||||||
static void restore_context(TestState *, ContextData *);
|
static void restore_context(TestState *, ContextData *);
|
||||||
static void run_single_test_context(TestState *);
|
static void run_single_test_context(TestState *);
|
||||||
|
static void test_context_with_test(TestState *);
|
||||||
|
static void check_value_test(TestState *, void *);
|
||||||
|
|
||||||
// Public Functions
|
// Public Functions
|
||||||
|
|
||||||
@ -90,6 +114,23 @@ run_test(TestState *s, TestResult (*t)(TestState *))
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
run_test_with(
|
||||||
|
TestState *s, // the state
|
||||||
|
TestResult (*test)(TestState *, void *), // the test
|
||||||
|
void *val // the value being passed in
|
||||||
|
)
|
||||||
|
{
|
||||||
|
if (!s) return;
|
||||||
|
if (!test) run_test(s, 0);
|
||||||
|
RunTestWith d;
|
||||||
|
d.ptr = s->ptr;
|
||||||
|
d.test = test;
|
||||||
|
d.val = val;
|
||||||
|
s->ptr = &d;
|
||||||
|
run_test(s, run_test_with_test);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
run_tests(void (*tests)(TestState *))
|
run_tests(void (*tests)(TestState *))
|
||||||
{
|
{
|
||||||
@ -172,6 +213,40 @@ single_test_context(
|
|||||||
test_context(s, label, run_single_test_context);
|
test_context(s, label, run_single_test_context);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
test_context_with(
|
||||||
|
TestState *s,
|
||||||
|
const char *context,
|
||||||
|
void (*test)(TestState *, void *),
|
||||||
|
void *val
|
||||||
|
)
|
||||||
|
{
|
||||||
|
if (!(s && test)) return;
|
||||||
|
TestContextWith d;
|
||||||
|
d.ptr = s->ptr;
|
||||||
|
d.val = val;
|
||||||
|
d.test = test;
|
||||||
|
s->ptr = &d;
|
||||||
|
test_context(s, context, test_context_with_test);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
check_value(
|
||||||
|
TestState *s,
|
||||||
|
const char *context,
|
||||||
|
void (*test)(TestState *, void *, void *),
|
||||||
|
void *chk_val,
|
||||||
|
void *ref_val
|
||||||
|
)
|
||||||
|
{
|
||||||
|
if (!(s && test)) return;
|
||||||
|
CheckValue d;
|
||||||
|
d.chk_val = chk_val;
|
||||||
|
d.ref_val = ref_val;
|
||||||
|
d.test = test;
|
||||||
|
test_context_with(s, context, check_value_test, &d);
|
||||||
|
}
|
||||||
|
|
||||||
// Internal Functions
|
// Internal Functions
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -230,6 +305,14 @@ report(const char *str)
|
|||||||
print("%s", str);
|
print("%s", str);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static TestResult
|
||||||
|
run_test_with_test(TestState *s)
|
||||||
|
{
|
||||||
|
RunTestWith *d = s->ptr;
|
||||||
|
s->ptr = d->ptr;
|
||||||
|
return (*d->test)(s, d->val);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
build_new_context(TestState *s, ContextData *cd)
|
build_new_context(TestState *s, ContextData *cd)
|
||||||
{
|
{
|
||||||
@ -276,4 +359,19 @@ run_single_test_context(TestState *s)
|
|||||||
run_test(s, stc->test);
|
run_test(s, stc->test);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_context_with_test(TestState *s)
|
||||||
|
{
|
||||||
|
TestContextWith *d = s->ptr;
|
||||||
|
s->ptr = d->ptr;
|
||||||
|
(*d->test)(s, d->val);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
check_value_test(TestState *s, void *ptr)
|
||||||
|
{
|
||||||
|
CheckValue *d = ptr;
|
||||||
|
(*d->test)(s, d->chk_val, d->ref_val);
|
||||||
|
}
|
||||||
|
|
||||||
//jl
|
//jl
|
||||||
|
31
9unit.h
31
9unit.h
@ -67,6 +67,13 @@ extern void run_test(
|
|||||||
TestResult (*)(TestState *) // the test to run
|
TestResult (*)(TestState *) // the test to run
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// Runs a single test with an arbitrary input
|
||||||
|
extern void run_test_with(
|
||||||
|
TestState *, // the state
|
||||||
|
TestResult (*)(TestState *, void *), // the test
|
||||||
|
void * // the value to pass in
|
||||||
|
);
|
||||||
|
|
||||||
// Runs multiple tests, displaying a summary at the end
|
// Runs multiple tests, displaying a summary at the end
|
||||||
extern void run_tests(
|
extern void run_tests(
|
||||||
// runs the tests and updates a provided TestState
|
// runs the tests and updates a provided TestState
|
||||||
@ -94,4 +101,28 @@ extern void single_test_context(
|
|||||||
TestResult (*)(TestState *) // the actual test
|
TestResult (*)(TestState *) // the actual test
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// Runs a test with a context and an additional input
|
||||||
|
extern void test_context_with(
|
||||||
|
TestState *, // the current state
|
||||||
|
const char *, // a description of the context
|
||||||
|
void (*)(TestState *, void *), // the test function
|
||||||
|
void * // the value being passed in
|
||||||
|
);
|
||||||
|
|
||||||
|
// Runs a test to check a value
|
||||||
|
extern void check_value(
|
||||||
|
TestState *, // the current test state
|
||||||
|
const char *, // a description of the context
|
||||||
|
|
||||||
|
// the test function
|
||||||
|
void (*)(
|
||||||
|
TestState *,
|
||||||
|
void *, // the check value
|
||||||
|
void * // the reference value
|
||||||
|
),
|
||||||
|
|
||||||
|
void *, // the value being checked
|
||||||
|
void * // the reference value
|
||||||
|
);
|
||||||
|
|
||||||
//jl
|
//jl
|
||||||
|
Loading…
x
Reference in New Issue
Block a user