2015-04-27 05:23:50 +08:00
# Contributing to Jenkins
2017-10-04 18:19:20 +08:00
2017-10-05 04:54:01 +08:00
This page provides information about contributing code to the Jenkins core codebase.
2017-10-04 18:19:20 +08:00
2018-09-15 01:25:16 +08:00
:exclamation: There's a lot more to the Jenkins project than just code. For information on contributing to the Jenkins project overall, check out [Participate].
2017-10-04 18:19:20 +08:00
## Getting started
1. Fork the repository on GitHub
2. Clone the forked repository to your machine
2017-10-05 04:54:01 +08:00
3. Install the development tools. In order to develop Jenkins, you need the following tools:
* Java Development Kit (JDK) 8.
2018-09-15 01:25:16 +08:00
- In Jenkins project we usually use [OpenJDK],
2017-10-04 18:19:20 +08:00
but you can use other JDKs as well.
2018-09-15 01:25:16 +08:00
- Java 9+ is **not supported** in Jenkins.
* Maven 3.5.3 or above. You can [download maven].
* Any IDE which supports importing Maven projects.
4. Setup your development environment as described in [Preparing for Plugin Development]
2017-10-04 18:19:20 +08:00
2017-10-05 04:54:01 +08:00
If you want to contribute to Jenkins or just learn about the project,
you can start by fixing some easier issues.
In the Jenkins issue tracker we mark such issues as `newbie-friendly` .
You can find them
2018-09-15 01:25:16 +08:00
using this query for [newbie friendly issues].
2017-10-04 18:19:20 +08:00
## Building and Debugging
2017-10-05 04:54:01 +08:00
The build flow for Jenkins core is built around Maven.
2018-09-15 01:25:16 +08:00
There is a description of the [building and debugging process].
2017-10-04 18:19:20 +08:00
If you want simply to have the `jenkins.war` file as fast as possible without tests, run:
2018-07-17 07:36:06 +08:00
mvn clean package -pl war -am -DskipTests -Dfindbugs.skip
2017-10-04 18:19:20 +08:00
2017-10-05 04:54:01 +08:00
The WAR file will be created in `war/target/jenkins.war` .
2018-09-15 01:25:16 +08:00
After that you can start Jenkins using Java CLI ([guide]).
2017-10-04 18:19:20 +08:00
If you want to debug this WAR file without using Maven plugins,
2018-09-15 01:25:16 +08:00
You can just start the executable with [Remote Debug Flags]
2017-10-04 18:19:20 +08:00
and then attach IDE Debugger to it.
## Testing changes
2017-10-05 04:54:01 +08:00
Jenkins core includes unit and functional tests as a part of the repository.
2017-10-04 18:19:20 +08:00
Functional tests (`test` module) take a while even on server-grade machines.
2017-10-05 04:54:01 +08:00
Most of the tests will be launched by the continuous integration instance,
2017-10-04 18:19:20 +08:00
so there is no strict need to run full test suites before proposing a pull request.
2018-10-06 21:01:00 +08:00
There are 3 profiles for tests:
* `light-test` - only unit tests, no functional tests
* `smoke-test` - run unit tests + a number of functional tests
* `all-tests` - Runs all tests, with re-run (default)
2017-10-05 04:54:01 +08:00
In addition to the included tests, you can also find extra integration and UI
2018-09-15 01:25:16 +08:00
tests in the [Acceptance Test Harness (ATH)] repository.
2017-10-05 04:54:01 +08:00
If you propose complex UI changes, you should create new ATH tests for them.
2017-10-04 18:19:20 +08:00
## Proposing Changes
2018-10-27 04:56:06 +08:00
The Jenkins project source code repositories are hosted at GitHub.
2017-10-05 04:54:01 +08:00
All proposed changes are submitted and code reviewed using the _GitHub Pull Request_ process.
To submit a pull request:
2017-10-04 18:19:20 +08:00
2017-10-05 04:54:01 +08:00
1. Commit changes and push them to your fork on GitHub.
2017-10-04 18:19:20 +08:00
It is a good practice is to create branches instead of pushing to master.
2. In GitHub Web UI click the _New Pull Request_ button
3. Select `jenkinsci` as _base fork_ and `master` as `base` , then click _Create Pull Request_
* We integrate all changes into the master branch towards the Weekly releases
* After that the changes may be backported to the current LTS baseline by the LTS Team.
2018-09-15 01:25:16 +08:00
Read more about the [backporting process]
4. Fill in the Pull Request description according to the [proposed template].
2017-10-04 18:19:20 +08:00
5. Click _Create Pull Request_
6. Wait for CI results/reviews, process the feedback.
* If you do not get feedback after 3 days, feel free to ping `@jenkinsci/code-reviewers` to CC.
* Usually we merge pull requests after 2 votes from reviewers or after 1 vote and 1-week delay without extra reviews.
2017-10-05 04:54:01 +08:00
Once your Pull Request is ready to be merged,
the repository maintainers will integrate it, prepare changelogs and
2017-10-04 18:19:20 +08:00
ensure it gets released in one of incoming Weekly releases.
2017-10-17 04:42:23 +08:00
There is no additional action required from pull request authors at this point.
2017-10-04 18:19:20 +08:00
2017-10-04 18:31:46 +08:00
## Copyright
2018-09-15 01:25:16 +08:00
Jenkins core is licensed under [MIT license], with a few exceptions in bundled classes.
2017-10-04 19:59:07 +08:00
We consider all contributions as MIT unless it's explicitly stated otherwise.
MIT-incompatible code contributions will be rejected.
2017-10-05 04:54:01 +08:00
Contributions under MIT-compatible licenses may be also rejected if they are not ultimately necessary.
2017-10-04 18:31:46 +08:00
2018-09-15 01:25:16 +08:00
We **Do NOT** require pull request submitters to sign the [contributor agreement]
2017-10-05 04:54:01 +08:00
as long as the code is licensed under MIT and merged by one of the contributors with the signed agreement.
2017-10-04 18:31:46 +08:00
2017-10-17 04:42:23 +08:00
We still encourage people to sign the contributor agreement if they intend to submit more than a few pull requests.
2017-10-05 04:54:01 +08:00
Signing is also a mandatory prerequisite for getting merge/push permissions to core repositories
2018-09-15 01:25:16 +08:00
and for joining teams like [Jenkins Security Team].
2017-10-04 18:31:46 +08:00
2017-10-04 18:19:20 +08:00
## Continuous Integration
2017-10-05 04:54:01 +08:00
The Jenkins project has a Continuous Integration server... powered by Jenkins, of course.
2018-09-15 01:25:16 +08:00
It is located at [ci.jenkins.io].
2017-10-04 18:19:20 +08:00
2018-09-15 01:25:16 +08:00
The Jenkins project uses [Jenkins Pipeline] to run builds.
The code for the core build flow is stored in the [Jenkinsfile] in the repository root.
2017-10-05 04:54:01 +08:00
If you want to update that build flow (e.g. "add more checks"),
just submit a pull request.
2015-04-27 05:23:50 +08:00
2017-10-04 18:31:46 +08:00
# Links
2017-10-17 04:42:23 +08:00
* [Jenkins Contribution Landing Page ](https://jenkins.io/participate/ )
* [Jenkins IRC Channel ](https://jenkins.io/chat/ )
2017-10-04 18:31:46 +08:00
* [Beginners Guide To Contributing ](https://wiki.jenkins.io/display/JENKINS/Beginners+Guide+to+Contributing )
* [List of newbie-friendly issues in the core ](https://issues.jenkins-ci.org/issues/?jql=project%20%3D%20JENKINS%20AND%20status%20in%20(Open%2C%20%22In%20Progress%22%2C%20Reopened )%20AND%20component%20%3D%20core%20AND%20labels%20in%20(newbie-friendly))
2018-09-15 01:25:16 +08:00
[download maven]: https://maven.apache.org/download.cgi
[Preparing for Plugin Development]: https://jenkins.io/doc/developer/tutorial/prepare/
[newbie friendly issues]: https://issues.jenkins-ci.org/issues/?jql=project%20%3D%20JENKINS%20AND%20status%20in%20(Open%2C%20%22In%20Progress%22%2C%20Reopened)%20AND%20component%20%3D%20core%20AND%20labels%20in%20(newbie-friendly)
[OpenJDK]: http://openjdk.java.net/
[Participate]: https://jenkins.io/participate/
[building and debugging process]: https://jenkins.io/doc/developer/building/
[guide]: https://wiki.jenkins.io/display/JENKINS/Starting+and+Accessing+Jenkins
[Remote Debug Flags]: https://stackoverflow.com/questions/975271/remote-debugging-a-java-application
[Acceptance Test Harness (ATH)]: https://github.com/jenkinsci/acceptance-test-harness
[backporting process]: https://jenkins.io/download/lts/
[proposed template]: .github/PULL_REQUEST_TEMPLATE.md
[MIT license]: ./LICENSE.txt
[contributor agreement]: https://wiki.jenkins.io/display/JENKINS/Copyright+on+source+code
[Jenkins Security Team]: https://jenkins.io/security/#team
[ci.jenkins.io]: https://ci.jenkins.io/
[Jenkins Pipeline]: https://jenkins.io/doc/book/pipeline/
[Jenkinsfile]: ./Jenkinsfile