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
will be synced with
[`v1beta1` ](https://github.com/tektoncd/catalog/tree/v1beta1 ) on 2020,
15th 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
2019-10-17 16:15:37 +00:00
cluster. A directory can hold more than one task (e.g. [`golang` ](golang )).
2019-04-25 21:20:02 +00:00
2020-03-24 15:08:49 +00:00
_See [our project roadmap ](roadmap.md )._
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 )._