Skip to content

a modern, portable, cross-language unit testing and mocking framework for C and C++

License

LGPL-2.1, LGPL-2.1 licenses found

Licenses found

LGPL-2.1
LICENSE
LGPL-2.1
COPYING
Notifications You must be signed in to change notification settings

matthargett/cgreen

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Linux: Build Status

Coverage Status

Cgreen - The Modern Unit Test and Mocking Framework for C and C++

Do you TDD? In C? Maybe you want to have your tests read out in a fluent fashion? Like this

Ensure(Converter, converts_XIV_to_14) {
    assert_that(convert_roman_to_decimal("XIV"), is_equal_to(14));
}

And you want output like this

roman_test.c:12: Failure: Converter -> converts_XIV_to_14
        Expected [convert_roman_to_decimal("XIV")] to [equal] [14]
                actual value:                   [0]
                expected value:                 [14]

Then Cgreen is the thing for you!

What It Is

Cgreen is a modern unit test and mocking framework for C and C++. Here are some of Cgreens unique selling points:

  • fast build, clean code, highly portable
  • auto-discovery of tests without the abuse of static initializers or globals
  • extensible without recompiling
  • fluent, expressive and readable API with the same modern syntax across C and C++
  • process isolation for each test preventing intermittent failures and cross-test dependencies
  • built-in mocking for C, compatible with mockitopp and other C++ mocking libraries

Getting It

Cgreen has recently moved from SourceForge to GitHub so things are in a bit of a flux. From SourceForge you can get pre-build packages for not-so-old development versions.

But Cgreen is approaching a 1.0 release and things are changing, so for now an alternative is to download the zip from GitHub and build it yourself.

Building It

You need Cmake but most standard C/C++ compilers should work. GCC definitely does.

In the root directory run make. That will configure and build the C version and the C++ version of the libraries.

Reading Up!

The documentation is fairly up-to-date. You can read the extensive tutorial directly on GitHub.

You can also build the documentation yourself in HTML and PDF format. Generate it using Asciidoctor, which can be done using the Cmake configuration. Of course you need Asciidoctor.

Navigate to the build/build-c directory. You need to add the WITH_HTML and/or WITH_PDF option:

cmake -DWITH_HTML:bool=ON ../..

Run make. For example

cd build/build-c
cmake -DWITH_HTML:bool=ON -DWITH_PDF:bool=ON ../..
make

License

If there is no licence agreement with this package please download a version from the location above. You must read and accept that licence to use this software. The file is titled simply LICENSE.

The Original, Longer Version

What is it? It's a framework for unit testing, written in C. A tool for C developers writing tests of their own code.

If you have used JUnit, or any of the xUnit clones, you will find the concept familiar. In particular the tool supports a range of assertions, composable test suites and setup/teardown facilities. Because of the peculiarities of C programming, each test function is normally run in it's own process.

This project is very close in scope to the "Check" unit tester and was influenced by it... http://check.sourceforge.net/projects/check/

The main difference from this tool and other xUnit tools, such as "Check", is that test results are not stored. Instead they are streamed to the reporter psuedo-class, one that is easily overridden by the end user.

The other main extra feature is the support for writing mock callbacks. This includes generating sequences for return values or parameter expectations.

Feedback, queries and request should be put to the cgreen developers through https://github.com/cgreen-devs/cgreen.

This tool is basically a spin off from a research project at Wordtracker and would not have happened without the generous financial support of the Wordtracker keyword tool... http://www.wordtracker.com/

Substantial inital work by Marcus Baker marcus@lastcraft.com. Recent additions by Matt Hargett matt@use.net, Thomas Nilsson thomas@junovagen.se, João Freitas joaohf@gmail.com and others.

About

a modern, portable, cross-language unit testing and mocking framework for C and C++

Resources

License

LGPL-2.1, LGPL-2.1 licenses found

Licenses found

LGPL-2.1
LICENSE
LGPL-2.1
COPYING

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 73.8%
  • C++ 11.9%
  • CMake 11.3%
  • Makefile 1.1%
  • Perl 0.8%
  • Shell 0.7%
  • Other 0.4%