Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/tymonx/utest

Lightweight unit testing framework for C/C++ projects. Suitable for embedded devices.
https://github.com/tymonx/utest

arm arm-microcontrollers bsd-license c-plus-plus c-plus-plus-11 cmake cortex-m cpp cpp11 embedded embedded-devices microcontrollers tdd test-driven-development testing unit-testing

Last synced: 28 days ago
JSON representation

Lightweight unit testing framework for C/C++ projects. Suitable for embedded devices.

Awesome Lists containing this project

README

        

# µTest

[![Language](https://img.shields.io/badge/language-C++-blue.svg?style=flat)](https://isocpp.org/)
[![Standard](https://img.shields.io/badge/c%2B%2B-11/14/17-blue.svg?style=flat)](https://en.wikipedia.org/wiki/C%2B%2B#Standardization)
[![License (3-Clause BSD)](https://img.shields.io/badge/license-BSD%203--Clause-blue.svg?style=flat)](http://opensource.org/licenses/BSD-3-Clause)
[![Build Status](https://travis-ci.org/tymonx/utest.svg?branch=master)](https://travis-ci.org/tymonx/utest)
[![Coverity Scan Build Status](https://scan.coverity.com/projects/11797/badge.svg)](https://scan.coverity.com/projects/tymonx-utest)
[![Coverage Status](https://coveralls.io/repos/github/tymonx/utest/badge.svg?branch=master)](https://coveralls.io/github/tymonx/utest?branch=master)
[![Join the chat at https://gitter.im/utest-embedded/Lobby](https://badges.gitter.im/utest-embedded/Lobby.svg)](https://gitter.im/utest-embedded/Lobby?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)

Lightweight unit testing framework mainly for C++ and also for C projects. Suitable for embedded devices.

## Key Features

* Written in C++11
* An XUnit test framework
* The 3-clause BSD license
* No evil defined test macros, programmer API style
* Detailed assert messages including type info, address and total size in bytes
* Automatic test registration
* Single registered test can have multi test suites and test cases
* A rich set of assertions
* Fatal and non-fatal assertions
* Support for multi reporters with multi writers
* Working with/without exceptions and RTTI
* Optionally running test case in isolate environment using thread
* Minimal virtual methods usage
* Small footprint, friendly for embedded target like Cortex-Mx microcontrollers
* Warnings free even on the most aggressive levels
* Support for Clang 3.5 and later
* Support for GCC 4.8 and later

## How to use it

* [Build under Linux](docs/build-linux.md)
* [Build for ARM target](docs/build-arm.md)

## Examples

Test source example:

```c++
#include

using namespace utest;

static unsigned int Factorial(unsigned int number) {
return number > 1 ? Factorial(number - 1) * number : 1;
}

static TestRunner g([] (TestSuite& test_suite) {
test_suite.name("Factorial").run([] (TestCase& test_case) {
test_case.name("computed").run([] (TestParams& p) {
TestAssert{p}.equal(Factorial(0), 1u);
TestAssert{p}.equal(Factorial(1), 1u);
TestAssert{p}.equal(Factorial(2), 2u);
TestAssert{p}.equal(Factorial(3), 6u);
TestAssert{p}.equal(Factorial(10), 3628800u);
});
});
});
```

Test output example:

```
[==========] Running 1 registered test runner(s).
[----------] Running test(s) from Factorial
[ RUN ] computed
[ OK ] computed
[----------] 1 test(s) from Factorial
[ PASSED ] 1 test(s).

[==========] 1 test(s) from 1 test suite(s) ran.
[ PASSED ] 1 test(s).
```

Test assert message examples:
```
unit_test.cpp:7: Failure
Expected: (boolean)[address=0x00007fa3b3411e08,size=1] is true
Actual: false

unit_test.cpp:13: Failure
Expected: (string)[address=0x00007fff4d0c00b0,size=4] == (string)[address=0x00000000004097ee,size=5]
Actual: "Text" == "TextB"

unit_test.cpp:17: Failure
Expected: (signed int)[address=0x00007fa3b3411dc8,size=4] == (signed int)[address=0x00007fa3b3411d98,size=4]
Actual: 1 == 2
```

Main example with multi writers:

```c++
#include

#include
#include
#include

#include

using namespace utest;

int main(int argc, char* argv[]) {
test_writer::UDP udp{"127.0.0.1", 51234};
test_writer::File out{stdout};

TestWriterRefence writers[]{
out,
udp
};

test_reporter::GoogleTest google_test{writers};

TestReporterReference reporters[]{
google_test
};

return TestStatus::PASS == Test{argc, argv}.run().status()
? EXIT_SUCCESS : EXIT_FAILURE;
}
```

Test example with evil macros extension:

```
#include
#include

UTEST_RUNNER()
UTEST_SUITE("integer compare")
int x = 0;

UTEST_CASE_CONTEXT(x);

UTEST_CASE_SETUP()
UTEST_CONTEXT(int) = 5;
UTEST_CASE_SETUP_END

UTEST_CASE("equal")
UTEST_EXPECT_EQ(UTEST_CONTEXT(int), 5);
UTEST_CASE_END

UTEST_CASE_SETUP()
UTEST_CONTEXT(int) = 4;
UTEST_CASE_SETUP_END

UTEST_CASE("not equal")
UTEST_EXPECT_NE(UTEST_CONTEXT(int), 5);
UTEST_CASE_END
UTEST_SUITE_END
UTEST_RUNNER_END
```