d85bf7be11
* [jenkins] Don't try to run the packaged Xamarin.Mac tests if none were built. (#9658) * [jenkins] State all the time where we're working on. (#8447) It's annoying to have to track it down all the time when something goes wrong. * [jenkins] Make it possible to skip running packaged Xamarin.Mac tests by setting the 'skip-packaged-xamarin-mac-tests' label. (#9170) Diff is best viewed by ignoring whitespace. * [jenkins] Don't try to run the packaged Xamarin.Mac tests if none were built. * [jenkins] Add support for specifying custom labels using a file. This is a partial backport of #8549. * [jenkins] Make it possible to skip running packaged Xamarin.Mac tests by setting the 'skip-packaged-xamarin-mac-tests' label. (#9170) Diff is best viewed by ignoring whitespace. * [jenkins] Don't try to run the packaged Xamarin.Mac tests if none were built. |
||
---|---|---|
.. | ||
.gitignore | ||
Jenkinsfile | ||
Makefile | ||
README.md | ||
add-commit-comment.sh | ||
add-commit-status.sh | ||
build-api-diff.sh | ||
build-nugets.sh | ||
build-package.sh | ||
build.sh | ||
compare.sh | ||
custom-labels.txt | ||
fetch-pr-labels.sh | ||
list-macos-platforms.csharp | ||
prepare-packaged-macos-tests.sh | ||
productsign.sh | ||
provision-deps.sh | ||
publish-results.sh | ||
publish-to-nuget.sh | ||
run-tests.sh | ||
utils.groovy | ||
vsts-device-tests-set-status.sh |
README.md
Jenkins
This directory contains all the scripts to be executed as steps in the jenkins build bots for each of the PR in the project. The expected order in which they have to be executed is as follows:
- provision-deps.sh : Downloads and installs the project dependencies.
- build.sh : Builds the project.
- run-tests.sh : Runs the tests.
- build-api-diff.sh : Builds the API diff.
Jenkinsfile
This file contains the logic to run on our internal Jenkins, available here: http://xamarin-jenkins/blue/organizations/jenkins/macios/activity
The Jenkins job is a multi-branch pipeline job, it will execute in the following conditions:
- For all branches in the xamarin org (not forks) that has a jenkins/Jenkinsfile file.
- For all pull requests from people with write access (also conditional on having a jenkins/Jenkinsfile file).
In very broad strokes, the Jenkins job will:
-
Checkout xamarin-macios
-
Build
-
Create packages, upload them to Azure and publish the links to the packages as GitHub statuses.
-
Run our test suite.
-
Run selected Xamarin.Mac tests on all macOS versions we support. This is done in parallel with the normal test run.
If a particular macOS version must be excluded temporarily from testing, search Jenkinsfile for
excludedOSes
and follow the instructions you'll find.