github.com/jaylevin/jenkins-library@v1.230.4/documentation/docs/scenarios/gCTS_Scenario.md (about) 1 # Set up a Pipeline-Based ABAP Development and Testing Process Using Git-Enabled Change and Transport System 2 3 ## Introduction 4 5 [Git-enabled Change & Transport System (gCTS)](https://help.sap.com/viewer/4a368c163b08418890a406d413933ba7/latest/en-US/f319b168e87e42149e25e13c08d002b9.html) enables you to manage your ABAP change and transport management processes using Git as an external version management system. It allows you to set up continuous integration processes for ABAP development. For current information about gCTS, see SAP Note [2821718 - Central Note for Git-enabled Change and Transport System (gCTS)](https://launchpad.support.sap.com/#/notes/2821718). 6 7 This scenario explains how to use a pipeline to deploy a commit to a test system, and execute [ABAP unit tests](https://help.sap.com/viewer/ba879a6e2ea04d9bb94c7ccd7cdac446/latest/en-US/491cfd8926bc14cde10000000a42189b.html) and [ATC (ABAP Test Cockpit)](https://help.sap.com/viewer/ba879a6e2ea04d9bb94c7ccd7cdac446/latest/en-US/62c41ad841554516bb06fb3620540e47.html) checks in the test system. For each new commit that arrives in the remote repository, the pipeline executes the following Piper steps in the test system: 8 9 1. [gctsDeploy](../../steps/gctsDeploy/): Deploys the commit on the test system. 10 2. [gctsExecuteABAPQualityChecks](../../steps/gctsExecuteABAPQualityChecks/): Executes ABAP unit tests and ATC checks for the ABAP development objects of the commit. 11 - If the result of the testing is *success*, the pipeline finishes. 12 - If the result of the testing is *error*, a rollback is executed (see next step). 13 3. Only in case of errors: [gctsRollback](../../steps/gctsRollback/): Executes a rollback to the previous commit. You can check the cause of the errors using the [Warnings Next Generation Plugin](https://www.jenkins.io/doc/pipeline/steps/warnings-ng/#warnings-next-generation-plugin) in Jenkins. 14 15 ## Prerequisites 16 17 - You have configured Git-Enabled Change and Transport System, and you use it for your ABAP development. See 18 [Configuring Git-enabled Change & Transport System (gCTS)](https://help.sap.com/viewer/4a368c163b08418890a406d413933ba7/latest/en-US/26c9c6c5a89244cb9506c253d36c3fda.html) 19 - You have a Git repository on a Git server, such as GitHub, or GitLab. 20 The Git repository is usually created as part of the gCTS configuration. It is used to store your ABAP developments. 21 You can use this Git repository also for the pipeline configuration. (Jenkinsfile) 22 The repository used for the pipeline configuration needs to be accessed by the Jenkins instance. If the repository is password-protected, the user and password (or access token) should be stored in the Jenkins Credentials Store (**Manage Jenkins** > **Manage Credentials**). 23 - You have at least two ABAP systems with a version SAP S/4HANA 2020 or higher. You need one development system that you use to push objects to the Git repository, and a test system on which you run the pipeline. You have created and cloned the Git repository on all systems, on the development system with the *Development* role, and on the others with the *Provided* role. 24 - You have enabled [ATC](https://help.sap.com/viewer/ba879a6e2ea04d9bb94c7ccd7cdac446/latest/en-US/62c41ad841554516bb06fb3620540e47.html) checks in transaction ATC in the test system. 25 - You have access to a Jenkins instance including the [Warnings-Next-Generation Plugin](https://plugins.jenkins.io/warnings-ng/). The plug-in must be installed separately. It is required to view the results of the testing after the pipeline has run. 26 For the gCTS scenario, we recommend that you use the [Custom Jenkins setup](https://www.project-piper.io/infrastructure/customjenkins/) even though it is possible to run the gCTS scenario with [Piper´s CX server](https://www.project-piper.io/infrastructure/overview/). 27 - You have set up a suitable Jenkins instance as described under [Getting Started with Project "Piper"](https://www.project-piper.io/guidedtour/) under *Create Your First Pipeline*. 28 - The user that is used for the execution of the pipeline must have the credentials entered in gCTS as described in the gCTS documentation under [Set User-Specific Authentication](https://help.sap.com/viewer/4a368c163b08418890a406d413933ba7/latest/en-US/3431ebd6fbf241778cd60587e7b5dc3e.html). 29 30 ## Process 31 32 The pipeline process is as follows: 33 34 1. You create or change ABAP objects in the development system. When you release the transport request, the objects are pushed to the remote repository in a new commit. The pipeline is triggered by the new commit. The pipeline can be started manually in Jenkins, or automatically when the new commit arrives in the Git repository (by setting a webhook on your Git server). For more information about webhooks on GitHub, see [Creating webhooks](https://docs.github.com/en/developers/webhooks-and-events/webhooks/creating-webhooks). 35 2. The pipeline deploys the new commit on the test system. 36 3. If the deployment is successful, the pipeline executes ATC checks and ABAP Unit tests for the objects of the commit depending on the specified object scope. In the sample configuration provided below, this is `localChangedObjects`, which means, the checks are executed for all objects that were changed by the last activity in the local repository. 37 - If the checks don´t find any errors, the pipeline finishes. The test system remains on the new commit, and you can continue your testing activities, for example, using manual tests. 38 - If the checks find errors, the pipeline continues with the next step. 39 4. In case of warnings or errors, the pipeline executes a rollback to the last active commit in the test system. 40 You can display the errors and warnings of the checks in the [Warnings-Next-Generation Plugin](https://plugins.jenkins.io/warnings-ng/). For more information about the mapping of priorities and severities of the checks to statuses displayed in Jenkins, see the description of the following parameters in the description of the [gctsExecuteABAPQualityChecks](../../steps/gctsExecuteABAPQualityChecks/) step: 41 - Severities of ABAP Unit test results: [aUnitTest](../../steps/gctsExecuteABAPQualityChecks/#aunittest) 42 - Priorities of ATC check results: [atcCheck](../../steps/gctsExecuteABAPQualityChecks/#atccheck) 43 44 After analyzing the errors, you can correct the issues in the development system. Once you release the new transport request, the pipeline is triggered again. 45 46 The following image shows the steps involved when the checks finish successfully: 47 48 data:image/s3,"s3://crabby-images/1f6be/1f6beb329a57c71d4c8afa53d4172fc78a9d87e1" alt="Process: Deploy Git repository on local system and execute tests - Tests are successful" 49 50 **Image: Build and Deploy Process in Jenkins** 51 52 The following image shows the steps involved when the checks result in warnings or errors: 53 54 data:image/s3,"s3://crabby-images/64396/6439602d8a6fd3634734045bfc036c6cebd724e3" alt="Process: Deploy Git repository on local system and execute tests - Tests are not successful" 55 56 **Image: Build and Deploy Process in Jenkins** 57 58 ## Example 59 60 To implement the gCTS scenario, create a Jenkinsfile in the root directory of your Git repository. The sample Jenkinsfile below contains all configuration information required. It is also possible to use an additional `.pipeline/config.yml` file for the configuration of the step parameters. But the `config.yml` is not required for the gCTS scenario described here. For more information, see the examples in the individual step descriptions. For general information about configuration options in "Piper" projects, see [Configuration](https://www.project-piper.io/configuration/). 61 62 ### Jenkinsfile 63 64 ```groovy 65 @Library(['piper-lib-os']) _ 66 pipeline { 67 agent any 68 options { 69 disableConcurrentBuilds() 70 } 71 72 environment { 73 DEMOCREDS = 'ABAPUserPasswordCredentialsId' 74 HOST = 'https://<host of the ABAP system>:<port>' 75 CLIENT = '000' 76 REPO = '<repository name>' 77 REPO_URL = "<URL of the remote Git Repository>" 78 } 79 80 stages { 81 stage('gCTS Deploy') { 82 when { 83 anyOf { 84 branch 'main' 85 } 86 } 87 steps { 88 gctsDeploy( 89 script: this, 90 host: HOST, 91 client: CLIENT, 92 abapCredentialsId: DEMOCREDS, 93 repository: REPO, 94 remoteRepositoryURL: REPO_URL, 95 role: 'SOURCE', 96 vSID: '<vSID>') 97 98 } 99 } 100 101 stage('gctsExecuteABAPQualityChecks') { 102 when { 103 anyOf { 104 branch 'main' 105 } 106 } 107 steps { 108 script { 109 try { 110 gctsExecuteABAPQualityChecks( 111 script: this, 112 host: HOST, 113 client: CLIENT, 114 abapCredentialsId: DEMOCREDS, 115 repository: REPO, 116 scope: 'localChangedObjects', 117 commit: "${env.GIT_COMMIT}", 118 workspace: "${WORKSPACE}") 119 } catch (Exception ex) { 120 currentBuild.result = 'FAILURE' 121 unstable(message: "${STAGE_NAME} is unstable") 122 } 123 124 } 125 } 126 } 127 128 stage('Results in Checkstyle') { 129 when { 130 anyOf { 131 branch 'main' 132 } 133 } 134 steps{ 135 136 recordIssues( 137 enabledForFailure: true, aggregatingResults: true, 138 tools: [checkStyle(pattern: 'ATCResults.xml', reportEncoding: 'UTF8'),checkStyle(pattern: 'AUnitResults.xml', reportEncoding: 'UTF8')] 139 ) 140 141 } 142 } 143 stage('Rollback') { 144 when { 145 expression { 146 currentBuild.result == 'FAILURE' 147 } 148 } 149 steps { 150 gctsRollback( 151 script: this, 152 host: HOST, 153 client: CLIENT, 154 abapCredentialsId: DEMOCREDS, 155 repository: REPO 156 ) 157 158 } 159 } 160 } 161 162 } 163 ``` 164 165 ### Parameters 166 167 For a detailed description of the relevant parameters of the library steps used in the gCTS scenario, see: 168 169 - [gctsDeploy](../../steps/gctsDeploy/) 170 - [gctsExecuteABAPQualityChecks](../../steps/gctsExecuteABAPQualityChecks/) 171 - [gctsRollback](../../steps/gctsRollback/) 172 173 ## Troubleshooting 174 175 If you encounter an issue with the pipeline itself, please open an issue in [GitHub](https://github.com/SAP/jenkins-library/issues) and add the label `gcts` to it.