yq/usage/github-action.md
2022-08-14 10:36:23 +10:00

2.5 KiB

GitHub Action

Guide

You can use yq in your GitHub action, for instance:

  - uses: actions/checkout@v2
  - name: Get SDK Version from config
    id: lookupSdkVersion
    uses: mikefarah/yq@master
    with:
      cmd: yq '.renutil.version' 'config.yml'
  - name: Restore Cache
    id: restore-cache
    uses: actions/cache@v2
    with:
      path: ../renpy
      key:  ${{ runner.os }}-sdk-${{ steps.lookupSdkVersion.outputs.result }}
      restore-keys: |
        ${{ runner.os }}-sdk        
  # ... more

The yq action sets a result variable in its output, making it available to subsequent steps. In this case it's available as steps.lookupSdkVersion.outputs.result.

Details of how the GitHub action itself is configured can be found here

If you enable step debug logging, you can see additional information about the exact command sent as well as the response returned within the GitHub Action logs.

Thanks @devorbitus!

Environment variables with Github Actions:

GitHub Actions escape and interpolate rules can conflict with some yq syntax. Here is an example of how to quote a variable that could contain dots in a query path (more usage context: ambanum/OpenTermsArchive#899).

  - name: Get an entry with a variable that might contain dots or spaces
    id: get_username
    uses: mikefarah/yq@master
    with:
      cmd: yq '.all.children.["${{ matrix.ip_address }}"].username' ops/inventories/production.yml
  - name: Reuse a variable obtained in another step
    run: echo ${{ steps.get_username.outputs.result }}

Thanks @MattiSG!

Troubleshooting

Write in-place file permission errors

The default user in github action dockerfiles (at the time of writing) seems to be 1001. This is what the yq github action is configured to run with (see the docker file here)

There's a working example defined here and you can see the Github action results here

If you need to set the action to another user, follow the advice here.