2019-04-26 16:33:16 +00:00
# Tekton Catalog
2019-04-25 21:20:02 +00:00
2020-04-01 10:34:22 +00:00
**If you want `v1alpha1` resources, you need to go to the
2020-05-07 11:53:59 +00:00
[`v1alpha1` ](https://github.com/tektoncd/catalog/tree/v1alpha1 )
branch. The
[`master` ](https://github.com/tektoncd/catalog/tree/master ) branch
2020-06-19 14:08:03 +00:00
is synced with
[`v1beta1` ](https://github.com/tektoncd/catalog/tree/v1beta1 ) since
2020, 19th June.**
2020-04-01 10:34:22 +00:00
2019-04-26 16:33:16 +00:00
This repository contains a catalog of `Task` resources (and someday
`Pipeline` s and `Resource` s), which are designed to be reusable in many
pipelines.
2019-04-25 21:20:02 +00:00
Each `Task` is provided in a separate directory along with a README.md and a
Kubernetes manifest, so you can choose which `Task` s to install on your
2020-07-13 09:56:42 +00:00
cluster. A directory can hold one task and multiple versions.
2019-04-25 21:20:02 +00:00
2020-03-24 15:08:49 +00:00
_See [our project roadmap ](roadmap.md )._
2020-07-13 09:56:42 +00:00
## Catalog Structure
1. Each resource follows the following structure
```
./task/ 👈 the kind of the resource
/argocd 👈 definition file must have same name
/0.1
/OWNERS 👈 owners of this resource
/README.md
/argocd.yaml 👈 the file name should match the resource name
/samples/deploy-to-k8s.yaml
/0.2/...
/golang-build
/OWNERS
/README.md
/0.1
/README.md
/golang-build.yaml
/samples/golang-build.yaml
```
2. Resource YAML file includes following changes
* Labels include the version of the resource.
* Annotations include `minimum pipeline version` supported by the resource,
`tags` associated with the resource and `displayName` of the resource
```yaml
labels:
app.kubernetes.io/version: "0.1" 👈 Version of the resource
annotations:
tekton.dev/pipelines.minVersion: "0.12.1" 👈 Min Version of pipeline resource is compatible
tekton.dev/tags: "ansible, cli" 👈 Comma separated list of tags
tekton.dev/displayName: "Ansible Tower Cli" 👈 displayName can be optional
spec:
description: |-
ansible-tower-cli task simplifies
workflow, jobs, manage users... 👈 Summary
Ansible Tower (formerly ‘ AWX’ ) is a ...
```
2020-03-24 15:08:49 +00:00
2019-04-25 21:20:02 +00:00
## `Task` Kinds
There are two kinds of `Task` s:
1. `ClusterTask` with a Cluster scope, which can be installed by a cluster
operator and made available to users in all namespaces
2. `Task` with a Namespace scope, which is designed to be installed and used
only within that namespace.
`Task` s in this repo are namespace-scoped `Task` s, but can be installed as
`ClusterTask` s by changing the `kind` .
2019-10-17 16:15:37 +00:00
2019-04-25 21:20:02 +00:00
## Using `Task`s
First, install a `Task` onto your cluster:
```
2020-03-04 15:23:34 +00:00
$ kubectl apply -f golang/build.yaml
task.tekton.dev/golang-build created
2019-04-25 21:20:02 +00:00
```
You can see which `Task` s are installed using `kubectl` as well:
```
$ kubectl get tasks
2020-03-04 15:23:34 +00:00
NAME AGE
golang-build 3s
2019-04-25 21:20:02 +00:00
```
With the `Task` installed, you can define a `TaskRun` that runs that `Task` ,
being sure to provide values for required input parameters and resources:
```
2020-03-10 14:04:04 +00:00
apiVersion: tekton.dev/v1beta1
2019-04-25 21:20:02 +00:00
kind: TaskRun
metadata:
name: example-run
spec:
taskRef:
2020-03-04 15:23:34 +00:00
name: golang-build
2020-03-10 14:04:04 +00:00
params:
- name: package
value: github.com/tektoncd/pipeline
workspaces:
- name: source
persistentVolumeClaim:
claimName: my-source
2019-04-25 21:20:02 +00:00
```
Next, create the `TaskRun` you defined:
```
$ kubectl apply -f example-run.yaml
taskrun.tekton.dev/example-run created
```
You can check the status of the `TaskRun` using `kubectl` :
```
$ kubectl get taskrun example-run -oyaml
2020-03-10 14:04:04 +00:00
apiVersion: tekton.dev/v1beta1
2019-04-25 21:20:02 +00:00
kind: TaskRun
metadata:
name: example-run
spec:
...
status:
completionTime: "2019-04-25T18:10:09Z"
conditions:
- lastTransitionTime: "2019-04-25T18:10:09Z"
status: True
type: Succeeded
...
```
## Contributing and Support
If you want to contribute to this repository, please see our [contributing ](./CONTRIBUTING.md ) guidelines.
2019-10-31 13:40:01 +00:00
If you are looking for support, enter an [issue ](https://github.com/tektoncd/catalog/issues/new ) or join our [Slack workspace ](https://github.com/tektoncd/community/blob/master/contact.md#slack )
2019-10-17 16:15:37 +00:00
## Status of the Project
This project is still under active development, so you might run into
[issues ](https://github.com/tektoncd/catalog/issues ). If you do,
please don't be shy about letting us know, or better yet, contribute a
fix or feature. Its folder structure is not yet set in stone either.
2020-03-24 15:08:49 +00:00
_See [our project roadmap ](roadmap.md )._