This is a fork of https://github.com/toko-bifrost/ms-teams-deploy-card with the following changes:
- Ignore skipped steps when evaluating the result of the workflow.
- Write the name of the workflow in the Teams card.
- Fix wrong input names in readme
- Write the branch instead of the commit hash in the Teams card.
- Add option to ignore failures caused by cancelling the workflow.
- Properly report matrix job status (see Note when using matrix jobs).
When modifying the js code in this repository, the following steps need to be executed:
- Clone project
- Run
nvm use
(install node version manager if not installed) - Run
yarn install
(the project fails to compile when using npm install) - Make your changes
- Run
yarn ncc
to compile the changes - Commit the changed js files and everything in dist/
A comprehensive notification card in Microsoft Teams for your deployments.
- Add
MS_TEAMS_WEBHOOK_URI
on your repository's configs on Settings > Secrets. It is the webhook URI of the dedicated Microsoft Teams channel for notification.
- Add a new
step
on your workflow code belowactions/checkout@v2
:
name: MS Teams Deploy Card
on: [push]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
# this is the new step
- uses: freenet-actions/ms-teams-deploy-card@master
if: always()
with:
github-token: ${{ github.token }}
webhook-uri: ${{ secrets.MS_TEAMS_WEBHOOK_URI }}
The GitHub API makes it difficult to identify a specific matrix job from an action. To properly pass the matrix job status to the action, add the following step to the end of your workflow file:
- run: echo "ms_teams_notification_job_status=${{ job.status }}" >> "$GITHUB_ENV"
if: always()
The notification action will pick up the environment variable and use it to determine the status of the matrix job.
Name | Required | Default | Description |
---|---|---|---|
github-token |
true |
None | This can be set to the following: - ${{ github.token }} - ${{ secrets.GITHUB_TOKEN }} - ${{ secrets.CUSTOM_TOKEN }} |
webhook-uri |
true |
None | The value of MS_TEAMS_WEBHOOK_URI |
card-layout-start |
false |
complete |
Card layout on start (i.e. complete , cozy , compact ) |
card-layout-exit |
false |
compact |
Card layout on exit (i.e. complete , cozy , compact ) |
show-on-start |
false |
true |
Show an MS Teams card upon starting this Github Actions job |
show-on-exit |
false |
true |
Show an MS Teams card upon exiting this Github Actions job, regardless if it's a successful or a failed exit |
show-on-failure |
false |
false |
Show an MS Teams card upon exiting this Github Actions job and status is not SUCCESS ; This will override any boolean value of show-on-exit , e.g. with show-on-exit=false and show-on-failure=true , the notification card will still proceed upon job failure |
ignore-cancel |
false |
false |
Don't show an MS Teams card upon exiting this Github Actions job and status is CANCELLED . |
Name | Required | Default | Description |
---|---|---|---|
environment |
false |
None | Name of the environment, e.g. development , production (won't be included in the card if none) |
timezone |
false |
"UTC" |
A valid database timezone name, e.g. Australia/Sydney |
enable-view-status-action |
false |
true |
Enable an action to view the deployment status |
enable-review-diffs-action |
false |
true |
Enable an action to review commit diffs |
view-status-action-text |
false |
"View build/deploy status" |
Customize action text in viewing the deployment status |
review-diffs-action-text |
false |
"Review commit diffs" |
Customize action text in reviewing commit diffs |
custom-actions |
false |
null |
Add more actions; must be a YAML-parseable multiline string with text and url pairs |
Name | Required | Default | Description |
---|---|---|---|
custom-facts |
false |
null |
YAML-parseable multiline string defining a list of objects with name and value to display alongside existing facts. Only for complete layout. |
include-files |
false |
true |
Include the list of files when layout is set to complete |
allowed-file-len |
false |
7 |
Allowed number of changed files to display, when include-files is set to true |
- Clone this repository.
- Install JS dependencies via
yarn install
ornpm install
. - Before pushing you changes, execute
yarn ncc
(ornpm run ncc
) to create a build ondist
. - Do not remove the
dist
repository. Ever. - Check the Actions tab for the errors if there are any.
-
Avoid naming your secrets with the prefix
GITHUB_
as secrets are being used as environment variables, and they are reserved for Github Actions' use only. Better stick withCI_GITHUB_TOKEN
. -
As this is still in development, always use the working latest version from the
Releases
, as they have more bug fixes and added features. -
If you are going to set
custom-facts
(only forcomplete
layout) andcustom-actions
(on bothcozy
andcomplete
layout), look out for the pipe symbol (|
). Github Actions only acceptstring
,number
, andboolean
as parameters on job steps. To bypass this restriction and to instill YAML list formatting, we have to set it with a YAML-parseable multiline string containing a YAML list of objects withname
andvalue
oncustom-facts
, andtext
andurl
(i.e. must be a valid URI format) oncustom-actions
. If there is an error in YAML parsing, no custom facts/actions will be appended.
- uses: freenet-actions/ms-teams-deploy-card@master
with:
github-token: ${{ github.token }}
webhook-uri: ${{ secrets.MS_TEAMS_WEBHOOK_URI }}
custom-facts: |
- name: Custom Fact Name 1
value: Custom Fact Value 1
- name: Pull Request
value: "http://example.com/${{ github.run_id }}"
custom-actions: |
- text: View PR
url: "http://valid.uri.com"
- text: View CI
url: "http://example.com/${{ github.run_id }}"
-
Always set this job with
if: always()
when there are steps betweenactions/checkout@v2
and this job. -
Status
IN_PROGRESS
upon job completion means you have set thejobs.<job_id>.name
. It is encouraged to exclude setting thejobs.<job_id>.name
. It is becauseGITHUB_JOB
is set withjobs.<job_id>
, and the Github API gives off the value ofjobs.<job_id>.name
, if set. Thus, there is no way to match the current job with the ones in the Github API upon post-job conclusion. -
As much as possible, always set this Github action right after
actions/checkout@v2
and before any job steps. The following diagram shows when this job if going to trigger if done the right way.
job
|-- actions/checkout@v2
|-- ms-teams-deploy-card (fires notification of job initiation, if allowed)
|-- step 1
|...more steps
|-- step N
|-- post ms-teams-deploy-card
* checks the conclusion based on the previous completed steps
* fires notification if allowed in the settings
|-- post actions/checkout@v2