generated from skills/hello-github-actions
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Scott Gordon
authored
Jul 8, 2024
0 parents
commit 5322cff
Showing
18 changed files
with
703 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
version: 2 | ||
updates: | ||
- package-ecosystem: "github-actions" | ||
directory: "/" | ||
schedule: | ||
interval: "monthly" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
0 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
<!-- The readme will be displayed. --> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
## Step 1: Create a workflow file | ||
|
||
_Welcome to "Hello GitHub Actions"! :wave:_ | ||
|
||
**What is _GitHub Actions_?**: GitHub Actions is a flexible way to automate nearly every aspect of your team's software workflow. You can automate testing, continuously deploy, review code, manage issues and pull requests, and much more. The best part, these workflows are stored as code in your repository and easily shared and reused across teams. To learn more, check out these resources: | ||
|
||
- The GitHub Actions feature page, see [GitHub Actions](https://github.com/features/actions). | ||
- The "GitHub Actions" user documentation, see [GitHub Actions](https://docs.github.com/actions). | ||
|
||
**What is a _workflow_?**: A workflow is a configurable automated process that will run one or more jobs. Workflows are defined in special files in the `.github/workflows` directory and they execute based on your chosen event. For this exercise, we'll use a `pull_request` event. | ||
|
||
- To read more about workflows, jobs, and events, see "[Understanding GitHub Actions](https://docs.github.com/en/actions/learn-github-actions/understanding-github-actions)". | ||
- If you want to learn more about the `pull_request` event before using it, see "[pull_request](https://docs.github.com/en/developers/webhooks-and-events/webhooks/webhook-events-and-payloads#pull_request)". | ||
|
||
To get you started, we ran an Actions workflow in your new repository that, among other things, created a branch for you to work in, called `welcome-workflow`. | ||
|
||
### :keyboard: Activity: Create a workflow file | ||
|
||
1. Open a new browser tab, and navigate to this same repository. Then, work on the steps in your second tab while you read the instructions in this tab. | ||
1. Create a pull request. This will contain all of the changes you'll make throughout this part of the course. | ||
|
||
Click the **Pull Requests** tab, click **New pull request**, set `base: main` and `compare:welcome-workflow`, click **Create pull request**, then click **Create pull request** again. | ||
|
||
1. Navigate to the **Code** tab. | ||
1. From the **main** branch dropdown, click on the **welcome-workflow** branch. | ||
1. Navigate to the `.github/workflows/` folder, then select **Add file** and click on **Create new file**. | ||
1. In the **Name your file** field, enter `welcome.yml`. | ||
1. Add the following content to the `welcome.yml` file: | ||
|
||
```yaml copy | ||
name: Post welcome comment | ||
on: | ||
pull_request: | ||
types: [opened] | ||
permissions: | ||
pull-requests: write | ||
``` | ||
1. To commit your changes, click **Commit changes**. | ||
1. Type a commit message, select **Commit directly to the welcome-workflow branch** and click **Commit changes**. | ||
1. Wait about 20 seconds, then refresh this page (the one you're following instructions from). A separate Actions workflow in the repository (not the workflow you created) will run and will automatically replace the contents of this README file with instructions for the next step. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
## Step 2: Add a job to your workflow file | ||
|
||
_Nice work! :tada: You added a workflow file!_ | ||
|
||
Here's what the entries in the `welcome.yml` file, on the `welcome-workflow` branch, mean: | ||
|
||
- `name: Post welcome comment` gives your workflow a name. This name will appear in the Actions tab of your repository. | ||
- `on: pull_request: types: [opened]` indicates that your workflow will execute whenever someone opens a pull request in your repository. | ||
- `permissions` assigns the workflow permissions to operate on the repository | ||
- `pull-requests: write` gives the workflow permission to write to pull requests. This is needed to create the welcome comment. | ||
|
||
Next, we need to specify jobs to run. | ||
|
||
**What is a _job_?**: A job is a set of steps in a workflow that execute on the same runner (a runner is a server that runs your workflows when triggered). Workflows have jobs, and jobs have steps. Steps are executed in order and are dependent on each other. You'll add steps to your workflow later in the course. To read more about jobs, see "[Jobs](https://docs.github.com/en/actions/learn-github-actions/understanding-github-actions#jobs)". | ||
|
||
In the following activity, you'll add a "build" job to your workflow. You'll specify `ubuntu-latest` as the fastest, and cheapest, job runner available. If you want to read more about why we'll use that runner, see the code explanation for the line `runs-on: ubuntu-latest` in the "[Understanding the workflow file](https://docs.github.com/en/actions/learn-github-actions/understanding-github-actions#understanding-the-workflow-file)" article. | ||
|
||
### :keyboard: Activity: Add a job to your workflow file | ||
|
||
1. In a separate browser tab, make sure you are on the `welcome-workflow` branch and open your `.github/workflows/welcome.yml` file. | ||
1. Edit the file and update its contents to: | ||
|
||
```yaml copy | ||
name: Post welcome comment | ||
on: | ||
pull_request: | ||
types: [opened] | ||
permissions: | ||
pull-requests: write | ||
jobs: | ||
build: | ||
name: Post welcome comment | ||
runs-on: ubuntu-latest | ||
``` | ||
1. Click **Commit changes** in the top right of the workflow editor. | ||
1. Type a commit message and commit your changes directly to the `welcome-workflow` branch. | ||
1. Wait about 20 seconds, then refresh this page (the one you're following instructions from). Another workflow will run and will replace the contents of this README file with instructions for the next step. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
## Step 3: Add a step to your workflow file | ||
|
||
_Nice work adding a job to your workflow! :dancer:_ | ||
|
||
Workflows have jobs, and jobs have steps. So now we'll add a step to your workflow. | ||
|
||
**What are _steps_?**: Actions steps run - in the order they are specified, from the top down - when a workflow job is processed. Each step must pass for the next step to run. | ||
|
||
Each step consists of either a shell script that's executed, or a reference to an action that's run. When we talk about an action (with a lowercase "a") in this context, we mean a reusable unit of code. You can find out about actions in "[Finding and customizing actions](https://docs.github.com/en/actions/learn-github-actions/finding-and-customizing-actions)," but for now we'll use a shell script in our workflow step. | ||
|
||
Update your workflow to make it post a comment on new pull requests. It will do this using a [bash](https://en.wikipedia.org/wiki/Bash_%28Unix_shell%29) script and [GitHub CLI](https://cli.github.com/). | ||
|
||
### :keyboard: Activity: Add a step to your workflow file | ||
|
||
1. Still working on the `welcome-workflow` branch, open your `welcome.yml` file. | ||
1. Update the contents of the file to: | ||
|
||
```yaml copy | ||
name: Post welcome comment | ||
on: | ||
pull_request: | ||
types: [opened] | ||
permissions: | ||
pull-requests: write | ||
jobs: | ||
build: | ||
name: Post welcome comment | ||
runs-on: ubuntu-latest | ||
steps: | ||
- run: gh pr comment $PR_URL --body "Welcome to the repository!" | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
PR_URL: ${{ github.event.pull_request.html_url }} | ||
``` | ||
**Note:** The step you've added uses GitHub CLI (`gh`) to add a comment when a pull request is opened. To allow GitHub CLI to post a comment, we set the `GITHUB_TOKEN` environment variable to the value of the `GITHUB_TOKEN` secret, which is an installation access token, created when the workflow runs. For more information, see "[Automatic token authentication](https://docs.github.com/en/actions/security-guides/automatic-token-authentication)." We set the `PR_URL` environment variable to the URL of the newly created pull request, and we use this in the `gh` command. | ||
|
||
1. Click **Commit changes** in the top right of the workflow editor. | ||
1. Type your commit message and commit your changes directly to your branch. | ||
1. Wait about 20 seconds, then refresh this page (the one you're following instructions from). Another workflow will run and will replace the contents of this README file with instructions for the next step. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
## Step 4: Merge your workflow file | ||
|
||
_You're now able to write and run an Actions workflow! :sparkles:_ | ||
|
||
Merge your changes so the action will be a part of the `main` branch. | ||
|
||
### :keyboard: Activity: Merge your workflow file | ||
|
||
1. In your repo, click on the **Pull requests** tab. | ||
1. Click on the pull request you created in step 1. | ||
1. Click **Merge pull request**, then click **Confirm merge**. | ||
1. Optionally, click **Delete branch** to delete your `welcome-workflow` branch. | ||
1. Wait about 20 seconds, then refresh this page (the one you're following instructions from). Another workflow will run and will replace the contents of this README file with instructions for the next step. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
## Step 5: Trigger the workflow | ||
|
||
_You've now added a fully functioning workflow to your repository! :smile:_ | ||
|
||
The shell script in the workflow will run whenever a new pull request is opened. | ||
|
||
**Seeing your _action_ in action**: The status of each workflow run that's triggered is shown in the pull request before it's merged: look for **All checks have passed** when you try out the steps below. You can also see a list of all the workflows that are running, or have finished running, in the **Actions** tab of your repository. From there, you can click on each workflow run to view more details and access log files. | ||
|
||
![A screenshot of the Actions tab showing a list of workflow runs.](https://user-images.githubusercontent.com/16547949/62388049-4e64e600-b52a-11e9-8bf5-db0c5452360f.png) | ||
|
||
### :keyboard: Activity: Trigger the workflow | ||
|
||
1. Make a new branch named `test-workflow`. | ||
1. Make a change, such as adding an emoji to your README.md file, and commit the change directly to your new branch. | ||
1. In the **Pull requests** tab, create a pull request that will merge `test-workflow` into `main`. | ||
1. Watch the workflow running in the checks section of the pull request. | ||
1. Notice the comment that the workflow adds to the pull request. | ||
1. Wait about 20 seconds, then refresh this page (the one you're following instructions from). Another workflow will run and will replace the contents of this README file with instructions for the next step. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
## Finish | ||
|
||
_Congratulations friend, you've completed this course!_ | ||
|
||
<img src=https://octodex.github.com/images/jetpacktocat.png alt="Mona the Octocat wearing a jetpack and smiling." width=300 align=right> | ||
|
||
Here's a recap of all the tasks you've accomplished in your repository: | ||
|
||
- You've created your first GitHub Actions workflow file. | ||
- You learned where to make your workflow file. | ||
- You defined an event trigger, a job, and a step for your workflow. | ||
- You're ready to automate anything you can dream of. | ||
|
||
### What's next? | ||
|
||
- Learn more about GitHub Actions by reading "[Learn GitHub Actions](https://docs.github.com/actions/learn-github-actions)" | ||
- Use actions created by others in [awesome-actions](https://github.com/sdras/awesome-actions) | ||
- We'd love to hear what you thought of this course [in our discussion board](https://github.com/orgs/skills/discussions/categories/hello-github-actions) | ||
- [Take another course on GitHub Actions](https://skills.github.com/#automate-workflows-with-github-actions) | ||
- Learn more about GitHub by reading the "[Get started](https://docs.github.com/get-started)" docs | ||
- To find projects to contribute to, check out [GitHub Explore](https://github.com/explore) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
name: Step 0, Welcome | ||
|
||
# This step triggers after the learner creates a new repository from the template. | ||
# This workflow updates from step 0 to step 1. | ||
|
||
# This will run every time we create push a commit to `main`. | ||
# Reference: https://docs.github.com/en/actions/learn-github-actions/events-that-trigger-workflows | ||
on: | ||
workflow_dispatch: | ||
push: | ||
branches: | ||
- main | ||
|
||
# Reference: https://docs.github.com/en/actions/security-guides/automatic-token-authentication | ||
permissions: | ||
# Need `contents: read` to checkout the repository. | ||
# Need `contents: write` to update the step metadata. | ||
contents: write | ||
|
||
jobs: | ||
# Get the current step to only run the main job when the learner is on the same step. | ||
get_current_step: | ||
name: Check current step number | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v4 | ||
- id: get_step | ||
run: | | ||
echo "current_step=$(cat ./.github/steps/-step.txt)" >> $GITHUB_OUTPUT | ||
outputs: | ||
current_step: ${{ steps.get_step.outputs.current_step }} | ||
|
||
on_start: | ||
name: On start | ||
needs: get_current_step | ||
|
||
# We will only run this action when: | ||
# 1. This repository isn't the template repository. | ||
# 2. The step is currently 0. | ||
# Reference: https://docs.github.com/en/actions/learn-github-actions/contexts | ||
# Reference: https://docs.github.com/en/actions/learn-github-actions/expressions | ||
if: >- | ||
${{ !github.event.repository.is_template | ||
&& needs.get_current_step.outputs.current_step == 0 }} | ||
# We'll run Ubuntu for performance instead of Mac or Windows. | ||
runs-on: ubuntu-latest | ||
|
||
steps: | ||
# We'll need to check out the repository so that we can edit the README. | ||
- name: Checkout | ||
uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 # Let's get all the branches. | ||
|
||
# Make a branch, file, and commit for the learner. | ||
- name: Prepare a branch, and file | ||
run: | | ||
echo "Make sure we are on step 0" | ||
if [ "$(cat .github/steps/-step.txt)" != 0 ] | ||
then | ||
echo "Current step is not 0" | ||
exit 0 | ||
fi | ||
echo "Make a branch" | ||
BRANCH=welcome-workflow | ||
git checkout -b $BRANCH | ||
echo "Make a commit" | ||
git config user.name github-actions[bot] | ||
git config user.email github-actions[bot]@users.noreply.github.com | ||
git commit --allow-empty --message="Create an empty commit" | ||
echo "Push" | ||
git push --set-upstream origin $BRANCH | ||
echo "Restore main" | ||
git checkout main | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
# In README.md, switch step 0 for step 1. | ||
- name: Update to step 1 | ||
uses: skills/action-update-step@v2 | ||
with: | ||
token: ${{ secrets.GITHUB_TOKEN }} | ||
from_step: 0 | ||
to_step: 1 | ||
branch_name: welcome-workflow |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
name: Step 1, Create a workflow | ||
|
||
# This step triggers after every push to welcome-workflow. | ||
# This workflow updates from step 1 to step 2. | ||
|
||
# This will run every time we push to welcome-workflow. | ||
# Reference: https://docs.github.com/en/actions/learn-github-actions/events-that-trigger-workflows | ||
on: | ||
workflow_dispatch: | ||
push: | ||
branches: | ||
- welcome-workflow | ||
|
||
# Reference: https://docs.github.com/en/actions/security-guides/automatic-token-authentication | ||
permissions: | ||
# Need `contents: read` to checkout the repository. | ||
# Need `contents: write` to update the step metadata. | ||
contents: write | ||
|
||
jobs: | ||
# Get the current step to only run the main job when the learner is on the same step. | ||
get_current_step: | ||
name: Check current step number | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v4 | ||
- id: get_step | ||
run: | | ||
echo "current_step=$(cat ./.github/steps/-step.txt)" >> $GITHUB_OUTPUT | ||
outputs: | ||
current_step: ${{ steps.get_step.outputs.current_step }} | ||
|
||
on_create_workflow: | ||
name: On create workflow | ||
needs: get_current_step | ||
|
||
# We will only run this action when: | ||
# 1. This repository isn't the template repository. | ||
# 2. The step is currently 1. | ||
# Reference: https://docs.github.com/en/actions/learn-github-actions/contexts | ||
# Reference: https://docs.github.com/en/actions/learn-github-actions/expressions | ||
if: >- | ||
${{ !github.event.repository.is_template | ||
&& needs.get_current_step.outputs.current_step == 1 }} | ||
# We'll run Ubuntu for performance instead of Mac or Windows. | ||
runs-on: ubuntu-latest | ||
|
||
steps: | ||
# We'll need to check out the repository so that we can edit the README. | ||
- name: Checkout | ||
uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 # Let's get all the branches. | ||
|
||
# Verify the learner added the file contents. | ||
- name: Check workflow contents, name | ||
uses: skills/action-check-file@v1 | ||
with: | ||
file: ".github/workflows/welcome.yml" | ||
search: "name:" | ||
|
||
# In README.md, switch step 1 for step 2. | ||
- name: Update to step 2 | ||
uses: skills/action-update-step@v2 | ||
with: | ||
token: ${{ secrets.GITHUB_TOKEN }} | ||
from_step: 1 | ||
to_step: 2 | ||
branch_name: welcome-workflow |
Oops, something went wrong.