Skip to content

Github Actions

(https://github.com/features/actions) let's you automate, customize, and execute your software development workflows right in your repository.

Actions

Checkout V2

(https://github.com/actions/checkout)is an action for checking out a repo.

Example usage:

jobs:
  molecule:
    runs-on: ubuntu-latest
    strategy:
      fail-fast: false
    steps:
      - name: Checkout
        uses: actions/checkout@v2
        with:
          submodules: true

GitHub Action for GitHub Push

(https://github.com/ad-m/github-push-action)is a GitHub action to push back to repository eg. update code.

Example usage:

jobs:
  molecule:
    runs-on: ubuntu-latest
    strategy:
      fail-fast: false
    steps:
      - name: Push changes
        uses: ad-m/github-push-action@master
        with:
          github_token: ${{ secrets.GITHUB_TOKEN }}
          branch: ${{ github.ref }}

This will push the commited changes to the current branch.

Configuration

Concurrency

You can use concurrency to cancel any in-progress job or run. Example:

concurrency:
  group: docs-${{ github.head_ref }}
  cancel-in-progress: true

This is useful to cancel previous jobs if new commits are pushed, which saves minutes, energy and avoids conflicts when pushing changes during the action.

Secrets

Store file as secret

If you want to store a file (multiline, binary...) as a secret, first encode it with base64:

base64 -i < {{ file_path }} | tr -d '\n' | xclip -i -selection clipboard

Then paste it to a new secret. To restore the file diring the workflow, add:

- name: restore file
  run: echo ${{ secrets.SECRET }} | base64 -d > {{ file_path }}

Steps

Condition execution depending on another step outcome

To allow a step to fail without that implying failing the whole workflow and then execute some steps according to the result, do:

- name: commitizen
  id: commitizen
  continue-on-error: true
  uses: commitizen-tools/commitizen-action@0.11.0
  with:
    github_token: ${{ secrets.GITHUB_TOKEN }}

- name: Some other task
  if: steps.commitizen.outcome == 'success'
  run: something