Instrumentation and code coverage

Introduction

In addition to the information provided by the assertions you add using the Antithesis SDKs, the Antithesis Platform benefits from two kinds of information about the software under test. These are:

  1. Coverage instrumentation, which tells the Platform which lines of code are reached over the course of testing. Having coverage callbacks at every basic block in the program’s control flow enables the Antithesis platform to test your program more effectively. In some languages, this is done by the native compiler. For others, Antithesis’s instrumentors add these callbacks, either to source files or to the compiled code.

  2. An assertion catalog that lists every assertion you add to your code. Remember that in any given execution history, Antithesis may not encounter every assertion you make. Since many types of assertions are supposed to fail if they’re never reached, Antithesis must be informed that that these assertions exist so it can mark them as failing when this happens. No additional code is being added to your software beyond the assertions themselves, but this does provide a vital source of information about your system’s behavior.

The way we do this is a little different for every language, but each way produces a common output formatting, enabling us to provide unified reporting across your entire architecture.

Some of our SDKs include an instrumentor package that facilitates this instrumentation and cataloging, and we provide some filtering capabilities that enable you to control which portions of your code the instrumentor acts on. Please read the relevant language support documentation for details.

Be aware that when you instrument your code, you may need to install additional runtime dependencies into your containers, but the benefits are well worth it.

Coverage instrumentation has a higher overhead than other SDK functions. We do not recommend running binaries with coverage instrumentation in production.

Benefits of instrumentation

  • Instrumentation allows us to support assertions that refer to specific lines of code or conditions in your code.
  • Instrumentation provides much richer data to the bug report, allowing us to automatically discover which lines of code were most and least associated with the bug.
  • Instrumentation enables a powerful fault-injection technique called thread pausing which is useful for finding subtle race conditions and other concurrency bugs.
  • Instrumentation sends continuous feedback to the Antithesis Platform which enables it to find bugs faster and more reliably.

Supported languages

The following is a list of languages that are supported for instrumentation and code coverage.

If your language is not on this list, it may still be possible to enable instrumentation. Contact us for more details.

Symbolization

Symbolization is the process of translating between locations in your compiled code and locations in your source files. For some languages, the Antithesis Platform handles all of this automatically. For other languages, you might need to compile with specific flags, or have your build/CI system put symbol files into a specific location in order for symbolization to work.

If your code includes coverage instrumentation (whether from an Antithesis instrumentor or the language compiler) Antithesis expects to find symbol files, so if it doesn’t find any, it will report a failing property in the triage report under the “No Antithesis session errors” group to remind you to add them.

Please consult the language-specific documentation for detailed instructions on enabling symbolization.

Symbols are placed in the image containing the instrumented software. Antithesis will search the root of every container image you push for a directory named /symbols and automatically extract any symbol files it finds there. When searching for symbol files, Antithesis will follow symlinks, so you can place a symlink in the /symbols directory instead of a symbol file, which you might want to do if, for instance, your symbols are normally part of the same binary as your code.

Validation

You can confirm that the instrumentation process worked correctly by looking at your triage report. Specifically, under the Setup property group, there is a default property called Software was instrumented. If this property is passing, then your code was instrumented successfully and we were able to symbolize it as well. Each example listed under this property is a different binary, program, or module that was successfully instrumented. The details section for the examples will list the name of the module and the number of locations within it that were instrumented.

  • Introduction
  • How Antithesis Works
  • Getting started
  • Package your software
  • Make it go
  • Deploy to Antithesis
  • Launch a test run
  • User manual
  • Properties and Assertions
  • Properties in Antithesis
  • Assertions in Antithesis
  • Properties to Test For
  • Sometimes Assertions
  • Test Composer
  • Test Composer Basics
  • Test Composer Reference
  • Principles of Test Composition
  • Checking Test Templates Locally
  • Webhooks
  • Launching a test
  • Retrieving logs
  • Launching a debugging session
  • Webhook API
  • Reports
  • Triage report
  • Bug report
  • Multiverse debugging
  • Overview
  • Exploring the multiverse
  • Querying with event sets
  • The Environment and its utilities
  • Using the Antithesis Notebook
  • Cookbook
  • The Environment and Multiverse
  • The Antithesis Environment
  • Fault Injection
  • CPUID
  • Reference
  • Handling External Dependencies
  • SDK reference
  • Go
  • Tutorial
  • Instrumentor
  • Assert (reference)
  • Lifecycle (reference)
  • Random (reference)
  • Java
  • Tutorial
  • Instrumentation
  • Assert (reference)
  • Lifecycle (reference)
  • Random (reference)
  • C
  • C++
  • Tutorial
  • C/C++ Instrumentation
  • Assert (reference)
  • Lifecycle (reference)
  • Random (reference)
  • JavaScript
  • Python
  • Tutorial
  • Assert (reference)
  • Lifecycle (reference)
  • Random (reference)
  • Rust
  • Tutorial
  • Instrumentation
  • Assert (reference)
  • Lifecycle (reference)
  • Random (reference)
  • .NET
  • Languages not listed above
  • Assert (reference)
  • Lifecycle (reference)
  • Tooling integrations
  • CI integration
  • Discord and Slack integrations
  • Configuring Antithesis
  • Instrumentation
  • User management
  • Sizing your deployment
  • Best practices
  • Is Antithesis working?
  • Optimizing for Antithesis
  • Finding more bugs
  • Release notes
  • Release notes