-
Notifications
You must be signed in to change notification settings - Fork 572
Policies | Safe Checkin Testing
In order to maintain the stability of Primary Tested packages and code on the 'develop' branch of Trilinos, the checkin-test.py script should always be used to test code before any push that changes source code. A standard environment for running the pre-push CI tests has been set up based on the SEMS Development Environment encapsulated in the script checkin-test-sems.sh. This script makes it easy to run on any machine that has the SEMS Dev Env mounted. To set up to use this script to test and push changes to Trilinos, do:
$ cd Trilinos/
$ mkdir CHECKIN/ # Or put this anywhere you want on Linux systems
$ cd CHECKIN
$ ln -s ../cmake/std/sems/checkin-test-sems.sh .
Then when one wants to test and push changes (and the local git repo is "clean" with no modified or untracked files), one can do:
$ cd Trilinos/CHECKIN/
$ ./checkin-test-sems.sh --do-all --push
(see default options in local-checkin-test-defaults.py). That will automatically figure out what packages are changed and will enable those packages and all of their downstream packages and BASIC tests. Then if everything passes, it will rebase the commits on top of origin/develop
, amend the top commit message with the test results summary, and push the commits (i.e. it implements the simple centralized workflow by default).
If one is nervous testing and pushing in one shot, then one can break this up into two commands with:
$ ./checkin-test-sems.sh --do-all
<manually inspect what packages got enabled and tested and make sure looks good>
$ ./checkin-test-sems.sh --push
(Using the checkin-test-sems.sh script to push is critical in order to mark known-tested commits to allow for robust usage of git bisect. Without this, git bisection is very hard to do with Trilinos. Also, local commits will be rebased by default, keeping a nice linear history on 'develop'.)
If one changes a given Trilinos package and one knows that it only impacts that one package (such as when only modifying tests but no changes to library code), then one can run the build and tests for only the directly modified packages with:
$ ./checkin-test-sems.sh --enable-all-packages=off --no-enable-fwd-packages --do-all --push
Also, one can test any set of packages <pkg0>
, <pkg1>
, etc. (and not downstream packages) with the local git repo in any arbitrary state (i.e. has modified or untracked files, is in a detached-head state, etc.) using:
$ ./checkin-test-sems.sh --enable-all-packages=off --enable-packages=<pkg0>,<pkg1>,...
--no-enable-fwd-packages --local-do-all
One can also run any individual step by replacing --do-all
and --local-do-all
with the action commands --pull
, --configure
, --build
, and/or --test
(the script keep memory of what steps have been performed already).
If the configure, build or any tests fail, then one can easily reproduce them just like for any regular build of Trilinos by sourcing the script load_ci_sems_dev_env.sh and doing the following (in an sh
compatible shell, not (t)csh):
$ cd Trilinos/CHECKIN/
$ source ../cmake/load_ci_sems_dev_env.sh # NOTE: Does 'module purge' then loads new env!
$ cd MPI_RELEASE_DEBUG_SHARED_PT/
$ ./do-configure # Reproduce configure failure
$ make -j<N> # Reproduce build failure
$ ctest -j<N> -R <test-name> # Reproduce failing test(s)
Many other use cases are also supported. Some detailed documentation on the checkin-test.py script can be obtained using checkin-test.py --help.
- After the first time
checkin-test-sems.sh
is run, optionally edit the filelocal-checkin-test-defaults.py
for your machine (see comments inside of the scriptcheckin-test-sems.sh
itself). - The
checkin-test-sems.sh
script, by default, runs a single build calledMPI_RELEASE_DEBUG_SHARED_PT
(see CMake options inMPI_RELEASE_DEBUG_SHARED_PT/do-configure.base
) with the env defined by the source script load_ci_sems_dev_env.sh. This is a build designed to best protect developers and users of Trilinos. This build allows the enable of any Primary Tested (PT) packages and enables several TPLs provided by the SEMS env (seeFinal set of enabled TPLs
inMPI_RELEASE_DEBUG_SHARED_PT/configure.out
). - The standard pre-push CI build is currently chosen to be the Sandia Linux RHEL 6 or 7 COE with the SEMS env. It is recommended to Trilinos from one of these machines, or ask someone else with access to one of these machines to push for your. (Please contact trilinos-framework at software.sandia.gov if you do not have access and time on one of these systems. Most Sandia staff can be given lab-support systems for this purpose.).
- One can do development on any machine with any env one wishes and then use a remote SNL Linux RHEL 6 machine with the SEMS env to do a remote pull, test, and push of the commits.
Copyright © Trilinos a Series of LF Projects, LLC
For web site terms of use, trademark policy and other project policies please see https://lfprojects.org.
Trilinos Developer Home
Trilinos Package Owners
Policies
New Developers
Trilinos PR/CR
Productivity++
Support Policy
Test Dashboard Policy
Testing Policy
Managing Issues
New Issue Quick Ref
Handling Stale Issues and Pull Requests
Release Notes
Software Quality Plan
Compiler Warnings/Errors
Proposing a New Package
Guidance on Copyrights and Licenses
Tools
CMake
Doxygen
git
GitHub Notifications
Mail lists
Clang-format
Version Control
Initial git setup
'feature'/'develop'/'master' (cheatsheet)
Simple centralized workflow
Building
SEMS Dev Env
Mac OS X
ATDM Platforms
Containers
Development Tips
Automated Workflows
Testing
Test Harness
Pull Request Testing
Submitting a Pull Request
Pull Request Workflow
Reproducing PR Errors
Addressing Test Failures
Trilinos Status Table Archive
Pre-push (Checkin) Testing
Remote pull/test/push
PR Creation & Approval Guidelines for Tpetra, Ifpack2, and MueLu Developers