Curl runs in many different environments, so every change is run against a large number of test suites.
Every pull request is verified for each of the following:
If the pull-request fails one of these tests, it will show up as a red X and you are expected to fix the problem. If you do not understand when the issue is or have other problems to fix the complaint, just ask and other project members will likely be able to help out.
Consider the following table while looking at pull request failures:
| CI platform as shown in PR | State | What to look at next | | ----------------------------------- | ------ | -------------------------- | | CI / codeql | stable | quality check results | | CI / fuzzing | stable | fuzzing results | | CI / macos ... | stable | all errors and failures | | Code scanning results / CodeQL | stable | quality check results | | FreeBSD FreeBSD: ... | stable | all errors and failures | | LGTM analysis: Python | stable | new findings | | LGTM analysis: C/C++ | stable | new findings | | buildbot/curlwinssl ... | stable | all errors and failures | | continuous-integration/appveyor/pr | stable | all errors and failures | | curl.curl (linux ...) | stable | all errors and failures | | curl.curl (windows ...) | flaky | repetitive errors/failures | | deepcode-ci-bot | stable | new findings | | musedev | stable | new findings |
Sometimes the tests fail due to a dependency service temporarily being offline or otherwise unavailable, eg. package downloads. In this case you can just try to update your pull requests to rerun the tests later as described below.
Here are the different CI environments that are currently in use, and how they are configured:
Github Actions runs the following tests:
These are each configured in different files in .github/workflows
.
The following tests are run in Microsoft Azure CI environment:
These are all configured in .azure-pipelines.yml
.
As of November 2021 @bagder and @mback2k are the only people with administrator access to the Azure CI environment. Additional admins/group members can be added on request.
Appveyor runs a variety of different Windows builds, with different compilation options.
As of November 2021 @bagder, @mback2k, @jay, @vszakats, @dfandrich and @danielgustafsson have administrator access to the Appveyor CI environment. Additional admins/group members can be added on request.
The tests are configured in appveyor.yml.
Zuul is an open source CI tool. A number of Curl tests are run at curl.zuul.vexxhost.dev:
make checksrc
).As of November 2021, the tests run (sometimes) but do not run consistently and do not report results to the Github checks runner - you need to manually check for failures. See #7522 for more information.
As of November 2021 Daniel Stenberg is the only person with administrator access to the Zuul CI environment.
These are configured in zuul.d
and have test runners in scripts/zuul
.
CircleCI runs a basic Linux test suite on Ubuntu for both x86 and ARM
processors. This is configured in .circleci/config.yml
.
You can view the full list of CI jobs on CircleCI's website.
@bagder has access to edit the "Project Settings" on that page. Additional admins/group members can be added on request.
Cirrus CI runs a basic test suite on FreeBSD and Windows. This is configured in
.cirrus.yml
.
You can view the full list of CI jobs on Cirrus CI's website.
@bagder has access to edit the "Project Settings" on that page. Additional admins/group members can be added on request.