2017-12-04 15:09:52 +02:00
|
|
|
[![Build Status](https://travis-ci.org/SAP/jenkins-library.svg?branch=master)](https://travis-ci.org/SAP/jenkins-library)
|
2018-06-27 15:06:52 +02:00
|
|
|
[![Coverage Status](https://coveralls.io/repos/github/SAP/jenkins-library/badge.svg?branch=master)](https://coveralls.io/github/SAP/jenkins-library?branch=master)
|
2018-11-06 15:23:52 +02:00
|
|
|
[![Maintainability](https://api.codeclimate.com/v1/badges/0e6a23344616e29b4ed0/maintainability)](https://codeclimate.com/github/SAP/jenkins-library/maintainability)
|
|
|
|
[![Test Coverage](https://api.codeclimate.com/v1/badges/0e6a23344616e29b4ed0/test_coverage)](https://codeclimate.com/github/SAP/jenkins-library/test_coverage)
|
2017-12-04 15:09:52 +02:00
|
|
|
|
2017-11-16 13:55:23 +02:00
|
|
|
# Description
|
2017-07-11 15:12:03 +02:00
|
|
|
|
2017-11-16 13:55:23 +02:00
|
|
|
An efficient software development process is vital for success in building
|
|
|
|
business applications on SAP Cloud Platform or SAP on-premise platforms. SAP
|
|
|
|
addresses this need for efficiency with project "Piper". The goal of project
|
|
|
|
"Piper" is to substantially ease setting up continuous deployment processes for
|
|
|
|
the most important SAP technologies by means of Jenkins pipelines.
|
2017-07-11 15:12:03 +02:00
|
|
|
|
|
|
|
Project "Piper" consists of two parts:
|
|
|
|
|
2018-11-06 14:50:09 +02:00
|
|
|
* [A shared library][piper-library] containing steps and utilities that are
|
|
|
|
required by Jenkins pipelines.
|
|
|
|
* A set of [Jenkins pipelines][piper-pipelines] using the piper library to
|
|
|
|
implement best practice processes.
|
2017-07-11 15:12:03 +02:00
|
|
|
|
2017-11-16 13:55:23 +02:00
|
|
|
Please follow [this link to our extended library documentation][piper-library-pages].
|
2017-07-11 15:12:03 +02:00
|
|
|
|
2017-11-16 13:55:23 +02:00
|
|
|
## What you get
|
|
|
|
|
|
|
|
The shared library contains all the necessary steps to run our best practice
|
|
|
|
[Jenkins pipelines][piper-pipelines].
|
|
|
|
|
|
|
|
The best practice pipelines are based on the general concepts of [Jenkins 2.0
|
|
|
|
Pipelines as Code][jenkins-doc-pipelines]. With that you have the power of the
|
|
|
|
Jenkins community at hand to optimize your pipelines.
|
|
|
|
|
|
|
|
You can run the best practice Jenkins pipelines out of the box, take them as a
|
|
|
|
starting point for project-specific adaptations or implement your own pipelines
|
|
|
|
from scratch using the shared library.
|
|
|
|
|
|
|
|
## Extensibility
|
|
|
|
|
|
|
|
If you consider adding additional capabilities to your `Jenkinsfile`, consult
|
|
|
|
the [Jenkins Pipeline Steps Reference][jenkins-doc-steps]. There, you get an
|
|
|
|
overview about steps that are natively supported by Jenkins.
|
|
|
|
|
|
|
|
The [Jenkins shared libraries][jenkins-doc-libraries] concept helps you to
|
|
|
|
extract reusable parts from your pipeline and to keep your pipeline code small
|
|
|
|
and easy to maintain.
|
|
|
|
|
|
|
|
Custom library steps can be added using a custom library according to the
|
|
|
|
[Jenkins shared libraries][jenkins-doc-libraries] concept instead of adding
|
|
|
|
groovy coding to the `Jenkinsfile`. Your custom library can coexist next to the
|
|
|
|
provided pipeline library.
|
|
|
|
|
2018-03-06 10:59:58 +02:00
|
|
|
## API
|
|
|
|
|
2019-01-23 12:23:03 +02:00
|
|
|
All steps (`vars` and `resources` directory) are intended to be used by Pipelines and are considered API.
|
2019-01-08 18:35:53 +02:00
|
|
|
All the classes / groovy-scripts contained in the `src` folder are by default not part of
|
|
|
|
the API and are subjected to change without prior notice. Types and methods annotated with
|
|
|
|
`@API` are considered to be API, used e.g. from other shared libraries. Changes to those
|
|
|
|
methods/types needs to be announced, discussed and agreed.
|
2018-03-06 10:59:58 +02:00
|
|
|
|
2017-11-16 13:55:23 +02:00
|
|
|
# Requirements
|
|
|
|
|
2018-11-06 14:50:09 +02:00
|
|
|
* Java Runtime Environment 8
|
|
|
|
* Installation of Jenkins v 2.60.3 or higher running on Linux. We tested with
|
|
|
|
debian-stretch.
|
|
|
|
* Jenkins Plugins installed as described in the [Required
|
|
|
|
Plugin][piper-library-pages-plugins] section.
|
|
|
|
* A Jenkins user with administration privileges.
|
|
|
|
* The Jenkins instance has access to [github.com][github].
|
2017-11-16 13:55:23 +02:00
|
|
|
|
|
|
|
# Download and Installation
|
|
|
|
|
|
|
|
To setup the shared library, you need to perform the following steps:
|
|
|
|
|
|
|
|
1. Login to your Jenkins instance with administration privileges.
|
|
|
|
1. Open the system configuration page (*Manage Jenkins > Configure System*).
|
|
|
|
1. Scroll down to section *Global Pipeline Libraries* and add a new Library by
|
|
|
|
clicking the *Add* button.
|
2018-12-05 14:37:15 +02:00
|
|
|
1. set *Library Name* to `piper-lib-os`
|
2017-11-16 13:55:23 +02:00
|
|
|
1. set *Default Version* to the branch or tag you want to consume (e.g.
|
|
|
|
`master` or `v0.1`)
|
|
|
|
1. set *Retrieval Method* to `Modern SCM`
|
|
|
|
1. set *Source Code Management* to `Git`
|
|
|
|
1. set *Project Repository* to `https://github.com/SAP/jenkins-library`
|
|
|
|
1. Save changes
|
|
|
|
|
|
|
|
![Library Setup](./documentation/docs/images/setupInJenkins.png)
|
|
|
|
|
2018-12-05 14:37:15 +02:00
|
|
|
Now the library is available as `piper-lib-os` and can be used in any
|
2017-11-16 13:55:23 +02:00
|
|
|
`Jenkinsfile` by adding this line:
|
|
|
|
|
2018-11-06 14:50:09 +02:00
|
|
|
```groovy
|
2018-12-05 14:37:15 +02:00
|
|
|
@Library('piper-lib-os') _
|
2017-11-16 13:55:23 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
Jenkins will download the library during execution of the `Jenkinsfile`.
|
|
|
|
|
|
|
|
# Known Issues
|
|
|
|
|
|
|
|
A list of known issues is available on the [GitHub issues page of this
|
|
|
|
project][piper-library-issues].
|
|
|
|
|
|
|
|
# How to obtain support
|
|
|
|
|
|
|
|
Feel free to open new issues for feature requests, bugs or general feedback on
|
|
|
|
the [GitHub issues page of this project][piper-library-issues].
|
|
|
|
|
|
|
|
# Contributing
|
|
|
|
|
|
|
|
Read and understand our [contribution guidelines][piper-library-contribution]
|
|
|
|
before opening a pull request.
|
2017-11-14 10:55:17 +02:00
|
|
|
|
2017-11-14 10:50:11 +02:00
|
|
|
# [License][piper-library-license]
|
|
|
|
|
|
|
|
Copyright (c) 2017 SAP SE or an SAP affiliate company. All rights reserved.
|
2017-11-16 13:55:23 +02:00
|
|
|
This file is licensed under the Apache Software License, v. 2 except as noted
|
|
|
|
otherwise in the [LICENSE file][piper-library-license]
|
2017-11-14 10:50:11 +02:00
|
|
|
|
2017-11-16 13:55:23 +02:00
|
|
|
[github]: https://github.com
|
2017-07-11 15:12:03 +02:00
|
|
|
[piper-library]: https://github.com/SAP/jenkins-library
|
|
|
|
[piper-pipelines]: https://github.com/SAP/jenkins-pipelines
|
|
|
|
[piper-library-pages]: https://sap.github.io/jenkins-library
|
2017-11-16 13:55:23 +02:00
|
|
|
[piper-library-pages-plugins]: https://sap.github.io/jenkins-library/jenkins/requiredPlugins
|
|
|
|
[piper-library-issues]: https://github.com/SAP/jenkins-library/issues
|
2017-11-14 10:50:11 +02:00
|
|
|
[piper-library-license]: ./LICENSE
|
2018-09-13 11:08:40 +02:00
|
|
|
[piper-library-contribution]: .github/CONTRIBUTING.md
|
2017-11-16 13:55:23 +02:00
|
|
|
[jenkins-doc-pipelines]: https://jenkins.io/solutions/pipeline
|
|
|
|
[jenkins-doc-libraries]: https://jenkins.io/doc/book/pipeline/shared-libraries
|
|
|
|
[jenkins-doc-steps]: https://jenkins.io/doc/pipeline/steps
|
|
|
|
[jenkins-plugin-sharedlibs]: https://wiki.jenkins-ci.org/display/JENKINS/Pipeline+Shared+Groovy+Libraries+Plugin
|