1
0
mirror of https://github.com/SAP/jenkins-library.git synced 2025-01-20 05:19:40 +02:00
sap-jenkins-library/resources/metadata/cloudFoundryDeploy.yaml
Oliver Nocon b4d314215e
chore(cloudFoundryDeploy): remove deprecated groovy-based part (#3242)
* chore(cloudFoundryDeploy): remove deprecated groovy-based part

* chore: update test due to different step logic

* chore: update documentation

* fix yaml issue
2021-11-09 07:44:31 +01:00

407 lines
13 KiB
YAML

metadata:
name: cloudFoundryDeploy
description: "Deploys an application to Cloud Foundry"
longDescription: |
Deploys an application to a test or production space within Cloud Foundry.
spec:
inputs:
secrets:
- name: cfCredentialsId
description: Jenkins 'Username with password' credentials ID containing user and password to authenticate to the Cloud Foundry API.
type: jenkins
aliases:
- name: cloudFoundry/credentialsId
- name: dockerCredentialsId
description: Jenkins 'Username with password' credentials ID containing user and password to authenticate to the Docker registry.
type: jenkins
params:
- name: apiEndpoint
type: string
description: "Cloud Foundry API endpoint"
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: true
default: "https://api.cf.eu10.hana.ondemand.com"
aliases:
- name: cfApiEndpoint
- name: cloudFoundry/apiEndpoint
- name: appName
type: string
description: "Defines the name of the application to be deployed to the Cloud Foundry space"
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
aliases:
- name: cfAppName
- name: cloudFoundry/appName
- name: artifactVersion
type: string
description: "The artifact version, used for influx reporting"
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
resourceRef:
- name: commonPipelineEnvironment
param: artifactVersion
- name: commitHash
type: string
description: "The commit hash, used for influx reporting"
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
resourceRef:
- name: commonPipelineEnvironment
param: git/headCommitId
- name: cfHome
type: string
description: "The cf home folder used by the cf cli. If not provided the default assumed by the cf cli is used."
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
- name: cfNativeDeployParameters
type: string
description: "Additional parameters passed to cf native deployment command"
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
- name: cfPluginHome
type: string
description: "The cf plugin home folder used by the cf cli.
If not provided the default assumed by the cf cli is used."
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
- name: deployDockerImage
type: string
description: "Docker image deployments are supported
(via manifest file in general)[https://docs.cloudfoundry.org/devguide/deploy-apps/manifest-attributes.html#docker].
If no manifest is used, this parameter defines the image to be deployed.
The specified name of the image is passed to the `--docker-image` parameter of the cf CLI and must
adhere it's naming pattern (e.g. REPO/IMAGE:TAG).
See (cf CLI documentation)[https://docs.cloudfoundry.org/devguide/deploy-apps/push-docker.html]
for details.
Note: The used Docker registry must be visible for the targeted Cloud Foundry instance."
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
- name: deployTool
type: string
description: "Defines the tool which should be used for deployment."
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
- name: buildTool
type: string
description: "Defines the tool which is used for building the artifact.
If provided, `deployTool` is automatically derived from it.
For MTA projects, `deployTool` defaults to `mtaDeployPlugin`.
For other projects `cf_native` will be used."
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
resourceRef:
- name: commonPipelineEnvironment
param: buildTool
- name: deployType
type: string
description:
"Defines the type of deployment, either `standard` deployment which results in a system
downtime or a zero-downtime `blue-green` deployment.If 'cf_native' as deployType and 'blue-green'
as deployTool is used in combination, your manifest.yaml may only contain one application.
If this application has the option 'no-route' active the deployType will be changed to 'standard'."
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
default: "standard"
- name: dockerPassword
type: string
description:
"If the specified image in `deployDockerImage` is contained in a Docker registry,
which requires authorization, this defines the password to be used."
secret: true
scope:
- PARAMETERS
- STAGES
- STEPS
mandatory: false
resourceRef:
- name: dockerCredentialsId
type: secret
param: password
- name: dockerUsername
type: string
description:
"If the specified image in `deployDockerImage` is contained in a Docker registry,
which requires authorization, this defines the username to be used."
scope:
- PARAMETERS
- STAGES
- STEPS
mandatory: false
secret: true
resourceRef:
- name: dockerCredentialsId
type: secret
param: username
- name: keepOldInstance
type: bool
description:
"In case of a `blue-green` deployment the old instance will be deleted by default.
If this option is set to true the old instance will remain stopped in the Cloud Foundry space."
scope:
- PARAMETERS
- STAGES
- STEPS
mandatory: false
- name: loginParameters
type: string
description:
"Addition command line options for cf login command. No escaping/quoting is performed.
Not recommended for productive environments."
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
- name: manifest
type: string
description: "Defines the manifest to be used for deployment to Cloud Foundry."
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
aliases:
- name: cfManifest
- name: cloudFoundry/manifest
- name: manifestVariables
type: "[]string"
description: Defines a list of variables in the form `key=value` which are used for variable substitution within the file given by manifest.
longDescription: |
Defines a list of variables in the form `key=value` which are used for variable substitution
within the file given by manifest.
This can be used to set variables like it is provided by 'cf push --var key=value'.
**Note:** variables defined via 'manifestVariables' always win over conflicting variables defined
via any file given by 'manifestVariablesFiles' - no matter what is declared before.
This is the same behavior as can be observed when using 'cf push --var' in combination
with 'cf push --vars-file'."
Example:
```
...
cloudFoundryDeploy:
manifestVariables:
- 'key1=value1'
- 'key2=value2'
...
```
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
aliases:
- name: cfManifestVariables
- name: cloudFoundry/manifestVariables
- name: manifestVariablesFiles
type: "[]string"
description:
"path(s) of the Yaml file(s) containing the variable values to use as a
replacement in the manifest file. The order of the files is relevant in case there are
conflicting variable names and values within variable files.
In such a case, the values of the last file win."
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
default: ["manifest-variables.yml"]
mandatory: false
aliases:
- name: cfManifestVariablesFiles
- name: cloudFoundry/manifestVariablesFiles
- name: mtaDeployParameters
type: string
description: "Additional parameters passed to mta deployment command"
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
default: "-f"
- name: mtaExtensionDescriptor
type: string
description: "Defines additional extension descriptor file for deployment with the mtaDeployPlugin"
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
aliases:
- name: cloudFoundry/mtaExtensionDescriptor
- name: mtaExtensionCredentials
type: "map[string]interface{}"
description: "Defines a map of credentials that need to be replaced in the `mtaExtensionDescriptor`. This map needs to be created as `value-to-be-replaced`:`id-of-a-credential-in-jenkins`"
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
aliases:
- name: cloudFoundry/mtaExtensionCredentials
- name: mtaPath
type: string
description: "Defines the path to *.mtar for deployment with the mtaDeployPlugin"
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
resourceRef:
- name: commonPipelineEnvironment
param: mtarFilePath
- name: org
type: string
description: "Cloud Foundry target organization."
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
aliases:
- name: cfOrg
- name: cloudFoundry/org
mandatory: true
secret: false
- name: password
type: string
description: "Password"
scope:
- PARAMETERS
- STAGES
- STEPS
mandatory: true
secret: true
resourceRef:
- name: cfCredentialsId
type: secret
param: password
- type: vaultSecret
default: cloudfoundry-$(org)-$(space)
name: cloudfoundryVaultSecretName
- name: smokeTestScript
type: string
description:
"Allows to specify a script which performs a check during blue-green deployment.
The script gets the FQDN as parameter and returns `exit code 0` in case check returned
`smokeTestStatusCode`.
More details can be found [here](https://github.com/bluemixgaragelondon/cf-blue-green-deploy#how-to-use).
Currently this option is only considered for deployTool `cf_native`."
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
default: "blueGreenCheckScript.sh"
- name: smokeTestStatusCode
type: int
description: "Expected status code returned by the check."
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
mandatory: false
default: 200
- name: space
type: string
description: "Cloud Foundry target space"
scope:
- PARAMETERS
- STAGES
- STEPS
- GENERAL
aliases:
- name: cfSpace
- name: cloudFoundry/space
mandatory: true
- name: username
type: string
description: "User"
scope:
- PARAMETERS
- STAGES
- STEPS
mandatory: true
secret: true
resourceRef:
- name: cfCredentialsId
type: secret
param: username
- type: vaultSecret
default: cloudfoundry-$(org)-$(space)
name: cloudfoundryVaultSecretName
containers:
- name: cfDeploy
image: ppiper/cf-cli:6
outputs:
resources:
- name: influx
type: influx
params:
- name: deployment_data
fields:
- name: artifactUrl
- name: deployTime
- name: commitHash
- name: jobTrigger
tags:
- name: artifactVersion
- name: deployUser
- name: deployResult
- name: cfApiEndpoint
- name: cfOrg
- name: cfSpace