-
-
Notifications
You must be signed in to change notification settings - Fork 371
Testing: Continuous Integration
http://d1m1s1b1.stat.columbia.edu:8080
The server is a desktop computer running Windows 7. It has an Intel Core i7 920 @ 2.67 GHz processor with 8 GB of RAM. It is located in Daniel, Bob, and Sophie's office at Columbia University.
We use Jenkins as our continuous integration server.
Daniel is currently maintaining the server.
We use our continuous integration server to assist our development process. Here are some of our goals for our continuous integration:
- Maintaining the state of the
develop
branch. We test thedevelop
branch on every merged pull request. If a merge ends up breaking the build, we are able to detect it rather quickly. - Verifying pull requests. Before pull requests are merged into the
develop
branch, Jenkins is used to verify that the tests pass. - Cross platform testing. Most of the developers are on Mac or Linux machines. Running the server in Windows catches some of the cross platform issues. Ideally, we would set up Jenkins slave processes on each of our target platforms, but we currently do not have that set up.
For additional information on continuous integration, see the Wikipedia entry.
Here are the current Jenkins projects:
Stan Develop Branch. These projects test the current state of the develop
branch.
-
This project verifies that the C++ API documentation can be built and tracks Doxygen warnings.
Build target make doxygen
Frequency daily, when changes are made to the develop
branchArtifacts current API doc -
This project verifies that the manual can be built.
Build target make manual
Frequency daily, when changes are made to the develop
branchArtifacts draft version of the manual -
This project executes and tracks the unit tests and tracks compiler warnings. On success, calls the Header Tests.
Build target make test-unit O=0 -j4
Frequency every push to develop
and dailyArtifacts none -
This project executes the header tests and tracks compiler warnings. On success, calls the Distribution Tests.
Build target make test-headers -j4 O=0
Frequency called when Unit Tests reports success Artifacts none -
[Distribution Tests](http://d1m1s1b1.stat.columbia.edu:8080/view/Stan Develop Branch/job/Stan Distribution Tests):
This project executes and tracks the distribution tests and tracks compiler warnings.
Build target make test-distributions -j4 O=0
Frequency called when Header Tests reports success Artifacts none -
This project executes and tracks the model tests and tracks compiler warnings. These tests are currently used as an integration test that will indicate whether Stan is completely broken.
Build target make test-models
Frequency daily Artifacts time to execute each model is recorded. The files can be found here: timing files
Stan Pull Requests. These projects test incoming pull requests before they are merged into develop
.
-
Stan GitHub Pull Requests Project:
This project tests pull requests. See the Testing Pull Requests through Jenkins section for more information. The workspace starts with a current copy of
develop
, merges the pull request, then runs the suite of tests. Compiler warnings are tracked.Build target make manual doxygen && make test-unit test-headers test-distributions test-models -j2 O=3
Frequency see Testing Pull Requests through Jenkins Artifacts none
rstan. These projects test the current state of the rstan
repository.
-
This project tests pull requests. See the Testing Pull Requests through Jenkins section for more information. The workspace starts with a current copy of
develop
, merges the pull request, then runs the suite of tests. Compiler warnings are tracked.Build target git submodule update
cd stan
git fetch
git checkout origin/develop
cd ..
git submodule status
R -q -e "library(Rcpp); sessionInfo()"
cd rstan
make clean
make check && (cd tests & R -q -f runRunitTests.R --args ../rstan.Rcheck)
Frequency daily Artifacts none
Miscellaneous projects. These are utility projects.
-
This project pushes the website from branch
master
to http://mc-stan.orgBuild target N/A Frequency on demand Artifacts none
- We use our continuous integration server to test pull requests prior to merging into our
develop
branch. The plugin documentation is sparse. We describe how we use the plugin. - The Stan GitHub Pull Requests project is controlled through comments on the pull request.
- We created a GitHub user called
stan-buildbot
. This is how Jenkins communicates through comments. - We maintain a list of admins and whitelisted GitHub users on Jenkins.
- A whitelisted contributor creates a pull request.
- Jenkins automatically places the pull request on the testing queue.
- After the pull request is tested,
stan-buildbot
posts the status of the build as a comment. - An admin can retest the pull request by posting a comment.
- A contributor creates a pull request.
- Jenkins recognizes the pull request.
stan-buildbot
posts a comment on the pull request requesting verification from an admin. - An admin places the pull request on the testing queue.
- After the pull request is tested,
stan-buildbot
posts the status of the build as a comment. - An admin can retest the pull request by posting a comment.
All contributors need to create a GitHub pull request from their feature branch to the stan-dev:stan:develop
branch. This is done through GitHub.
When Jenkins recognizes the pull request, the stan-buildbot
GitHub user will respond to the pull request with:
Can one of the admins verify this patch?
Jenkins is now waiting for an admin to approve the pull request for testing. An admin can do this by commenting on the GitHub pull request with:
Jenkins, ok to test.
Jenkins will then place the pull request in the queue for testing.
Jenkins will merge the pull request into a clean develop
branch. The pull request needs to be able to be merged automatically.
After running the tests, stan-buildbot
will comment on the pull request with either:
Test PASSed.
Refer to this link for build results: http://d1m1s1b1.stat.columbia.edu:8080/job/Stan%20Github%20Pull%20Requests/###/
or
Test FAILed.
Refer to this link for build results: http://d1m1s1b1.stat.columbia.edu:8080/job/Stan%20Github%20Pull%20Requests/###/
If the tests pass and the pull request passes a code review, one of the developers should merge the pull request. After the pull request is merged, this will kick off another round of tests.
An admin may want to retest the pull request. A couple common reasons would include:
- Updated pull request.
- Updated
develop
branch.
To retest the pull request, an admin can comment:
Jenkins, retest this please.
The pull request will be placed back on the testing queue. Jenkins will respond with a comment indicating pass or fail as above.
Every subsequent push to the originating feature branch will put the pull request on the testing queue. This happens for every push, tagged with the commit. If the feature branch is still active, this could result in the same pull request being tested multiple times holding up other pull requests from being tested.
- Admins:
- bob-carpenter
- syclik
- Whitelist:
- all admins are automatically whitelisted
- Default messages (these can be reconfigured):
- Request for testing phrase:
Can one of the admins verify this patch?
- Success:
Test PASSed
. - Failure:
Test FAILed
.
- Request for testing phrase:
If you would like to be added to either the whitelist or admin list, please get in touch with Daniel.
-
Accept to test phrase:
Jenkins will comment:
Can one of the admins verify this patch?
An admin can accept the pull request with:
Jenkins, ok to test.
The acceptance regex:
.*ok\W+to\W+test.*
-
Test phrase:
To retest the pull request, an admin can comment:
Jenkins, retest this please.
The test regex:
.*test\W+this\W+please.*
Although an admin can just type
test this please
, it could be misinterpreted as an imperative statement directed to the creator of the pull request. -
Add to whitelist:
To add the contributor to the whitelist, an admin can either manage the whitelisted users through Jenkins or respond with:
Jenkins, add to whitelist.
The add to whitelist regex:
.*add\W+to\W+whitelist.*