Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/sombriks/gh-actions-playground
- Owner: sombriks
- License: mit
- Created: 2023-12-11T02:17:59.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-08-23T22:53:53.000Z (5 months ago)
- Last Synced: 2024-11-16T04:46:16.943Z (2 months ago)
- Topics: cicd, examples, ghactions, pipelines, workflows
- Homepage: https://sombriks.com/blog/0061-github-actions-recipes/
- Size: 299 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
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 workflowMore 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 trueMore 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 stepsMore 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] oneMore 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