Note that this example uses Tekton Pipeline resources, so make sure you've installed that first!
In this example you will use Triggers to create a PipelineRun and PipelineResource that simply clones a GitHub repository and prints a couple of messages.
- Create the resources for the example
kubectl apply -f role-resources/secret.yaml
kubectl apply -f role-resources/serviceaccount.yaml
kubectl apply -f role-resources/clustertriggerbinding-roles
kubectl apply -f role-resources/triggerbinding-roles
kubectl apply -f triggertemplates/triggertemplate.yaml
kubectl apply -f triggerbindings/triggerbinding.yaml
kubectl apply -f triggerbindings/triggerbinding-message.yaml
kubectl apply -f eventlisteners/eventlistener.yaml
- Check required pods and services are available and healthy
tekton:examples user$ kubectl get svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
el-listener ClusterIP 10.100.151.220 <none> 8080/TCP 48s <--- this will receive the event
tekton-pipelines-controller ClusterIP 10.103.144.96 <none> 9090/TCP 8m34s
tekton-pipelines-webhook ClusterIP 10.96.198.4 <none> 443/TCP 8m34s
tekton-triggers-controller ClusterIP 10.102.221.96 <none> 9000/TCP 7m56s
tekton-triggers-webhook ClusterIP 10.99.59.231 <none> 443/TCP 7m56s
tekton:examples user$ kubectl get pods
NAME READY STATUS RESTARTS AGE
el-listener-5c744f47c5-m9kdn 1/1 Running 0 78s
tekton-pipelines-controller-55c6b5b9f6-qsdnn 1/1 Running 0 9m4s
tekton-pipelines-webhook-6794d5bcc8-p4p8c 1/1 Running 0 9m4s
tekton-triggers-controller-594d4fcfdf-l4c9m 1/1 Running 0 6m57s
tekton-triggers-webhook-5985cfcfc5-cq5hp 1/1 Running 0 6m50s
- Apply an example pipeline and tasks that will be run (in this case named
example-pipeline
):
kubectl apply -f example-pipeline.yaml
This is intentionally very simple and operates on a created Git resource. The trigger created Git resource will have the repository URL and revision parameters.
- Send a payload to the listener
Assuming we have a listener available at localhost:8080
(and port-forwarded
for this example, with
kubectl port-forward $(kubectl get pod -o=name -l eventlistener=listener) 8080
),
run the following command in your shell of choice or using Postman:
curl -X POST \
http://localhost:8080 \
-H 'Content-Type: application/json' \
-H 'X-Hub-Signature: sha1=2da37dcb9404ff17b714ee7a505c384758ddeb7b' \
-d '{
"repository":
{
"url": "https://github.com/tektoncd/triggers.git"
}
}'
NOTE: defaults in triggertemplates/triggertemplate.yaml
like master
for gitrevision
are leveraged here to
satisfy missing items in the POST body like head_commit.id
.
- Observe created PipelineRun
tekton:examples user$ kubectl get pipelinerun
NAME SUCCEEDED REASON STARTTIME COMPLETIONTIME
simple-pipeline-runxl8rm Unknown Running 1s
tekton:examples user$ kubectl get pods
...
simple-pipeline-runnd654-say-hello-djs4v-pod-64cfef 0/2 Init:0/2 0 1s
...
- A
PipelineRun
with an embeddedresourceSpec
was created for us using our POST data and the specified Tekton Pipeline:
---
spec:
params:
- name: message
value: Hello from the Triggers EventListener!
- name: contenttype
value: application/json
pipelineRef:
name: simple-pipeline
resources:
- name: git-source
resourceSpec:
params:
- name: revision
value: master
- name: url
value: https://github.com/tektoncd/triggers.git
type: git
timeout: 1h0m0s
- The three Pods (one per Task) finish their work and the PipelineRun is marked as successful:
tekton:examples user$ kubectl logs simple-pipeline-runn4qps-say-hello-29ztk-pod-118fbd --all-containers
...
Hello Triggers!
tekton:examples user$ kubectl logs simple-pipeline-runn4qps-say-message-f64qf-pod-80fb58 --all-containers
...
Hello from the Triggers EventListener!
tekton:examples user$ kubectl logs simple-pipeline-runn4qps-say-bye-7xbk2-pod-116608 --all-containers
...
Goodbye Triggers!
tekton:examples user$ kubectl get pipelinerun
NAME SUCCEEDED REASON STARTTIME COMPLETIONTIME
simple-pipeline-runn4qps True Succeeded 5m 4m
kubectl delete all -l tekton.dev/eventlistener=listener
We hope you've found this example useful, please do get involved and contribute more useful examples!