9unit/9unit.h

143 lines
3.8 KiB
C
Raw Normal View History

2023-11-06 13:59:19 -05:00
/*
9unit
Copyright (C) Jonathan Lamothe <jonathan@jlamothe.net>
2023-11-06 13:59:19 -05:00
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as
published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
2023-11-06 13:59:19 -05:00
This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
2023-11-06 13:59:19 -05:00
You should have received a copy of the GNU Lesser General Public
License along with this program. If not, see
<http://www.gnu.org/licenses/>.
2023-11-06 13:59:19 -05:00
*/
// Types & Structs
2023-11-06 13:59:19 -05:00
// Tracks information about the tests being run.
typedef struct TestState TestState;
// Defines a log entry in a TestState struct
typedef struct TestLogEntry TestLogEntry;
// The following structures will typically be maintained by the
// testing framework. You shouldn't need to concern yourself with
// them.
struct TestState
2023-11-06 13:59:19 -05:00
{
int run; // number of tests run
2023-11-06 15:20:09 -05:00
int passed; // number of successful tests
int failed; // number of failed tests
int pending; // number of pending tests
TestLogEntry *first_log; // the first log entry
TestLogEntry *last_log; //the last log entry
void *ptr; // used for passing data between tests
2023-11-14 18:08:19 -05:00
const char *context; // immediate context of current test
const char *full_context; // full context of current test
int depth; // how many tests "deep" are we?
void (*report)(const char *); // prints a string immediately
};
struct TestLogEntry
{
char *text; // the entry text
TestLogEntry *next; // points to the next entry
};
2023-11-06 13:59:19 -05:00
2023-11-06 15:20:09 -05:00
// Possible results of running a single test
2023-11-06 13:59:19 -05:00
typedef enum TestResult
{
test_success, // the test succeeded
test_failure, // the test failed
test_pending // the test is pending
2023-11-06 13:59:19 -05:00
} TestResult;
// Functions
2023-11-06 15:20:09 -05:00
// Runs a single test
extern void run_test(
2023-11-06 15:20:09 -05:00
TestState *, // the TestState data
TestResult (*)(TestState *) // the test to run
2023-11-06 15:20:09 -05:00
);
2023-11-17 18:35:02 -05:00
// 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
);
2023-11-06 15:30:06 -05:00
// Runs multiple tests, displaying a summary at the end
extern void run_tests(
2023-11-10 15:05:37 -05:00
// runs the tests and updates a provided TestState
2023-11-06 15:20:09 -05:00
void (*)(TestState *)
);
2023-11-06 14:46:01 -05:00
// Adds an entry to the log that is displayed after the tests have
// completed
extern void append_test_log(
TestState *, // the current state
const char * // the message to append
);
// Gives additional context for a test
extern void test_context(
TestState *, // the current state
const char *, // a description of the context
void (*)(TestState *) // the actual test
);
2023-11-17 16:30:52 -05:00
// 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
);
2023-11-18 23:40:19 -05:00
// Runs a single test with a context label
extern void single_test_context(
TestState *, // the current state
const char *, // a description of the context
TestResult (*)(TestState *) // the actual test
);
2023-11-18 11:38:00 -05:00
// Runs a single test with a context and input
extern void single_test_context_with(
TestState *, // the state
const char *, // the context
// the test
TestResult (*)(
TestState *, // the state
void * // the value being passed
),
void * // the value being passed
);
2023-11-16 14:53:06 -05:00
// 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 (*)(
2023-11-16 14:53:06 -05:00
TestState *,
void *, // the check value
void * // the reference value
),
void *, // the value being checked
void * // the reference value
2023-11-16 14:53:06 -05:00
);
2023-11-06 13:59:19 -05:00
//jl