Skip to content

Latest commit

 

History

History
102 lines (66 loc) · 4.86 KB

File metadata and controls

102 lines (66 loc) · 4.86 KB

Post to Slack task helper

This Task posts a message to the Slack channel(s) integrated with your Continuous Delivery toolchain.

The task retrieves a Slack integration(s) from the Toolchain, filtered on the Slack domain (if passed as a parameter) and posts the message to the corresponding channel(s).

The message can be:

  • passed as a parameter

    • a static Slack formatted JSON payload
    • a static text message (that will be converted to Slack JSON payload)
  • dynamically injected

    • by a bash script
    • based on the output of previous task(s) stored in the PVC
  • default message if not set

    Default value

Prerequisites

Slack

Create a Slack Webhook.

Toolchain

Add a Slack integration to your Continuous Delivery toolchain

Install the Task

  • 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 slack.

Parameters

  • domain: (optional) the Slack domain to send the message to. If not set, the message will be posted to the Slack integration(s) as defined in the Toolchain.
  • channel: (optional) the Slack channel to send the message to. When set, overrides the default channel as set in the Slack Webhook URL. Only non-private channel can override the default channel. If the target channel is a private channel, the Slack Webhook URL in the Slack toolchain integration card needs to be updated.
  • message-format: (optional) the format of the message. Value: text(default) or JSON.
  • message-script: (optional) Shell script that provides messsage content.
  • message: (optional) the message to send to Slack.
  • exit-on-error: flag (true | false) to indicate if the task should fail or continue if unable to process the message or post to Slack (default false).
  • post-to-slack-step-image: (optional) image to use for the post-to-slack step. Default to icr.io/continuous-delivery/pipeline/pipeline-base-ubi:3.2

Workspaces

  • workspace: A workspace that contain data useful for the script/slack message resolution. Should be marked as optional when Tekton will permit it.

Outputs

None.

Usage

The sample sub-directory contains an EventListener and Pipeline definition that you can include in your Tekton pipeline configuration to run an example of the slack-post-message task.

  1. Create or update a Toolchain so it includes:

    • a Slack integration
    • the repository containing this tekton task
    • a Tekton pipeline definition

    Toolchain overview

  2. Add the definitions of this task and the sample (slack and slack/sample paths)

    Tekton pipeline definitions

  3. Add the environment properties as needed:

    • domain (optional) the Slack domain to send the message to.
    • channel (optional) the channel to post to (overrides the dafault channel as set in the Slack webhook).
    • message-format (optional) the format of the message (text or JSON).
    • message-script (optional) Shell script that provides messsage content.
    • message (optional) the message to post to Slack.

Note: when using JSON format, the message is posted as-is to Slack.

Tekton pipeline environment properties

  1. Create a manual trigger to start the sample listener

    Tekton pipeline sample trigger

  2. Run the pipeline

  3. The message is posted to Slack

    sample message

  4. Optional: check the execution log

    Tekton pipeline sample trigger

  5. Optionnal: Create a message using snippet

    a) Define the snippet in the message-script environment property of the pipeline

    message-script: `echo 'Message sent from PipelineRun' ${PIPELINE_RUN_NAME}; echo 'uid:' ${PIPELINE_RUN_ID}; echo 'buildNumber:' ${BUILD_NUMBER};`
    

    Note: this could also be done in the trigger-template or pipeline definition

    Tekton pipeline sample trigger

    b) After running the pipeline, a new message like the following should have been posted to the Slack channel

    sample message using snippet

    c) Check the execution log

    Tekton pipeline sample snippet message