3 - Environments and Secrets
In this lab you will use environments and secrets.
Duration: 10-15 minutes
References:
3.1 Create new encrypted secrets
- Follow the guide to create a new environment called
UAT
, add a reviewer and an environment variable.- Creating an environment
- Add required reviewers
- Create an encrypted secret in the environment called
MY_ENV_SECRET
.
- Follow the guide to create a new repository secret called
MY_REPO_SECRET
- Open the workflow file environments-secrets.yml
- Edit the file and copy the following YAML content as a first job (after the
jobs:
line): ```YAML
use-secrets: name: Use secrets runs-on: ubuntu-latest if: $ steps: - name: Hello world action with secrets uses: actions/hello-world-javascript-action@main with: # Set the secret as an input who-to-greet: $ env: # Or as an environment variable super_secret: $ - name: Echo secret is redacted in the logs run: | echo Env secret is $ echo Warning: GitHub automatically redacts secrets printed to the log, echo but you should avoid printing secrets to the log intentionally. echo $ | sed ‘s/./& /g’
6. Update the workflow to also run on push and pull_request events
```YAML
on:
push:
branches: [main]
pull_request:
branches: [main]
workflow_dispatch:
- Commit the changes into the
main
branch - Go to
Actions
and see the details of your running workflow
3.2 Add a new workflow job to deploy to UAT environment
- Open the workflow file environments-secrets.yml
- Edit the file and copy the following YAML content between the test and prod jobs (before the
use-environment-prod:
line): ```YAML
use-environment-uat: name: Use UAT environment runs-on: ubuntu-latest if: $ needs: use-environment-test
environment:
name: UAT
url: 'https://uat.github.com'
steps:
- name: Step that uses the UAT environment
run: echo "Deployment to UAT..."
env:
env_secret: $
7. Inside the `use-environment-prod` job, replace `needs: use-environment-test` with:
```YAML
needs: use-environment-uat
- Commit the changes into the
main
branch - Go to
Actions
and see the details of your running workflow - Review your deployment and approve the pending UAT job
- Go to
Settings
>Environments
and update thePROD
environment created to protect it with approvals (same as UAT)