5a3e5f630f
- Initially all tags were mapped to categories in Hub, for e.g. config.yaml: https://github.com/tektoncd/hub/blob/master/config.yaml, so whenever a new tag was added in a task it was mapped to a category called `others`. Hence before every release we had to manually map these new tags to some category, hence after the discussion in Catalog and Hub WG, a proposal was created for adding a category as an annotation. - PR to update the TEP-0003-Tekton Catalog Organization: https://github.com/tektoncd/community/pull/352 Signed-off-by: Puneet Punamiya <ppunamiy@redhat.com> |
||
---|---|---|
.. | ||
samples | ||
git-rebase.yaml | ||
README.md |
Git Task
This Task
is Git task to work with repositories used by other tasks
in your Pipeline.
git-rebase
This task will rebase
the branch based
on the user input. Before rebase, if squashing
of the commits is required,
then it can be done by providing the squash count
i.e number of commits to squash.
Workspaces
- source: A workspace that contains the fetched git repository.
Parameters
- SQUASH_COUNT: Number of commits to squash in the branch. (only required if squashing needs to be performed).
- COMMIT_MSG: Commit message to add in commit after the squashing is done (only required if squashing needs to be performed).
- GIT_USER_NAME: Git user name to use for rebase (required).
- GIT_USER_EMAIL: Git user email to use for rebase (required).
- PULL_REMOTE_NAME: Git remote name from which we have to pull
and rebase.(default:
origin
). - PULL_REMOTE_URL: Git remote URL from which we have to pull and rebase (required to set remote).
- PULL_BRANCH_NAME: Git branch name from which we have to pull and rebase (required).
- PUSH_REMOTE_NAME: Git remote name to push after rebase(default:
origin
). - PUSH_REMOTE_URL: Git remote URL to push after rebase(required).
- PUSH_BRANCH_NAME: Git branch name to push after rebase (required).
Results
- commit: The precise commit SHA after the rebase.
Usage
This task needs authentication to git in order to push after the rebase.
This can be done via secrets
and service account
. Refer this
example to create secret and service account for the git authentication.
Git Rebase pipeline has two tasks, one to clone a git repository in the provided workspace and other to perform rebase operation. Here, git-clone task is used to clone the repository.
A workspace called "shared-workspace" is passed first to the git-clone
Task for the code to be checked out on and then to the git-rebase
Task
to perform the rebase operation.
Remote name, Remote URL and Branch name needs to provided in the input to set the remote in order to perfrom push and pull operations.
Git Rebase pipeline can be referred to
create a pipeline
and pipelinerun
.
NOTE
-
If
two factor authentication
is enabled in your git account, thenaccess-token
for the respective git platform must be provided in thepassword
field while adding secrets. -
In the params for
git-clone
task, make sure that param value fordepth
must be greater than param value forSQUASH_COUNT
ingit-rebase
task. -
If there are chances for
merge conflicts
, then that needs to resolved before doing rebase through this task as task will fail, if any merge conflict is found.