Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/0rayn/jt
Just-Test is your Test-Harness software made in C for C
https://github.com/0rayn/jt
c-language test-automation test-harnesses unit-testing
Last synced: about 2 months ago
JSON representation
Just-Test is your Test-Harness software made in C for C
- Host: GitHub
- URL: https://github.com/0rayn/jt
- Owner: 0rayn
- License: bsd-2-clause
- Created: 2024-07-25T14:14:40.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-08-07T14:26:43.000Z (6 months ago)
- Last Synced: 2024-12-01T22:37:04.652Z (about 2 months ago)
- Topics: c-language, test-automation, test-harnesses, unit-testing
- Language: C
- Homepage:
- Size: 133 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
```
██╗██╗ ██╗███████╗████████╗ ████████╗███████╗███████╗████████╗
██║██║ ██║██╔════╝╚══██╔══╝ ╚══██╔══╝██╔════╝██╔════╝╚══██╔══╝
██║██║ ██║███████╗ ██║ █████╗ ██║ █████╗ ███████╗ ██║
██ ██║██║ ██║╚════██║ ██║ ╚════╝ ██║ ██╔══╝ ╚════██║ ██║
╚█████╔╝╚██████╔╝███████║ ██║ ██║ ███████╗███████║ ██║
╚════╝ ╚═════╝ ╚══════╝ ╚═╝ ╚═╝ ╚══════╝╚══════╝ ╚═╝
```
Just-Test or Jt for short is your test-harness made in C for C, with the goal of making it as easy as possible for C devs to integrate unit testing and test-driven development(TDD) into their workflow.## *Summary*:
* [How to Build and Use](#HowToBuild)
* [General Structure of a Test file](#generalStructure)
* [Test Groups](#testGroups)
* [Assertions](#assertions)
* [Additional Features](#additionalFeatures)
* [Contributing](#contributing)
* [Examples](#examples)
## > *How to Build and Use*:
- you can either build the library to use everywhere in the future:
```bash
$> make lib
$> gcc -o Test MyTestFile.c jt.a
```
- Or you can compile it using the makeFile:
```bash
>> change FILE=
$> make
```
- BONUS:
- you can directly override variables in the makeFile like this:
```bash
$> make FILE=
```
- Check [LIBASM](https://github.com/Ayg0/LIBASM) where I did add Tests for under the Linux Section.
## > *Structure of a Test file*:
- Your test file must Contain:
- main with at leats `JTEST_START` and `JTEST_END`, which defines the block where you call the tests.
- You can call induvial TestGroups Using `runTest`(); or run all tests using `runAll`();
- A definition of `Jsetup`() and `Jcleanup`(), you can leave them empty if you don't need them.
- your test file can have multiple testGroups declared.
- Multiple Assertions to make sure everything works well.
## > *Test Groups*:
- If you Assertions are for the same purpose consider Grouping them under a TestGroup.
- Here is a declaration example ensuring the output of the add function:
```C
TEST_START(AddOutputChecks)
ASSERT_INT32_EQU(3, add(1,2));
ASSERT_INT32_EQU(-5, add(6, -11));
TEST_END
```
- TestGroups can be flaged to be ignored and not ran by JTEST, using the optional param `IGNORE_TEST`:
```C
TEST_START(AddOutputChecks, IGNORE_TEST)
ASSERT_INT32_EQU(3, add(1,2));
ASSERT_INT32_EQU(-5, add(6, -11));
TEST_END
```
## > *Assertions*:
- Assertions are your building blocks, they support all generic types for example:
```C
ASSERT_UINT32_EQU(3, add(1,2));
ASSERT_INT32_EQU(-5, add(6, -11));
ASSERT_FLOAT_EQU(3.14, PI);
```
- And also supports some useful formats, and types for example:
```C
ASSERT_HEX_EQU(0x45, 0x43);
ASSERT_STR_EQU("Hello", s);
```
- you can also test your own types using `ASSERT_DATA_EQU` for example:
```C
/*More Information Available in the TestExamples.c*/
typedef struct vector{
int x;
int y;
} _vector;_vector v1 = {.x = 0, .y = 6};
_vector v2 = {.x = 0, .y = 6};
ASSERT_DATA_EQU(&v1, &v2, cmpVector, printVector);
```
## > *Additional Features*:
**=>** Jtest Work on the Standard Error By default making it easier to dump it's output to a log file.
**=>** Jtest offers a No-Colors mode to make it well presented in a log file where colors will not show up (check Makefile).
## > *Contributing*:
Contributions are very welcome! Feel free to open issues or pull requests for bug fixes, improvements, or new features.
## > *Examples*:
| atoiBase | jtestExample |
|---|---|
| | |