Getting Started 🔗

Welcome to the online documentation for the Audition testing framework. Offline documentation is available for Linux users via the Audition man page which you can access by typing man audition in your shell after installing Audition.

Audition is a modern xUnit testing framework for C11 and beyond. It provides numerous quality-of-life improvements over other C unit testing frameworks, including automatic test registration and generic assertion macros. Additionally, Audition features a robust mocking system and a sandbox mode for running tests in an isolated address space.

Before you begin using Audition you must first install it. The remainder of this page will guide you through the installation processes. Once you’ve installed Audition you’re ready to learn the basics.

Supported Platforms and Compilers 🔗

Audition is tested on real hardware running Windows, Linux, Apple Silicon, and emulation via QEMU and Virtual Box. It has been tested in the following environments:

Architecture Environment Compilers
AArch32 Linux 5.15 GCC 11
AArch64 Linux 5.15 GCC 11
AArch64 macOS 13.6 Clang 14
AArch64 macOS 15.1 Clang 14
MIPS Linux 5.15 GCC 11
MIPS 64 Linux 5.15 GCC 11
RISC-V 32 Linux 5.15 GCC 11
RISC-V 64 Linux 5.15 GCC 11
x86 Linux 5.15 Clang 12, GCC 11
x86 Windows 10 MSVC 2019, Clang-CL 14
x86 Windows 10 MSVC 2022
AMD64 FreeBSD 13.1 Clang 13
AMD64 Ubuntu 22.04 LTS Clang 14, GCC 11
AMD64 Ubuntu 24.04 LTS GCC 13
AMD64 Fedora 40 GCC 14
AMD64 Fedora 41 GCC 14
AMD64 NetBSD 9.3 GCC 7.5
AMD64 Windows 10 MSVC 2019, Clang-CL 14
AMD64 Windows 10 MSVC 2022
AMD64 Windows 10 MinGW GCC 11, Clang 14

The binary releases of Audition are limited to Windows, macOS, the latest long-term support releases of Ubuntu, and the maintained releases of Fedora Workstation. To build for other operating systems and architectures, you must license the Audition source code.

Installing Audition 🔗

The section will guide you through the installation of Audition on your system and its configuration with your C environment

Once Audition is installed you can integrate it with your C project by following the Discovering Audition guide.

Installing Audition On Windows 🔗

The simplest way to install Audition on Windows is to use the .msi installer available from the downloads page. The installer does not require administrative privileges. By default, it will place Audition in the %LOCALAPPDATA% directory.

After installing Audition, you can discover it with CMake or pass the appropriate flags to your C compiler to discover the library and header.

You can also download Audition for Windows as an archive (i.e. a zip file) which includes the Audition library and header.

Installing Audition On macOS 🔗

To install Audition on macOS, first download the latest .dmg from the downloads page, double click the disk image to mount it, then drag-and-drop Audition.framework into your Frameworks folder.

You can now discover Audition.framework from Xcode just as you would any other framework. You can also discover Audition with CMake.

Installing Audition On Linux 🔗

The binary release of Audition is available for both Ubuntu LTS and Fedora Workstations.

To install Audition on your Linux system, download and install the deb (Ubuntu users) or rpm (Fedora users) from the downloads page.

Audition is built as a generic Linux binary and links against glibc which Ubuntu and Fedora both use. If you need to link against a different version of libc or you need to use Audition on a different Linux distribution, then you must build it from source. You can obtain its source code by purchasing a business license.

Discovering Audition 🔗

This section outlines the various ways Audition can be discovered and integrated with your projects after being installed on your computer.

Discovering Audition with CMake 🔗

The easiest way to discover Audition with CMake is to install Audition using an installer program (i.e. msi, deb, rpm, dmg) and then use find_package to find it. If you’ve downloaded Audition via an archive (i.e. a zip file), then find_package will not work and you must manually configure it with CMake using find_library and friends.

find_package(Audition REQUIRED)

Assuming you did find Audition with find_package, you can then use the AUDITION_INCLUDE_DIR and AUDITION_LIBRARY variables to refer to the Audition library and header directory.

