mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-16 05:16:08 +02:00
Refactor of gctsExecuteABAPUnitTests (#3338)
* Update gctsExecuteABAPUnitTests.yaml * Update gctsExecuteABAPUnitTests.go * Update gctsExecuteABAPUnitTests.go * Update gctsExecuteABAPUnitTests.yaml * Add commit parameter * Update gctsExecuteABAPUnitTests.yaml * Update gctsExecuteABAPUnitTests.go * Update gctsExecuteABAPUnitTests.go * Update gctsExecuteABAPUnitTests.yaml * Update gctsExecuteABAPUnitTests.go * Change the commit parameter in Yaml file * Adding scope paramter to gCTSExecuteABAPUnitTest * Adding logs * Adapting checkstyle for success case * write ATC file * add log * time duration * add log * Improve log * Improve unit test * severity error * Fix the xml file for Unit Tests * Editing UnitTest Results for better parsing * Change file name * Add folder * Add path to file * Add src * Add src and object type * Add filename * Add path * Handling success cases * complete refactoring * fix for file path * filname lower case * Add log entry * Delete ATC Results * Change ATC name * Functiongroups * When ATC errors Pipeline fails * Reading a file into chuncks * escape string * Fix for a bug * Unesscape URL * Change from fatal error to error * When unit test fails pipeline fails too * Severity errors * Severity for Unit Test * Fix for successful unit test * Code review * Telemetry was missing * yaml file * generate yaml file * add logs * fix location * do not close body * checkstyle severity * checkstyle * checkstyle2 * atc method * line calculation * global file * method * line * fix * add logs * add log * add logg * unit test error * Code checked and finalized * change commit paramter to optional * Add logs for current local and remote commit * Add logs for object type and name * parse ATC checks error * add log of http response * add log * remove end of function findline * log cleaning * log extra cleaning * cleaning log for unit test * more cleaning * double cleanser for your code * more cleaning * docu checks * file name fix for function group * handle programs-reports * fix a bug * fix regex * fix regex for test class * fix regexos * fix dots * fix a error message in unit tests * calculate dynamically file extension * add log for path * add method name * add method name- * fix repo scope * include table type * Change paramter commitId to commit only * change log output * give more detailed examples * Table Name in get file name * change logs * improve log entries * improve log entries again * final improvements * Delete UnitTestResults * Review * Change text and comments * fix a type in commit paramter * change repository method name * Fix typos in yaml file * Remove empty lines in yaml file * Remove blank lines in the end * Add new line * go generate * Remove tabs Co-authored-by: Martin Bredy <58846699+martin-bredy@users.noreply.github.com> Co-authored-by: Christopher Fenner <26137398+CCFenner@users.noreply.github.com>
This commit is contained in:
parent
0879fa591a
commit
278c47b808
File diff suppressed because it is too large
Load Diff
@ -16,14 +16,22 @@ import (
|
||||
)
|
||||
|
||||
type gctsExecuteABAPUnitTestsOptions struct {
|
||||
Username string `json:"username,omitempty"`
|
||||
Password string `json:"password,omitempty"`
|
||||
Repository string `json:"repository,omitempty"`
|
||||
Host string `json:"host,omitempty"`
|
||||
Client string `json:"client,omitempty"`
|
||||
Username string `json:"username,omitempty"`
|
||||
Password string `json:"password,omitempty"`
|
||||
Host string `json:"host,omitempty"`
|
||||
Repository string `json:"repository,omitempty"`
|
||||
Client string `json:"client,omitempty"`
|
||||
AUnitTest bool `json:"aUnitTest,omitempty"`
|
||||
AtcCheck bool `json:"atcCheck,omitempty"`
|
||||
AtcVariant string `json:"atcVariant,omitempty"`
|
||||
Scope string `json:"scope,omitempty"`
|
||||
Commit string `json:"commit,omitempty"`
|
||||
Workspace string `json:"workspace,omitempty"`
|
||||
AtcResultsFileName string `json:"atcResultsFileName,omitempty"`
|
||||
AUnitResultsFileName string `json:"aUnitResultsFileName,omitempty"`
|
||||
}
|
||||
|
||||
// GctsExecuteABAPUnitTestsCommand Runs ABAP unit tests for all packages of the specified repository
|
||||
// GctsExecuteABAPUnitTestsCommand Runs ABAP unit tests and ATC (ABAP Test Cockpit) checks for a specified object scope.
|
||||
func GctsExecuteABAPUnitTestsCommand() *cobra.Command {
|
||||
const STEP_NAME = "gctsExecuteABAPUnitTests"
|
||||
|
||||
@ -36,8 +44,14 @@ func GctsExecuteABAPUnitTestsCommand() *cobra.Command {
|
||||
|
||||
var createGctsExecuteABAPUnitTestsCmd = &cobra.Command{
|
||||
Use: STEP_NAME,
|
||||
Short: "Runs ABAP unit tests for all packages of the specified repository",
|
||||
Long: `This step will execute every unit test associated with a package belonging to the specified local repository on an ABAP system.`,
|
||||
Short: "Runs ABAP unit tests and ATC (ABAP Test Cockpit) checks for a specified object scope.",
|
||||
Long: `This step executes ABAP unit test and ATC checks for a specified scope of objects that exist in a local Git repository on an ABAP system.
|
||||
Depending on your use case, you can specify a scope of objects for which you want to execute the checks. In addition, you can choose whether you want to execute only ABAP units tests, or only ATC checks, or both.
|
||||
By default, both checks are executed.
|
||||
The results of the checks are stored in a [Checkstyle](https://checkstyle.sourceforge.io/) format. With the help of the Jenkins [Warnings-Next-Generation](https://plugins.jenkins.io/warnings-ng/) Plugin), you can view the issues found, and navigate to the exact line of the source code where the issue occurred.
|
||||
To make the findings visible in Jenkins interface, you will need to use step recordIssues. An example will be shown in the Example section.
|
||||
<br />
|
||||
You can use this step as of SAP S/4HANA 2020.`,
|
||||
PreRunE: func(cmd *cobra.Command, _ []string) error {
|
||||
startTime = time.Now()
|
||||
log.SetStepName(STEP_NAME)
|
||||
@ -114,17 +128,26 @@ func GctsExecuteABAPUnitTestsCommand() *cobra.Command {
|
||||
}
|
||||
|
||||
func addGctsExecuteABAPUnitTestsFlags(cmd *cobra.Command, stepConfig *gctsExecuteABAPUnitTestsOptions) {
|
||||
cmd.Flags().StringVar(&stepConfig.Username, "username", os.Getenv("PIPER_username"), "User to authenticate to the ABAP system")
|
||||
cmd.Flags().StringVar(&stepConfig.Password, "password", os.Getenv("PIPER_password"), "Password to authenticate to the ABAP system")
|
||||
cmd.Flags().StringVar(&stepConfig.Repository, "repository", os.Getenv("PIPER_repository"), "Specifies the name (ID) of the local repsitory on the ABAP system")
|
||||
cmd.Flags().StringVar(&stepConfig.Host, "host", os.Getenv("PIPER_host"), "Specifies the protocol and host address, including the port. Please provide in the format `<protocol>://<host>:<port>`. Supported protocols are `http` and `https`.")
|
||||
cmd.Flags().StringVar(&stepConfig.Client, "client", os.Getenv("PIPER_client"), "Specifies the client of the ABAP system to be addressed")
|
||||
cmd.Flags().StringVar(&stepConfig.Username, "username", os.Getenv("PIPER_username"), "User that authenticates to the ABAP system. Note – Don´t provide this parameter directly. Either set it in the environment, or in the Jenkins credentials store, and provide the ID as value of the abapCredentialsId parameter.")
|
||||
cmd.Flags().StringVar(&stepConfig.Password, "password", os.Getenv("PIPER_password"), "Password of the ABAP user that authenticates to the ABAP system. Note – Don´t provide this parameter directly. Either set it in the environment, or in the Jenkins credentials store, and provide the ID as value of the abapCredentialsId parameter.")
|
||||
cmd.Flags().StringVar(&stepConfig.Host, "host", os.Getenv("PIPER_host"), "Protocol and host of the ABAP system, including the port. Please provide in the format <protocol>://<host>:<port>. Supported protocols are http and https.")
|
||||
cmd.Flags().StringVar(&stepConfig.Repository, "repository", os.Getenv("PIPER_repository"), "Name (ID) of the local repository on the ABAP system")
|
||||
cmd.Flags().StringVar(&stepConfig.Client, "client", os.Getenv("PIPER_client"), "Client of the ABAP system in which you want to execute the checks")
|
||||
cmd.Flags().BoolVar(&stepConfig.AUnitTest, "aUnitTest", true, "Indication whether you want to execute the unit test checks.")
|
||||
cmd.Flags().BoolVar(&stepConfig.AtcCheck, "atcCheck", true, "Indication whether you want to execute the ATC checks.")
|
||||
cmd.Flags().StringVar(&stepConfig.AtcVariant, "atcVariant", `DEFAULT_REMOTE_REF`, "Variant for ATC checks")
|
||||
cmd.Flags().StringVar(&stepConfig.Scope, "scope", `repository`, "Scope of objects for which you want to execute the checks:\n\n * localChangedObjects - object delta between the commit that triggered the pipeline and the current commit in the local repository. The checks are executed for the individual objects.\n * remoteChangedObjects - object delta between the commit that triggered the pipeline and the current commit in the remote repository. The checks are executed for the individual objects.\n * localChangedPackages - object delta between the commit that triggered the pipeline and the current commit in the local repository. All objects are resolved into packages. The checks are executed for the packages.\n * remoteChangedPackages - object delta between the commit that triggered the pipeline and the current commit in the remote repository. All objects are resolved into packages. The checks are executed for the packages.\n * repository - all objects that are part of the local repository. The checks are executed for the individual objects. Packages (DEVC) are excluded. This is the default scope.\n * packages - all packages that are part of the local repository . The checks are executed for the packages.\n")
|
||||
cmd.Flags().StringVar(&stepConfig.Commit, "commit", os.Getenv("PIPER_commit"), "ID of the commit that triggered the pipeline or any other commit to compare objects. For scopes localChangedObjects, remoteChangedObjects, localChangedPackages and remoteChangedPackages secifying a commit it's mandatory.")
|
||||
cmd.Flags().StringVar(&stepConfig.Workspace, "workspace", os.Getenv("PIPER_workspace"), "Absolute path to directory which contains the source code that your CI/CD tool checks out. For example in Jenkins, the workspace parameter is /var/jenkins_home/workspace/<jobName>/")
|
||||
cmd.Flags().StringVar(&stepConfig.AtcResultsFileName, "atcResultsFileName", `ATCResults.xml`, "Specifies output file name for the results from the ATC checks")
|
||||
cmd.Flags().StringVar(&stepConfig.AUnitResultsFileName, "aUnitResultsFileName", `AUnitResults.xml`, "Specifies output file name for the results from the AUnit tests")
|
||||
|
||||
cmd.MarkFlagRequired("username")
|
||||
cmd.MarkFlagRequired("password")
|
||||
cmd.MarkFlagRequired("repository")
|
||||
cmd.MarkFlagRequired("host")
|
||||
cmd.MarkFlagRequired("repository")
|
||||
cmd.MarkFlagRequired("client")
|
||||
cmd.MarkFlagRequired("workspace")
|
||||
}
|
||||
|
||||
// retrieve step metadata
|
||||
@ -133,12 +156,12 @@ func gctsExecuteABAPUnitTestsMetadata() config.StepData {
|
||||
Metadata: config.StepMetadata{
|
||||
Name: "gctsExecuteABAPUnitTests",
|
||||
Aliases: []config.Alias{},
|
||||
Description: "Runs ABAP unit tests for all packages of the specified repository",
|
||||
Description: "Runs ABAP unit tests and ATC (ABAP Test Cockpit) checks for a specified object scope.",
|
||||
},
|
||||
Spec: config.StepSpec{
|
||||
Inputs: config.StepInputs{
|
||||
Secrets: []config.StepSecrets{
|
||||
{Name: "abapCredentialsId", Description: "Jenkins credentials ID containing username and password for authentication to the ABAP system on which you want to perform the unit tests", Type: "jenkins"},
|
||||
{Name: "abapCredentialsId", Description: "ID taken from the Jenkins credentials store containing user name and password of the user that authenticates to the ABAP system on which you want to execute the checks.", Type: "jenkins"},
|
||||
},
|
||||
Parameters: []config.StepParameters{
|
||||
{
|
||||
@ -171,15 +194,6 @@ func gctsExecuteABAPUnitTestsMetadata() config.StepData {
|
||||
Aliases: []config.Alias{},
|
||||
Default: os.Getenv("PIPER_password"),
|
||||
},
|
||||
{
|
||||
Name: "repository",
|
||||
ResourceRef: []config.ResourceReference{},
|
||||
Scope: []string{"PARAMETERS", "STAGES", "STEPS"},
|
||||
Type: "string",
|
||||
Mandatory: true,
|
||||
Aliases: []config.Alias{},
|
||||
Default: os.Getenv("PIPER_repository"),
|
||||
},
|
||||
{
|
||||
Name: "host",
|
||||
ResourceRef: []config.ResourceReference{},
|
||||
@ -189,6 +203,15 @@ func gctsExecuteABAPUnitTestsMetadata() config.StepData {
|
||||
Aliases: []config.Alias{},
|
||||
Default: os.Getenv("PIPER_host"),
|
||||
},
|
||||
{
|
||||
Name: "repository",
|
||||
ResourceRef: []config.ResourceReference{},
|
||||
Scope: []string{"PARAMETERS", "STAGES", "STEPS"},
|
||||
Type: "string",
|
||||
Mandatory: true,
|
||||
Aliases: []config.Alias{},
|
||||
Default: os.Getenv("PIPER_repository"),
|
||||
},
|
||||
{
|
||||
Name: "client",
|
||||
ResourceRef: []config.ResourceReference{},
|
||||
@ -198,6 +221,78 @@ func gctsExecuteABAPUnitTestsMetadata() config.StepData {
|
||||
Aliases: []config.Alias{},
|
||||
Default: os.Getenv("PIPER_client"),
|
||||
},
|
||||
{
|
||||
Name: "aUnitTest",
|
||||
ResourceRef: []config.ResourceReference{},
|
||||
Scope: []string{"PARAMETERS", "STAGES", "STEPS"},
|
||||
Type: "bool",
|
||||
Mandatory: false,
|
||||
Aliases: []config.Alias{},
|
||||
Default: true,
|
||||
},
|
||||
{
|
||||
Name: "atcCheck",
|
||||
ResourceRef: []config.ResourceReference{},
|
||||
Scope: []string{"PARAMETERS", "STAGES", "STEPS"},
|
||||
Type: "bool",
|
||||
Mandatory: false,
|
||||
Aliases: []config.Alias{},
|
||||
Default: true,
|
||||
},
|
||||
{
|
||||
Name: "atcVariant",
|
||||
ResourceRef: []config.ResourceReference{},
|
||||
Scope: []string{"PARAMETERS", "STAGES", "STEPS"},
|
||||
Type: "string",
|
||||
Mandatory: false,
|
||||
Aliases: []config.Alias{},
|
||||
Default: `DEFAULT_REMOTE_REF`,
|
||||
},
|
||||
{
|
||||
Name: "scope",
|
||||
ResourceRef: []config.ResourceReference{},
|
||||
Scope: []string{"PARAMETERS", "STAGES", "STEPS"},
|
||||
Type: "string",
|
||||
Mandatory: false,
|
||||
Aliases: []config.Alias{},
|
||||
Default: `repository`,
|
||||
},
|
||||
{
|
||||
Name: "commit",
|
||||
ResourceRef: []config.ResourceReference{},
|
||||
Scope: []string{"PARAMETERS", "STAGES", "STEPS"},
|
||||
Type: "string",
|
||||
Mandatory: false,
|
||||
Aliases: []config.Alias{},
|
||||
Default: os.Getenv("PIPER_commit"),
|
||||
},
|
||||
{
|
||||
Name: "workspace",
|
||||
ResourceRef: []config.ResourceReference{},
|
||||
Scope: []string{"PARAMETERS", "STAGES", "STEPS"},
|
||||
Type: "string",
|
||||
Mandatory: true,
|
||||
Aliases: []config.Alias{},
|
||||
Default: os.Getenv("PIPER_workspace"),
|
||||
},
|
||||
{
|
||||
Name: "atcResultsFileName",
|
||||
ResourceRef: []config.ResourceReference{},
|
||||
Scope: []string{"PARAMETERS", "STAGES", "STEPS"},
|
||||
Type: "string",
|
||||
Mandatory: false,
|
||||
Aliases: []config.Alias{},
|
||||
Default: `ATCResults.xml`,
|
||||
},
|
||||
{
|
||||
Name: "aUnitResultsFileName",
|
||||
ResourceRef: []config.ResourceReference{},
|
||||
Scope: []string{"PARAMETERS", "STAGES", "STEPS"},
|
||||
Type: "string",
|
||||
Mandatory: false,
|
||||
Aliases: []config.Alias{},
|
||||
Default: `AUnitResults.xml`,
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -4,9 +4,9 @@
|
||||
|
||||
## Prerequisites
|
||||
|
||||
* You have gCTS installed and configured on your ABAP systems.
|
||||
|
||||
Learn more about the SAP Git-enabled Change & Transport System (gCTS) [here](https://help.sap.com/viewer/4a368c163b08418890a406d413933ba7/201909.001/en-US/f319b168e87e42149e25e13c08d002b9.html). With gCTS, ABAP developments on ABAP servers can be maintained in Git repositories.
|
||||
* [ATC](https://help.sap.com/viewer/c238d694b825421f940829321ffa326a/202110.000/en-US/4ec5711c6e391014adc9fffe4e204223.html) checks are enabled in transaction ATC in the ABAP systems where you want to use the step.
|
||||
* [gCTS](https://help.sap.com/viewer/4a368c163b08418890a406d413933ba7/latest/en-US/26c9c6c5a89244cb9506c253d36c3fda.html) is available and configured in the ABAP systems where you want to use the step.
|
||||
* The [Warnings-Next-Generation](https://plugins.jenkins.io/warnings-ng/) Plugin is installed in Jenkins.
|
||||
|
||||
## ${docGenParameters}
|
||||
|
||||
@ -24,7 +24,11 @@ gctsExecuteABAPUnitTests(
|
||||
host: 'https://abap.server.com:port',
|
||||
client: '000',
|
||||
abapCredentialsId: 'ABAPUserPasswordCredentialsId',
|
||||
repository: 'myrepo'
|
||||
repository: 'myrepo',
|
||||
scope: 'localChangedObjects',
|
||||
commit: "${GIT_COMMIT}",
|
||||
workspace: "${WORKSPACE}"
|
||||
|
||||
)
|
||||
```
|
||||
|
||||
@ -38,4 +42,82 @@ steps:
|
||||
client: '000'
|
||||
abapCredentialsId: 'ABAPUserPasswordCredentialsId'
|
||||
repository: 'myrepo'
|
||||
scope: 'remoteChangedObjects'
|
||||
commit: '38abb4814ae46b98e8e6c3e718cf1782afa9ca90'
|
||||
workspace: '/var/jenkins_home/workspace/myFirstPipeline'
|
||||
```
|
||||
|
||||
Example configuration when you define scope: *repository* or *packages*. For these two cases you do not need to specify a *commit*.
|
||||
|
||||
```yaml
|
||||
steps:
|
||||
<...>
|
||||
gctsExecuteABAPUnitTests:
|
||||
host: 'https://abap.server.com:port'
|
||||
client: '000'
|
||||
abapCredentialsId: 'ABAPUserPasswordCredentialsId'
|
||||
repository: 'myrepo'
|
||||
scope: 'repository'
|
||||
workspace: '/var/jenkins_home/workspace/myFirstPipeline'
|
||||
```
|
||||
|
||||
Example configuration when you want to execute only ABAP Unit Test.
|
||||
|
||||
```yaml
|
||||
steps:
|
||||
<...>
|
||||
gctsExecuteABAPUnitTests:
|
||||
host: 'https://abap.server.com:port'
|
||||
client: '000'
|
||||
abapCredentialsId: 'ABAPUserPasswordCredentialsId'
|
||||
repository: 'myrepo'
|
||||
atcCheck: false
|
||||
scope: 'packages'
|
||||
workspace: '/var/jenkins_home/workspace/myFirstPipeline'
|
||||
```
|
||||
|
||||
Example configuration for the use of *recordIssue* step to make the findings visible in Jenkins interface.
|
||||
|
||||
```groovy
|
||||
stage('ABAP Unit Tests') {
|
||||
steps{
|
||||
|
||||
script{
|
||||
|
||||
try{
|
||||
gctsExecuteABAPUnitTests(
|
||||
script: this,
|
||||
commit: "${GIT_COMMIT}",
|
||||
workspace: "${WORKSPACE}")
|
||||
}
|
||||
catch (Exception ex) {
|
||||
currentBuild.result = 'FAILURE'
|
||||
unstable(message: "${STAGE_NAME} is unstable")
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
stage('Results in Checkstyle') {
|
||||
steps{
|
||||
|
||||
recordIssues(
|
||||
enabledForFailure: true, aggregatingResults: true,
|
||||
tools: [checkStyle(pattern: 'ATCResults.xml', reportEncoding: 'UTF8'),checkStyle(pattern: 'AUnitResults.xml', reportEncoding: 'UTF8')]
|
||||
)
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
```
|
||||
|
||||
**Note:** If you have disabled *atcCheck* or *aUnitTest*, than you also need to remove the corresponding *ATCResults.xml* or *AUnitResults.xml* from *recordIssues* step. In the example below the *atcCheck* was disabled, so *ATCResults.xml* was removed.
|
||||
|
||||
```groovy
|
||||
recordIssues(
|
||||
enabledForFailure: true, aggregatingResults: true,
|
||||
tools: [checkStyle(pattern: 'AUnitResults.xml', reportEncoding: 'UTF8')]
|
||||
|
||||
)
|
||||
```
|
||||
|
2
go.sum
2
go.sum
@ -2625,4 +2625,4 @@ sigs.k8s.io/structured-merge-diff/v4 v4.0.3/go.mod h1:bJZC9H9iH24zzfZ/41RGcq60oK
|
||||
sigs.k8s.io/yaml v1.1.0/go.mod h1:UJmg0vDUVViEyp3mgSv9WPwZCDxu4rQW1olrI1uml+o=
|
||||
sigs.k8s.io/yaml v1.2.0 h1:kr/MCeFWJWTwyaHoR9c8EjH9OumOmoF9YGiZd7lFm/Q=
|
||||
sigs.k8s.io/yaml v1.2.0/go.mod h1:yfXDCHCao9+ENCvLSE62v9VSji2MKu5jeNfTrofGhJc=
|
||||
sourcegraph.com/sourcegraph/appdash v0.0.0-20190731080439-ebfcffb1b5c0/go.mod h1:hI742Nqp5OhwiqlzhgfbWU4mW4yO10fP+LoT9WOswdU=
|
||||
sourcegraph.com/sourcegraph/appdash v0.0.0-20190731080439-ebfcffb1b5c0/go.mod h1:hI742Nqp5OhwiqlzhgfbWU4mW4yO10fP+LoT9WOswdU=
|
@ -1,19 +1,25 @@
|
||||
metadata:
|
||||
name: gctsExecuteABAPUnitTests
|
||||
description: Runs ABAP unit tests for all packages of the specified repository
|
||||
description: Runs ABAP unit tests and ATC (ABAP Test Cockpit) checks for a specified object scope.
|
||||
longDescription: |
|
||||
This step will execute every unit test associated with a package belonging to the specified local repository on an ABAP system.
|
||||
This step executes ABAP unit test and ATC checks for a specified scope of objects that exist in a local Git repository on an ABAP system.
|
||||
Depending on your use case, you can specify a scope of objects for which you want to execute the checks. In addition, you can choose whether you want to execute only ABAP units tests, or only ATC checks, or both.
|
||||
By default, both checks are executed.
|
||||
The results of the checks are stored in a [Checkstyle](https://checkstyle.sourceforge.io/) format. With the help of the Jenkins [Warnings-Next-Generation](https://plugins.jenkins.io/warnings-ng/) Plugin), you can view the issues found, and navigate to the exact line of the source code where the issue occurred.
|
||||
To make the findings visible in Jenkins interface, you will need to use step recordIssues. An example will be shown in the Example section.
|
||||
<br />
|
||||
You can use this step as of SAP S/4HANA 2020.
|
||||
|
||||
spec:
|
||||
inputs:
|
||||
secrets:
|
||||
- name: abapCredentialsId
|
||||
description: Jenkins credentials ID containing username and password for authentication to the ABAP system on which you want to perform the unit tests
|
||||
description: ID taken from the Jenkins credentials store containing user name and password of the user that authenticates to the ABAP system on which you want to execute the checks.
|
||||
type: jenkins
|
||||
params:
|
||||
- name: username
|
||||
type: string
|
||||
description: User to authenticate to the ABAP system
|
||||
description: User that authenticates to the ABAP system. Note – Don´t provide this parameter directly. Either set it in the environment, or in the Jenkins credentials store, and provide the ID as value of the abapCredentialsId parameter.
|
||||
scope:
|
||||
- PARAMETERS
|
||||
- STAGES
|
||||
@ -26,7 +32,7 @@ spec:
|
||||
param: username
|
||||
- name: password
|
||||
type: string
|
||||
description: Password to authenticate to the ABAP system
|
||||
description: Password of the ABAP user that authenticates to the ABAP system. Note – Don´t provide this parameter directly. Either set it in the environment, or in the Jenkins credentials store, and provide the ID as value of the abapCredentialsId parameter.
|
||||
scope:
|
||||
- PARAMETERS
|
||||
- STAGES
|
||||
@ -37,17 +43,17 @@ spec:
|
||||
- name: abapCredentialsId
|
||||
type: secret
|
||||
param: password
|
||||
- name: repository
|
||||
- name: host
|
||||
type: string
|
||||
description: Specifies the name (ID) of the local repsitory on the ABAP system
|
||||
description: Protocol and host of the ABAP system, including the port. Please provide in the format <protocol>://<host>:<port>. Supported protocols are http and https.
|
||||
scope:
|
||||
- PARAMETERS
|
||||
- STAGES
|
||||
- STEPS
|
||||
mandatory: true
|
||||
- name: host
|
||||
- name: repository
|
||||
type: string
|
||||
description: Specifies the protocol and host address, including the port. Please provide in the format `<protocol>://<host>:<port>`. Supported protocols are `http` and `https`.
|
||||
description: Name (ID) of the local repository on the ABAP system
|
||||
scope:
|
||||
- PARAMETERS
|
||||
- STAGES
|
||||
@ -55,9 +61,90 @@ spec:
|
||||
mandatory: true
|
||||
- name: client
|
||||
type: string
|
||||
description: Specifies the client of the ABAP system to be addressed
|
||||
description: Client of the ABAP system in which you want to execute the checks
|
||||
scope:
|
||||
- PARAMETERS
|
||||
- STAGES
|
||||
- STEPS
|
||||
mandatory: true
|
||||
- name: aUnitTest
|
||||
type: bool
|
||||
default: true
|
||||
description: Indication whether you want to execute the unit test checks.
|
||||
scope:
|
||||
- PARAMETERS
|
||||
- STAGES
|
||||
- STEPS
|
||||
- name: atcCheck
|
||||
type: bool
|
||||
default: true
|
||||
description: Indication whether you want to execute the ATC checks.
|
||||
scope:
|
||||
- PARAMETERS
|
||||
- STAGES
|
||||
- STEPS
|
||||
- name: atcVariant
|
||||
type: string
|
||||
default: "DEFAULT_REMOTE_REF"
|
||||
description: Variant for ATC checks
|
||||
scope:
|
||||
- PARAMETERS
|
||||
- STAGES
|
||||
- STEPS
|
||||
- name: scope
|
||||
type: string
|
||||
default: repository
|
||||
enum:
|
||||
- localChangedObjects
|
||||
- remoteChangedObjects
|
||||
- localChangedPackages
|
||||
- remoteChangedPackages
|
||||
- repository
|
||||
- packages
|
||||
description: |
|
||||
Scope of objects for which you want to execute the checks:
|
||||
|
||||
* localChangedObjects - object delta between the commit that triggered the pipeline and the current commit in the local repository. The checks are executed for the individual objects.
|
||||
* remoteChangedObjects - object delta between the commit that triggered the pipeline and the current commit in the remote repository. The checks are executed for the individual objects.
|
||||
* localChangedPackages - object delta between the commit that triggered the pipeline and the current commit in the local repository. All objects are resolved into packages. The checks are executed for the packages.
|
||||
* remoteChangedPackages - object delta between the commit that triggered the pipeline and the current commit in the remote repository. All objects are resolved into packages. The checks are executed for the packages.
|
||||
* repository - all objects that are part of the local repository. The checks are executed for the individual objects. Packages (DEVC) are excluded. This is the default scope.
|
||||
* packages - all packages that are part of the local repository . The checks are executed for the packages.
|
||||
scope:
|
||||
- PARAMETERS
|
||||
- STAGES
|
||||
- STEPS
|
||||
- name: commit
|
||||
type: string
|
||||
description: ID of the commit that triggered the pipeline or any other commit to compare objects. For scopes localChangedObjects, remoteChangedObjects, localChangedPackages and remoteChangedPackages secifying a commit it's mandatory.
|
||||
scope:
|
||||
- PARAMETERS
|
||||
- STAGES
|
||||
- STEPS
|
||||
mandatory: false
|
||||
- name: workspace
|
||||
type: string
|
||||
description: Absolute path to directory which contains the source code that your CI/CD tool checks out. For example in Jenkins, the workspace parameter is /var/jenkins_home/workspace/<jobName>/
|
||||
scope:
|
||||
- PARAMETERS
|
||||
- STAGES
|
||||
- STEPS
|
||||
mandatory: true
|
||||
- name: atcResultsFileName
|
||||
type: string
|
||||
description: Specifies output file name for the results from the ATC checks
|
||||
scope:
|
||||
- PARAMETERS
|
||||
- STAGES
|
||||
- STEPS
|
||||
mandatory: false
|
||||
default: "ATCResults.xml"
|
||||
- name: aUnitResultsFileName
|
||||
type: string
|
||||
description: Specifies output file name for the results from the AUnit tests
|
||||
scope:
|
||||
- PARAMETERS
|
||||
- STAGES
|
||||
- STEPS
|
||||
mandatory: false
|
||||
default: "AUnitResults.xml"
|
||||
|
Loading…
Reference in New Issue
Block a user