| Browse by Topic | Browse by Author | Browse by Artefact Type | Request a Recipe | Report a broken link | Contribute|
-
Your build server is up and running. As we have used a Jenkins build server for building the pipelines, we will link to the Jenkins documentation: https://www.jenkins.io/doc/book/installing/. But you can use your own build server, as long as it’s able to process the pipeline scripts.
-
Your source code repository/version management system is up and running. In our examples, we’ve used Git, but GitHub is fine, too. You probably need one Git repository for each pipeline script file and one Git repository for your whole integration content.
-
The SAP Integration Suite capabilities API Management and/or Cloud Integration or the corresponding standalone products are up and running. If you want to try out the trial version of SAP Integration Suite, this tutorial might help.
-
OData API access for API Management and Cloud Integration should be enabled. In this first version of our pipelines, we support API Management on Cloud Foundry only as we are using OAuth2 for authentication, and API Management uses Basic Authentication on Neo.
For setup OData API access instructions, check out the following topics:
-
For Cloud Integration, see Authentication. If you only want to perform non-modifying actions (e.g. download artefacts), you can use a read-only role for the API access. If you want to perform modifying actions (deploy artefacts, update configuration parameters, …) you need to add additional roles.
-
For API Management, see API Access plan for API Portal.
-
As the output of the steps above, you get the following for each capability:
- A tenant URL.
- An OAuth token URL.
- Client ID and Client Secret.
-
If the prerequisites are fulfilled, you’ll be ready to run our CICD pipelines with a few steps only!
Instead of putting the credentials of your integration capabilities in readable text into the script pipeline, let’s use the secure storage of the Jenkins build server. See also https://www.jenkins.io/doc/book/using/using-credentials/
To do this, open your Jenkins, go to Manage Jenkins > Security > Manage Credentials.
Store the following credentials with a separate alias/identifier:
- Client credentials (client ID + client secret) for your integration capabilities.
- Credentials to access your Git repositories (the repository for your integration content and the repositories of your CICD pipelines).
The identifier that you enter here is needed either in the pipeline script configuration directly or when creating Jenkins environment variables (see next step).
Fig 1: Add Credentials in Jenkins
This step is optional, but we recommend storing all parameters such as credential IDs, hostnames, etc. as environment variables in your Jenkins and to use those environment variables in your pipeline script configuration. Using this approach, you get a central place where you can easily change such parameters at any time without the need of touching them in every single pipeline script.
To do this, open your Jenkins, go to Manage Jenkins > Configure > Global Properties > Environment variables.
Fig 2: Add Environment Variables in Jenkins
Be careful which variable names you choose as Jenkins uses certain predefined variable names. Overwriting them can cause undesired side effects. See the variable GIT_BRANCH as an example. For more details, see: https://plugins.jenkins.io/git/
For every submission to Git, you need a valid user. Instead of adding a configuration parameter for this user in each pipeline script, we have chosen the global Jenkins configuration. To do this, open your Jenkins, go to Manage Jenkins > Configure System > section Git plugin.
Enter the name and the email address of the user that will submit the changes to your integration content repository.
Fig 3: Add Global Git Configuration
As you have to configure the pipeline script to work with your environment, we recommend storing it in a source code repository. One of the benefits is that you avoid losing your configuration due to any unforeseen circumstances (Don’t forget to also add the credentials for the repository in Jenkins as described above, so that Jenkins will be able to access the pipeline script later).
To execute the script you need to create a Jenkins pipeline job. See for more information on pipelines: https://www.jenkins.io/doc/pipeline/tour/hello-world/
To do so, open your Jenkins and click on New Item. Enter a self-explaining name for your pipeline and depending on your source code repository type, select one of the following types for your Jenkins job.
-
Job type Pipeline
Select this pipeline type if you store one pipeline script per source code repository and your source code repository is Git. Confirm with OK.
Fig 4: Select job type Pipeline
In the job configuration under section “Pipeline”, change the Definition to “Pipeline script from SCM”, choose “Git” as SCM, and then provide the URL and credentials to your Git repository where your pipeline script is located.
Fig 5: Configure Jenkins Pipeline with Git Repository of Pipeline Script
When executing this Jenkins job, Jenkins will automatically search for a pipeline script called “Jenkinsfile” in the specified repository.
-
Job type Multibranch Pipeline
Select this pipeline type if you are using a different source code repository, e.g. GitHub, or if you plan to store multiple pipeline scripts in one repository. Confirm with OK.
Fig 6: Select Job Type Multibranch Pipeline
Fig 7: Select Repository Type
Enter the repository URL and select the credentials for the repository (which you have uploaded before).
Fig 8: Enter Repository Details
Under “Build Configuration”, choose Mode “by Jenkinsfile” and provide the name of the pipeline script that you want to use for this Jenkins job. It’s ok if the script does not exist yet.
Fig 9: Specify Pipeline Script Name in Jenkins Job
Save the Job configuration.
The job that you have created will perform the steps that will be given by the script. In case you want to change anything in your pipeline, don’t touch the job! Instead, change the pipeline script!
Important: Avoid running Jenkins jobs in parallel that submit content into the same repository as it might come to conflicts otherwise, same like when two people are working with the same Git repository.
It is important to have a structured and consistent order for your integration content so that you get the most out of your CICD processes.
In our scripts, we’ve used the following folder structure:
Fig 10: Folder Structure
If you want to use a different folder structure, you can specify this in the pipeline scripts via the corresponding parameter.
Important: Ensure that the folder structure that you want to use in your pipeline script already exists in your Git repository before running the pipeline, otherwise you will receive an error stating “Sparse checkout leaves no entry on working directory”.
Now that you’re done with the setup, you can start configuring the scripts and perform the CICD processes on your SAP Integration Suite tenants using our pipeline scripts.