Skip to content

Latest commit

 

History

History
95 lines (73 loc) · 2.37 KB

README.rst

File metadata and controls

95 lines (73 loc) · 2.37 KB

Boost.Build Toolset Tester

The project contains a Boost.Build project intended to test a Boost.Build toolset. To do this, it attempts to build components of C and C++ programs (libraries, programs, object files, etc.) in all the ways that a toolset must to satisfy the Boost.Build architecture.

It is intended to be useful for bare metal cross-compilers as well as normal toolsets.

Overview

Running the following command will run all tests against each compiler known. Note that using the --test-config option ensures that the user's configuration does not interfere with the testing and the --hash option keeps the paths to reasonable lengths with the large number of properties generated for this project.

$ b2 --test-config=user-config.jam --hash

By default, this tests almost all combination of the standard features. These features are defined in Boost.Build and a non-normative list is given below. The list of options tested can be found in the logic within the Jamroot.

  • link
  • runtime-link (disabled)
  • runtime-debugging (disabled)
  • optimization
  • profiling
  • inlining
  • threading
  • rtti
  • exception-handling
  • asynch-exceptions (disabled)
  • extern-c-nothrow (disabled)
  • debug-symbols
  • strip
  • define
  • undef
  • include
  • warnings
  • warnings-as-errors

This is a lot of tests. To limit the scale of the tests, add properties for features to the command line to limit the tests to only that value of the given property.

For example, to limit to only building for a single toolset, run the following command.

$ b2 --test-config=user-config.jam \
    --hash \
    toolset=gcc

To limit further to only include static linking, run the following command.

$ b2 --test-config=user-config.jam \
    --hash \
    toolset=gcc \
    link=static

To limit further to only test for single-threaded programs, run the following command.

$ b2 --test-config=user-config.jam \
    --hash \
    toolset=gcc \
    link=static \
    threading=single

Requirements

  • Boost.Build
  • All desired compilers

Adding Toolsets

To add a cross-compiler to the test suite, configure the toolset in project-config.jam and add it to the toolsets variable, ensuring that the toolset is only configured for platforms that actually have it.