include_directories(${AUDITION_INCLUDE_DIR})
link_libraries(${AUDITION_LIBRARY})

One “gotcha” to watch out for is that Audition requires C11 and Visual Studio, at the time of this writing, defaults to C89. You must change the version of the C standard MSVC uses by setting the CMAKE_C_STANDARD variable in your CMakeLists.txt as shown below:

set(CMAKE_C_STANDARD 11)

You can review a complete example in the Audition examples CMakeLists.txt.

Discovering Audition with Meson 🔗

On systems with pkg-config, Meson should find Audition with the dependency function.

audition = dependency('audition')

On systems with CMake, Meson should find Audition through CMake's find_package function.

audition = dependency('Audition')

Discovering Audition with pkg-config 🔗

If you’re on Linux and have pkg-config installed, you can execute the following command in your terminal to discover the Audition library and header.

$ pkg-config audition --cflags --libs

You can run this command from your build system of choice (e.g. your Makefile, Autotools, etc.) to discover Audition.

Discovering Audition with Visual Studio 🔗

This section explores how to manually setup Audition with your Visual Studio project. If you generated your Visual Studio project with CMake, then you can disregard this section because CMake configures it for you.

To configure Audition with your Visual Studio project, start by opening the property page of your test runner project. Once opened, navigate to Configuration Properties 🠞 General 🠞 C Language Standard and set the C standard to C11 or newer. This is necessary because Visual Studio defaults to C89, but Audition requires C11 or newer.

Next, under Configuration Properties 🠞 C/C++ 🠞 General add to the Additional Include Directories the path where the Audition header file resides. If you installed Audition to its default directory with the Windows installer, then set this property to:

$(LOCALAPPDATA)\Programs\Audition

If you downloaded Audition as a zip file, then set the property to the location you extracted the audition.h header file.

Next, under Configuration Properties 🠞 Linker 🠞 Input, add to the Additional Dependencies property the path to the audition.lib file. If you installed Audition to its default directory with the Windows installer, then set this property to:

$(LOCALAPPDATA)\Programs\Audition\audition.lib

If you downloaded Audition as a zip file, then you must set the property to the location of the audition.lib file.

Lastly, if you downloaded Audition as a zip, you need to copy the Audition.dll to the location of your test runner executable or add it the directory in which it resides to your PATH variable. This step isn’t necessary if you installed Audition with the Windows installer.

Discovering Audition with Xcode 🔗

This section explores how to manually configure Audition with your Xcode project. If you generated your Xcode project with CMake, then you can disregard this section because CMake configures it for you.

Firstly, you must ensure your test runner target is configured as a command line program. So if you’re creating a new project (or target) be sure you create it as a Command Line Tool.

Once you have your target created, you must link it with the Audition.framework. You can link it by clicking the “plus” icon under General 🠞 Frameworks and Libraries and then searching for “Audition” in the frameworks search box. If you cannot find Audition in the list, then you can add it manually by clicking Add Other... 🠞 Add Files... or by dragging Audition.framework into the Xcode user interface.

This guide assumes you’ll add Audition as a reference rather than copying it into the project. Also, be sure that the Embed column has Do Not Embed selected.

Now that the Audition framework is linked, you must ensure your test runner executable can find the framework at runtime. If you fail to perform this step, you will receive a runtime error:

Library not loaded: @rpath/Audition.framework/Versions/A/Audition

To ensure Audition is discoverable at runtime, you must set the Build Settings 🠞 Runpath Search Paths and Framework Search Paths to the directory where Audition.framework is located. If you installed the Audition framework by dragging it into the “Frameworks” directory, as instructed by the DMG, then it will be located in “/Library/Frameworks”.

You’re now ready to use Audition on macOS! However, there is one “gotcha” and that is you will need to include the audition.h header file in a way that’s different from other platforms: On macOS framework headers are referenced by specifying the frameworks name first as a directory, then the header like so:

#include <Audition/audition.h>

Right now, this is how you need to include the Audition header file. If you want to include the Audition header directly as

#include "audition.h"

which is how it’s included on non-macOS platforms, then you must update the Build Settings 🠞 Header Search Path option to reference the Audition header directory.