Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/sombriks/gh-actions-playground

small examples of interesting github actions combinations
https://github.com/sombriks/gh-actions-playground

cicd examples ghactions pipelines workflows

Last synced: 10 days ago
JSON representation

small examples of interesting github actions combinations

Awesome Lists containing this project

README

        

# My gh-actions playground

Small examples of interesting GitHub actions combinations.

## How to run this playground

Most workflows where intentionally left with `workflow_dispatch` so they don't
run by accident on every commit. Not as if it was a big issue, since they do
_mostly nothing_ by design.

But you can also run them using the [act][0] command line tool, which emulates
the GitHub actions environment in a quite near the real thing way.

So, the three big ways to run a workflow:

- Visit [the actions page][1] and run them by hand
- Use the [GitHub CLI][2]: `gh workflow run .github/workflow/00-hello-world.yml`
- Use act: `act -W .github/workflows/00-hello-world.yml`

## Overview

GitHub Actions is what happens when yaml and bash decide to have a child.

The workflow files are used to common integration routines: run tests, check the
quality of code, perform any chore that can be automatized, scripted.

## Workflow file syntax

Each workflow file must define:

- _name_ (unique across all workflows)
- _on_ (event)
- _jobs_ (actual work)

### Events

What could possibly trigger an workflow?

- You hit a button
- A git push or something
- Another workflow

More possibilities [here][3].

### Jobs

- Give cool names to your jobs, not just _build_
- One workflow can house several jobs
- Jobs will run in **parallel** unless you do something about it
- make jobs `needs` other jobs
- run jobs `if` some condition is true

More details [here][4].

## 00 - [smallest possible][5]

- [Manual dispatch][6]
- [Echoes 'hello world'][7]

![image-manual-dispatch.png][8]

## 01 - [occurs on every git push or merge][9]

- The 101 of CI
- [Echoes 'hello word from _some branch_'][10]

![image-on-push.png][11]

## 02 - [have two jobs][12]

- Remember, runs in [parallel][13]!
- Pretty much like two distinct workflows, but sharing rent on the same workflow
file. Useful in more complex builds.

![two-jobs.png][14]

## 03 - [have two jobs but in sequence][15]

- Make sure the second [needs][16] the first

![job-needs.png][17]

## 04 - [make one job use another workflow][18]

- This is why [workflow_call][19] exists
- Don't misread as [workflow_dispatch][20], it's another thing
- Quite similar to what we do when [consuming actions from marketplace][21]

![use-another-workflow.png][22]

## 05 - [jobs inputs][23]

- Both `workflow_call` and `workflow_dispatch` can receive inputs
- Use [inputs][24] inside the steps inside jobs

![job-input.png][25]

## 06 - [jobs outputs][26]

- You can define [outputs values][27] so other jobs can check on
- For dynamic outputs check the `$GITHUB_OUTPUT` variable usage

![job-output.png][28]

## 07 - [environment variables][29]

- The repository itself can contribute with custom variables
- Use [GitHub CLI][2] to list, set or remove [repository variables][30]
- If using [act][0], create a `.vars` file to define variables
- With `act` there is also a `.env` file but we talk about it later

```bash
# ~/github/gh-actions-playground/.vars
X="some value from vars"
```

![repository-variables.png][31]

## 08 - [secrets][32]

- Very useful to interact with the world outside the repo
- Define secrets via web console settings
- Or use GitHub CLI to create them, pretty handy!
- With act, just put it inside a `.secrets` file!
- Note: **secret values are [not echoed][33] on logs**

```bash
# ~/github/gh-actions-playground/.secrets
X=10
MY_SECRET="not telling you!"
```

```bash
[sombriks@thanatos gh-actions-playground](main)$ gh secret set X
? Paste your secret **

✓ Set Actions secret X for sombriks/gh-actions-playground
```

## 09 - [steps][34]

- Simplest step is a `run` command
- Complex ones `uses` external actions from [marketplace][21]
- Give proper `names` for your steps

More details of what is possible [here][35]

## 10 / 11 - define outputs for reusable workflows

- Define a [reusable workflow][43] with an output section
- Define a workflow with a [job consuming the reusable][44] one

More info [here][45] and [here][46].

## 12 - create a commit

- Useful to modify something in the repo as [part of the workflow][48]
- Does not trigger other workflows
- Can manipulate several branches, see [checkout action][47] for details.

