generated from skills/connect-the-dots
-
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
0 parents
commit 0281ded
Showing
26 changed files
with
926 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,5 @@ | ||
# Resources | ||
|
||
- [Learning resources](learning-resources.md) | ||
- [Documentation references](doc-references_.md) | ||
- [Past work](past-work.md) |
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,5 @@ | ||
# Resources | ||
|
||
- [Learning resources](learning-resources.md) | ||
- [Documentation references](doc-references__.md) | ||
- [Past work](past-work.md) |
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,15 @@ | ||
# GIVEN: | ||
|
||
- User opens \_sidebar.md file | ||
|
||
# WHEN: | ||
|
||
- User navigates by clicking on [Documentation references] link | ||
|
||
# THEN (EXPECTED): | ||
|
||
- [Documentation references] page must be open successfully | ||
|
||
# OBSERVED: | ||
|
||
- File not found error OR GitHub reports HTTP 404 error (file not found) |
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,15 @@ | ||
# GIVEN: | ||
|
||
- User opens \_sidebar.md file | ||
|
||
# WHEN: | ||
|
||
- User navigates by clicking on [Documentation references] link | ||
|
||
# THEN (EXPECTED): | ||
|
||
- [Documentation references] page must be open successfully | ||
|
||
# OBSERVED: | ||
|
||
- File not found error OR GitHub reports HTTP 404 error (file not found) |
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 @@ | ||
<!-- readme --> |
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,29 @@ | ||
<!-- | ||
<<< Author notes: Step 1 >>> | ||
Choose 3-5 steps for your course. | ||
The first step is always the hardest, so pick something easy! | ||
Link to docs.github.com for further explanations. | ||
Encourage users to open new tabs for steps! | ||
--> | ||
|
||
## Step 1: Resolve duplicate issues | ||
|
||
_Welcome to the course :tada:_ | ||
|
||
GitHub has special capabilities to help reference other information on GitHub. For example, when you reference another issue or pull request by number, that number will be hyperlinked. At the same time, a cross-reference is created in the linked issue or pull request. This two-way reference helps people track the relationship of information across GitHub. | ||
|
||
![a screenshot of an issue linking to a PR, and a PR with a cross-reference to the issue](https://user-images.githubusercontent.com/6351798/172456846-2daec570-08b0-4ffa-a7cb-41acc50b836e.png) | ||
|
||
With collaboraration from multiple team members, sometimes issues can be duplicated. In the above example, the new issue `#8346` is a duplicate of a previous issue `#8249`. The cross-reference ability allows you to track these duplications and close issues when appropriate. | ||
|
||
### Creating references | ||
|
||
When you link to another issue, a reference within GitHub is automatically created. In fact, you don't even need to include the full link. If you were to type `#5` within a comment, that would turn into a link to issue or pull request number 5. | ||
|
||
When you want to create a crosslink, start typing the title of an issue or pull request directly after you type the `#` symbol. GitHub will suggest issues or pull requests that will link to the right place. To learn even more, check out the [Autolinked References and URLs](https://docs.github.com/en/articles/autolinked-references-and-urls) article. | ||
|
||
### :keyboard: Activity: Find and close the cross-linked issue | ||
|
||
1. Navigate to the issue #1 (Welcome) | ||
2. Type "Duplicate of #2" as a comment and close issue #1 | ||
3. Wait about 20 seconds then refresh this page (the one you're following instructions from). [GitHub Actions](https://docs.github.com/en/actions) will automatically update to 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,33 @@ | ||
<!-- | ||
<<< Author notes: Step 2 >>> | ||
Start this step by acknowledging the previous step. | ||
Define terms and link to docs.github.com. | ||
--> | ||
|
||
## Step 2: Find a commit in history | ||
|
||
_Thanks for the duplicate note :wave:_ | ||
|
||
An important part of version control is the ability to look into the past. By using `git blame`, and finding the story behind a commit, we're able to do more than _blame_ people for code. We're able to see the story around why a commit was made. What is the associated pull request? Who approved the pull request? What tests were run on that commit before it was merged? | ||
|
||
The obvious reason to find things in history is to know about the history. With issues and pull requests, we see a more complete story about the history, not just the bare minimum. | ||
|
||
### What's `git blame`? | ||
|
||
`git blame` is a Git functionality that shows what revision and author last modified each line of a file. Information like who made a commit, when, and even why can be found this way. If you aren't sure who introduced certain changes to a file, you can use `git blame` to find out. While `git blame` sounds rather accusatory, this can be used to understand the context around decisions. | ||
|
||
### What's a Secure Hash Algorithm (SHA)? | ||
|
||
A SHA is a reference to a specific object. In this case, it's a reference to a commit. On GitHub, you can look at a specific commit to see the changes introduced, by whom, and if they were a part of a pull request. | ||
|
||
### :keyboard: Activity: Find commit in history | ||
|
||
1. Navigate to the Code tab of your repository | ||
- _Tip: you may have previously created your repository in a new tab_ | ||
2. Click `docs` to navigate into the `/docs` directory | ||
3. Click `_sidebar.md` to view the file | ||
4. On the top of the file, click **Blame** to see the details of the most recent revision | ||
5. Click the commit message, `add sidebar to documentation` to see the commit details | ||
6. Copy the first seven characters of the SHA (the first 7 characters of the 40 character hexadecimal string listed after `commit`) | ||
7. Comment on issue #2 by adding the SHA from step 6 as a comment text and click on "Comment" button | ||
8. Wait about 20 seconds then refresh this page (the one you're following instructions from). [GitHub Actions](https://docs.github.com/en/actions) will automatically update to 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,39 @@ | ||
<!-- | ||
<<< Author notes: Step 3 >>> | ||
Start this step by acknowledging the previous step. | ||
Define terms and link to docs.github.com. | ||
--> | ||
|
||
## Step 3: Fix a broken sidebar | ||
|
||
_Great job finding that commit :heart:_ | ||
|
||
Thanks for finding that commit! We now know that the sidebar was indeed added, and it was done in that commit. Let's see if we can dig a little deeper to find out if any planning or conversation, using comments, occurred around this change. | ||
|
||
As we've already seen, conversations in issues and pull requests can reference other work, but the amount of context goes much further than crosslinks. Remember, Git is version control! For example, the commit that you found in the last step is connected with much more information such as: | ||
|
||
- Who made the commit. | ||
- What other changes were included. | ||
- When the commit was made. | ||
- Which pull request the commit was a part of. | ||
|
||
The pull request is important because it goes beyond knowing when a commit happened. You can know _why_ a commit happened. Finding history is not about _blaming_ anyone, but about seeing the bigger picture. Why were decisions made? Who was involved? What were the build outputs and test results for each commit? Who requested changes, and who approved them? | ||
|
||
### Finding a pull request from a commit | ||
|
||
When you're looking at a commit on GitHub, you can see a lot of information. From this view, you can also find a link to the pull request in which the commit was created. We'll use this in the next step. | ||
|
||
![screenshot of a view of a commit on GitHub, highlighting the link to the pull request](https://user-images.githubusercontent.com/16547949/67341250-3edbb480-f4fd-11e9-805a-6bce5a8ba2d1.png) | ||
|
||
### :keyboard: Activity: Fix a broken sidebar | ||
|
||
1. In the main branch [Edit the `docs/_sidebar.md` file](/docs/_sidebar.md). | ||
2. Correct the spelling of the reference `(doc-references__.md)` on line 4 by changing it into `(doc-references.md)`. | ||
3. Select or create a new branch `fix-sidebar` for this commit and start a pull request. | ||
4. Make sure that **main** is selected for **base:** and **fix-sidebar** for **compare:**. | ||
5. Using the **Assignees** section on the right side, assign yourself to the pull request. | ||
6. In the PR comment add 'Closes #2' and autolink issue #2. | ||
7. Click **Create pull request** and wait about 20 seconds. | ||
8. Merge this pull request. | ||
9. Delete the branch 'fix-sidebar'. | ||
10. Wait about 20 seconds then refresh this page (the one you're following instructions from). [GitHub Actions](https://docs.github.com/en/actions) will automatically update to 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,31 @@ | ||
<!-- | ||
<<< Author notes: Finish >>> | ||
Review what we learned, ask for feedback, provide next steps. | ||
--> | ||
|
||
## Finish | ||
|
||
_Congratulations friend, you've completed this course! :tada:_ | ||
|
||
<img src="https://octodex.github.com/images/collabocats.jpg" alt=celebrate width=300 align=right> | ||
|
||
In this course, you've learned a lot about finding and sharing information. Within a GitHub repository, you can find history about what changes were made, and more importantly, _why_ changes were made. | ||
|
||
### What's next? | ||
|
||
You can enable GitHub Pages and see `docs/index.html` as a website! | ||
|
||
1. Replace `USERNAME` with your GitHub username and `REPONAME` with your GitHub repository name in `docs/index.html`. | ||
1. Under your repository name at the upper right, click :gear: **Settings**. | ||
1. Then on the lower left, click **Pages**. | ||
1. In the **GitHub Pages** section, select `main` in the **Select branch** drop-down menu and `/docs` in the **Select folder** drop-down menu. | ||
1. Click the **Save** button. | ||
1. Wait about 30 seconds then refresh the page. When you see "Your site is published at ...," you can click on the link to see your published site. | ||
|
||
Check out these resources to learn more or get involved: | ||
|
||
- Are you a student? Check out the [Student Developer Pack](https://education.github.com/pack). | ||
- We'd love to hear what you thought of this course in our [discussion board](https://github.com/orgs/skills/discussions/categories/connect-the-dots). | ||
- [Take another GitHub Skills course](https://github.com/skills). | ||
- [Read the GitHub Getting Started docs](https://docs.github.com/en/get-started). | ||
- 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,110 @@ | ||
name: Step 0, Welcome | ||
|
||
# This step listens for the learner pushing a commit to `main`. | ||
# This workflow updates from step 0 to step 1. | ||
|
||
# This will run every time we 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 | ||
|
||
permissions: | ||
contents: write | ||
pull-requests: write | ||
issues: 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. | ||
|
||
# This is required to establish related issues | ||
# after being created from the template repository. | ||
- name: Prepare issues | ||
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 "Create issue #1 from file" | ||
gh issue create --title "Welcome" -F .github/files/issue01.md | ||
echo "Create issue #2 from file" | ||
gh issue create --title "Fix the sidebar" -F .github/files/issue02.md | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
# This is required to create a relevant history for docs/_sidebar.md | ||
# after being created from the template repository. | ||
- name: Prepare files history | ||
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 | ||
git config user.name github-actions[bot] | ||
git config user.email github-actions[bot]@users.noreply.github.com | ||
git checkout main | ||
echo "Update _sidebar.md for the 1st time" | ||
cp -f .github/files/_sidebar01.md docs/_sidebar.md | ||
git add docs/_sidebar.md | ||
git commit -m "updated _sidebar.md" | ||
git push | ||
echo "update _sidebar.md for the 2nd time" | ||
cp -f .github/files/_sidebar02.md docs/_sidebar.md | ||
git add docs/_sidebar.md | ||
git commit -m "add sidebar to documentation" | ||
git push | ||
echo "preserve the commit shaw" | ||
git log --all --oneline | grep "add sidebar to documentation" | cut -c 1-7 >> .github/files/SIDEBARCOMMIT | ||
git add .github/files/SIDEBARCOMMIT | ||
git commit -m "created SIDEBARCOMMIT" | ||
git push | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
# Update README from step 0 to step 1. | ||
- name: Update to step 1 | ||
uses: skills/action-update-step@v2 | ||
with: | ||
token: ${{ secrets.GITHUB_TOKEN }} | ||
from_step: 0 | ||
to_step: 1 |
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,78 @@ | ||
name: Step 1, Resolve duplicate issues | ||
|
||
# This step listens for the learner creating or editing an issue comment. | ||
# This workflow updates from step 1 to step 2. | ||
|
||
# This will run every time we create or edit an issue comment. | ||
# Reference: https://docs.github.com/en/actions/learn-github-actions/events-that-trigger-workflows | ||
|
||
on: | ||
workflow_dispatch: | ||
issue_comment: | ||
types: [created, edited] | ||
|
||
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_duplicate_issue_closed: | ||
name: Check if duplicate issue is marked as duplicate | ||
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. | ||
|
||
- name: Dump GitHub comment context | ||
id: github_comment_step | ||
env: | ||
COMMENT_CONTEXT: ${{ toJSON(github.event.comment) }} | ||
run: echo "$COMMENT_CONTEXT" | ||
|
||
- name: Dump GitHub issue context | ||
id: github_issue_step | ||
env: | ||
ISSUE_CONTEXT: ${{ toJSON(github.event.issue) }} | ||
run: echo "$ISSUE_CONTEXT" | ||
|
||
- name: Check if commented issue is closed and marked as duplicate | ||
if: ${{ contains(github.event.comment.body, 'Duplicate of') && (github.event.issue.state == 'closed')}} | ||
run: echo 'Duplicate issue closed' | ||
|
||
# Update README from step 1 to step 2. | ||
- name: Update to step 2 | ||
uses: skills/action-update-step@v2 | ||
with: | ||
token: ${{ secrets.GITHUB_TOKEN }} | ||
from_step: 1 | ||
to_step: 2 |
Oops, something went wrong.