Skip to content

CDash integration

Matthias Diener edited this page Nov 9, 2019 · 39 revisions

Overview

CDash (https://cdash.org), from the same developers as CMake and CTest, is a potential alternative for our autobuild system (https://github.com/UIUC-PPL/autobuild). Some reasons for the switch are mentioned in issue #2571.

A proof-of-concept implementation is in PR #2587, with the build results shown on the hosted CDash dashboard: Charm++ CDash.

In contrast to autobuild, CDash works by pushing the results from regular (e.g. nightly) or occasional tests to the dashboard. These tests have to be started on the machine where they are intended to run, either manually or through cron.

CDash requires the CTest framework for submission of test results. The above patch works around that by wrapping our existing test system in CTest, creating 3 CTest tests, tests/, examples/, and benchmarks/. These tests can be regenerated with the cdash/generate_ctest.py script.

Running a build

The cdash/run_autobuild.sh script is a frontend to run a single test (manually or via cron). It clones, builds, and tests Charm++, and submits the results to the CDash dashboard.

To choose a build configuration (build name, branch to test, machine layer etc.), please modify the variables at the top of run_autobuild.sh. Before the above PR is merged, the tested branch needs to be cdash.

Manual tests

To run a manual test, you can use the following commands:

# Download autobuild script
$ wget https://raw.githubusercontent.com/UIUC-PPL/charm/cdash/cdash/run_autobuild.sh
$ chmod a+x run_autobuild.sh

# Set build options:
$ export AUTOBUILD_MACHINE_NAME="machineA" # default: hostname
$ export AUTOBUILD_BUILD_NAME="netlrts-darwin-x86_64" # default: netlrts-linux-x86_64
$ export AUTOBUILD_BRANCH="cdash" # needs to be cdash until PR is merged
$ export AUTOBUILD_BUILD_COMMAND="./build ..." # optional

# Run build
$ ./run_autobuild.sh

Nightly tests

To run a nightly autobuild on Quartz, the following crontab entry can be used (edit your crontab file with crontab -e):

LC_ALL=en_US.UTF-8
5 0 * * * AUTOBUILD_BUILD_NAME="netlrts-linux-x86_64 smp" srun -n 1 -c 8 ~/run_autobuild.sh > /dev/null 2>&1

This crontab entry runs a build at five minutes past midnight each day.

⚠️ Make sure to allocate a compute node in the crontab entry (srun in the above example)!