## 13 - create comments

- Useful to report some important result as [part of the workflow][49]
- Event needed is a pull request

## 14 - create a reusable action

The key difference is a reusable workflow will eat an entire job, while a
reusable action only a step.

Actions can't access env or secrets directly, you must pass inputs.

You can define custom actions locally to the repo or use 3rd party ones.

[More details][51].

## Noteworthy 3rd party actions

- This is why GitHub Actions it's better than other CI tools from other vendors
- Rich ecosystem

- [Java][36]
- [Node][37]
- [Docker][38]
- [AWS Actions][39]
- [Upload][40]
- [Download][41]
- [Checkout][42]
- [Cache][50]

There's much, much more!

## Writing good CI/CD pipelines

- Run tests
- Publish packages or images
- For GitOps, update _desired state_ on IaC manifests files

## Conclusion

This playground is intended to be simple, educational.

It's up to you combine the techniques sampled here to build real things.

[0]: https://github.com/nektos/act?tab=readme-ov-file#installation-through-package-managers

[1]: https://github.com/sombriks/gh-actions-playground/actions

[2]: https://cli.github.com/

[3]: https://docs.github.com/en/actions/using-workflows/events-that-trigger-workflows

[4]: https://docs.github.com/en/actions/using-jobs/using-conditions-to-control-job-execution

[5]: .github/workflows/00-hello-world.yml

[6]: https://github.com/sombriks/gh-actions-playground/actions/workflows/00-hello-world.yml

[7]: https://github.com/sombriks/gh-actions-playground/actions/runs/7162121699/job/19498652966#step:2:5

[8]: imgs/manual-dispatch.png

[9]: .github/workflows/01-it-happens-on-push.yml

[10]: https://github.com/sombriks/gh-actions-playground/actions/runs/7162222469/job/19498893130#step:2:5

[11]: imgs/on-push.png

[12]: .github/workflows/02-two-jobs.yml

[13]: https://github.com/sombriks/gh-actions-playground/actions/runs/7175366895/job/19538528783

[14]: imgs/two-jobs.png

[15]: .github/workflows/03-sequence-jobs.yml

[16]: https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idneeds

[17]: imgs/job-needs.png

[18]: .github/workflows/04-use-workflow.yml

[19]: https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#onworkflow_call

[20]: https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#onworkflow_dispatch

[21]: https://github.com/marketplace?type=actions

[22]: imgs/use-another-workflow.png

[23]: .github/workflows/05-job-inputs.yml

[24]: https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#example-of-onworkflow_dispatchinputs

[25]: imgs/job-input.png

[26]: .github/workflows/06-job-outputs.yml

[27]: https://docs.github.com/en/actions/using-jobs/defining-outputs-for-jobs

[28]: imgs/job-output.png

[29]: .github/workflows/07-environment-variable.yml

[30]: https://docs.github.com/en/actions/learn-github-actions/variables#using-contexts-to-access-variable-values

[31]: imgs/repository-variables.png

[32]: .github/workflows/08-using-secrets.yml

[33]: https://github.com/sombriks/gh-actions-playground/actions/runs/7189569566/job/19581317663#step:2:2

[34]: .github/workflows/09-steps.yml

[35]: https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idsteps

[36]: https://github.com/marketplace/actions/setup-java-jdk

[37]: https://github.com/marketplace/actions/setup-node-js-environment

[38]: https://github.com/marketplace/actions/build-and-push-docker-images

[39]: https://github.com/aws-actions

[40]: https://github.com/marketplace/actions/upload-a-build-artifact

[41]: https://github.com/marketplace/actions/download-a-build-artifact

[42]: https://github.com/marketplace/actions/checkout

[43]: ./.github/workflows/10-job-outputs.yml

[44]: ./.github/workflows/11-use-job-outputs.yml

[45]: https://stackoverflow.com/a/73702649/420096

[46]: https://docs.github.com/en/actions/using-workflows/reusing-workflows#using-outputs-from-a-reusable-workflow

[47]: https://github.com/actions/checkout

[48]: .github/workflows/12-create-a-commit.yml

[49]: .github/workflows/13-comment-a-pr.yml

[50]: https://github.com/actions/cache

[51]: https://docs.github.com/en/actions/sharing-automations/creating-actions/creating-a-composite-action#creating-an-action-metadata-file