- git-clone-repo: This Task fetches the credentials needed to perform git operations on a repository integrated in a Continuous Delivery toolchain and then uses it to clone (and/or perform the appropriate checkout if pull request parameters are given) of the repository.
- git-set-commit-status: This task is setting a git commit status for a given git commit (revision) in a git repository repository integrated in a Continuous Delivery toolchain
- Add a github integration in your toolchain to the repository containing the task (https://github.com/open-toolchain/tekton-catalog)
- Add that github integration to the Definitions tab of your Continuous Delivery tekton pipeline, with the Path set to
git
-
The
sample
sub-directory contains an EventListener definition that you can include in your CD tekton pipeline configuration to run an example showing a simple usage of thegit-clone-repo
.See the documentation here
-
The
sample-git-trigger
sub-directory contains several EventListener definitions that you can include in your CD tekton pipeline configuration to run an example showing usage of the git-clone-repo in the context of CD tekton pipeline triggered by git event(s) (Commit pushed or PullRequest opened/updated)See the documentation here
-
The
sample-set-commit-status
sub-directory contains several EventListener definitions that you can include in your CD tekton pipeline configuration to run an example demonstrating the usage of thegit-set-commit-status
task in the context of a CD Tekton pipeline triggered by a Git event (Commit push).See the documentation here
-
The
sample-git-pr-status
sub-directory contains several EventListener definitions that you can include in your CD tekton pipeline configuration to run an example demonstrating the usage of thegit-set-commit-status
in the context of a CD Tekton pipeline triggered by a Git Pull Request event (PullRequest push/update).See the documentation here
Git integration clone task
The task may rely on the following kubernetes resources to be defined:
-
Secret secure-properties
Secret containing:
- apikey: An IBM Cloud Api Key used to access to the toolchain (and
Git Repos and Issue Tracking
service if used). Note: secret name and secret key can be configured using Task's params.
If this secret is provided, it will be used to obtain the the git token for the git integration in the toolchain
Note: the
secure-properties
secret is injected in the Tekton Pipeline environment by Continuous Delivery Tekton Pipeline support. See Tekton Pipelines environment and resources - apikey: An IBM Cloud Api Key used to access to the toolchain (and
- git-access-token: (optional) token to access the git repository. Either
secure-properties
or git-access-token has to be provided. - git-max-retry: max retry for the git clone operation (default to "1")
- repository: the git repository url that the toolchain is integrating
- branch: the git branch (default value to
master
). This param can also be given as a full git ref likerefs/heads/master
(as described by Git References) - revision: (optional) the git revision/commit to update the git HEAD to (default to empty meaning only use the branch information)
- pr-repository: the originated repository where the PullRequest come from (in case of a fork). Default to '' means same repository (not a fork) or it can be the same as repository to clone.
- pr-branch: the branch that is the source of this PullRequest. Default to ''.
- pr-revision: the commit/revision in the source branch of the PullRequest that is to be built. Defaults to ''.
- directory-name: (optional) name of the new directory to clone into (default to
.
in order to clone at the root of the volume mounted for the pipeline run). Note: It will be to the "humanish" part of the repository if this param is set to blank - properties-file: (optional) name of the properties file that will be created as an additional outcome of this task in the workspace
workspace
. This file will contains the git related information (GIT_URL
,GIT_BRANCH
andGIT_COMMIT
) - resource-group: (optional) target resource group (name or id) for the ibmcloud login operation
- continuous-delivery-context-secret: (optional) Name of the secret containing the continuous delivery pipeline context secret (default to
secure-properties
) - ibmcloud-apikey-secret-key: (optional) field in the secret that contains the api key used to login to ibmcloud (default to
apikey
) - git-credentials-json-file: (optional) name of JSON file to store git credentials found out of the clone task (it can be a file path relative to the workspace
workspace
backed by a volume). Default to '' meaning no output of this information. - fetch-gitoken-step-image: (optional) image to use for the fetch-gitoken step. Default to
icr.io/continuous-delivery/pipeline/pipeline-base-ubi:3.2
- output: The git repo will be cloned onto the volume backing this workspace
- git-repository: The cloned repository
- git-branch: The active branch for the repository
- git-commit: The current commit id that was cloned
- git-user: The auth user that cloned the repository
- clone-directory: The directory where the cloned repository content is located
The output of this task is the repository cloned into the directory on the workspace workspace
.
Git commit status setter task
The task may rely on the following kubernetes resources to be defined:
-
Secret secure-properties
Secret containing:
- apikey: An IBM Cloud Api Key used to access to the toolchain (and
Git Repos and Issue Tracking
service if used). Note: secret name and secret key can be configured using Task's params.
If this secret is provided, it will be used to obtain the the git token for the git integration in the toolchain
Note: the
secure-properties
secret is injected in the Tekton Pipeline environment by Continuous Delivery Tekton Pipeline support. See Tekton Pipelines environment and resources - apikey: An IBM Cloud Api Key used to access to the toolchain (and
- resource-group: (optional) target resource group (name or id) for the ibmcloud login operation
- continuous-delivery-context-secret: (optional) Name of the secret containing the continuous delivery pipeline context secret (default to
secure-properties
) - ibmcloud-apikey-secret-key: (optional) field in the secret that contains the api key used to login to ibmcloud (default to
apikey
) - git-access-token: (optional) token to access the git repository. Either
secure-properties
secret orgit-access-token
has to be provided. - repository: the git repository url that the toolchain is integrating
- revision: the git revision/commit to update the status
- description: A short description of the status.
- context: (optional) A string label to differentiate this status from the status of other systems. (default to
continuous-integration/tekton
) - state: The state of the status. Can be one of the following:
pending
,running
,success
,failed
,canceled
or a value meaningful for the target git repository (gitlab/hostedgit:pending
,running
,success
,failed
,canceled
- github/integrated github:pending
,success
,failure
,error
- bitbucket:SUCCESSFUL
,FAILED
,INPROGRESS
,STOPPED
) - state-var: Customized variable stored in
properties-file
(likebuild-properties
for instance) to use as state ifstate
input param is empty. - properties-file: (optional) name of a properties file that may contain the state as value for the entry/key defined by
state-var
(default tobuild.properties
) - target-url: (optional) a url to set as the status detail link for the PR. If left empty, the status detail link will point to the pipeline run.
- fetch-git-information-step-image: (optional) image to use for the fetch-git-information step (default to
icr.io/continuous-delivery/pipeline/pipeline-base-ubi:3.2
) - set-status-step-image: (optional) image to use for the fetch-git-information step (default to
registry.access.redhat.com/ubi8/ubi:8.1
)
- artifacts: Workspace that may contain git repository information (ie build.properties). Should be marked as optional when Tekton will permit it
The task expects the following kubernetes resource to be defined:
-
Secret secure-properties (optional)
Secret containing:
- apikey: An IBM Cloud Api Key allowing access to the toolchain (and
Git Repos and Issue Tracking
service if used)
If this secret is provided, it will be used to obtain the the git token for the git integration in the toolchain
Note: the
secure-properties
secret is injected in the Tekton Pipeline environment by Continuous Delivery Tekton Pipeline support. See Tekton Pipelines environment and resources - apikey: An IBM Cloud Api Key allowing access to the toolchain (and
- task-pvc: the input pvc - this is where the properties file (like
build.properties
defined inpropertiesFile
parameter) would be stored - resourceGroup: (optional) target resource group (name or id) for the ibmcloud login operation
- continuous-delivery-context-secret: (optional) name of the configmap containing the continuous delivery pipeline context secret (default to
secure-properties
) - ibmcloud-apikey-secret-key: (optional) field in the secret that contains the api key used to login to ibmcloud (default to
apikey
) - gitAccessToken: (optional) token to access the git repository. Either
secure-properties
or gitAccessToken has to be provided. - repository: the git repository url that the toolchain is integrating
- revision: the git revision/commit to update the status
- description: A short description of the status.
- context: (optional) A string label to differentiate this status from the status of other systems. (default to
continuous-integration/tekton
) - state: The state of the status. Can be one of the following:
pending
,running
,success
,failed
,canceled
or a value meaningful for the target git repository (gitlab/hostedgit:pending
,running
,success
,failed
,canceled
- github/integrated github:pending
,success
,failure
,error
- bitbucket:SUCCESSFUL
,FAILED
,INPROGRESS
,STOPPED
) - state-var: Customized variable stored in
propertiesFile
(likebuild-properties
for instance) to use as state ifstate
input param is empty. - propertiesFile: (optional) name of a properties file that may contain the state as value for the entry/key defined by
state-var
(default tobuild.properties
)