Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Add preview content about agent mode #13

Merged
merged 32 commits into from
Mar 25, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
971ab05
feat: Add intro for bonus lesson
chriswblake Mar 21, 2025
af472ab
feat: Add steps to switch to insiders mode
chriswblake Mar 21, 2025
300f9b9
feat: Add steps to switch to agent mode
chriswblake Mar 21, 2025
6d09447
feat: Add prompt to add delete icons on participants
chriswblake Mar 21, 2025
58ff19c
feat: Add prompt to fix bug when adding participants
chriswblake Mar 21, 2025
9d8192f
feat: Add second activity intro
chriswblake Mar 21, 2025
8e0cd58
feat: Add prompt to install mongodb
chriswblake Mar 21, 2025
dfa999d
feat: Add prompt to modify the app to use mongodb
chriswblake Mar 21, 2025
48fff1a
docs: Add description of agent mode
chriswblake Mar 21, 2025
82fb1a6
chore: Move finish message to end
chriswblake Mar 21, 2025
8053e92
feat: Add workflow to trigger bonus lesson
chriswblake Mar 21, 2025
126d5cf
feat: Modify step 3 to clarify bullet points are desired
chriswblake Mar 21, 2025
dac7cb0
feat: Add hint about bonus level to step 3
chriswblake Mar 21, 2025
aa79844
feat: Modify 2 workflow 2 to enable the bonus content
chriswblake Mar 21, 2025
6888646
fix: cleanup from dev work
chriswblake Mar 21, 2025
a6dd60b
docs: Add note about insiders changing daily.
chriswblake Mar 21, 2025
6eca8e8
docs: Add styling to prompts.
chriswblake Mar 21, 2025
1651b10
fix: alert format doesn't work inside expanding details
chriswblake Mar 21, 2025
e6a9076
fix: Require keywords for workflow to run
chriswblake Mar 24, 2025
37faaaa
fix: Clarify need for both insiders version of vs code and pre-releas…
chriswblake Mar 24, 2025
5ab770c
chore: Update agent mode screenshot
chriswblake Mar 24, 2025
8b00dae
fix: Clarify breaking change nature of preview features.
chriswblake Mar 24, 2025
7636d7f
fix: typo
chriswblake Mar 24, 2025
999a634
fix: Ensure copilot to update the styling css.
chriswblake Mar 25, 2025
e966950
chore: Move insiders instructions into own activity area
chriswblake Mar 25, 2025
1ba1ecb
feat: Add some intro text to the activity
chriswblake Mar 25, 2025
c3157a5
fix: update screenshot
chriswblake Mar 25, 2025
17d8fde
chore: Wording tweaks
chriswblake Mar 25, 2025
45f6503
feat: Add step to suggest trying another model
chriswblake Mar 25, 2025
e625305
fix: Update screenshots
chriswblake Mar 25, 2025
62caf61
chore: wording tweaks
chriswblake Mar 25, 2025
67571d3
fix: incorrect workflow name
chriswblake Mar 25, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 12 additions & 4 deletions .github/steps/3-copilot-edits.md
Original file line number Diff line number Diff line change
Expand Up @@ -40,8 +40,9 @@ In our previous steps, we used features of Copilot that require more hands-on gu
> <img width="13px" src="https://github.com/user-attachments/assets/98fd5d2e-ea29-4a4a-9212-c7050e177a69" /> **Prompt**
>
> ```prompt
> Hey Copilot, can you please edit the area where activities are
> listed on the website to show what participants are already signed up for that activity.
> Hey Copilot, can you please edit the activity cards to add a participants section.
> It will show what participants that are already signed up for that activity as a bulleted list.
> Remember to make it pretty!
> ```

- An extra icon has appeared next to the file names and open editor windows indicating they have suggested edits.
Expand All @@ -56,13 +57,13 @@ In our previous steps, we used features of Copilot that require more hands-on gu

Remember, to add the relevant files to the working set.

![image](https://github.com/user-attachments/assets/bdd7318b-50e3-46d0-88ce-7615f45ce334)
![screenshot of working set](https://github.com/user-attachments/assets/d3eadc8e-583e-4a28-9e82-be128eab843b)

</details>

1. Before we simply accept the changes, please check our website again and verify everything is updated as expected. Here is an example of an updated activity card. You may need to restart the app or refresh the page.

<img width="350" alt="Activity card with participant info" src="https://github.com/user-attachments/assets/59fe792e-d587-487d-8525-2548ac0a7adf" />
<img width="350" alt="Activity card with participant info" src="https://github.com/user-attachments/assets/c4d56187-4791-4c8e-87d7-d5ce7cdc0bee" />

> **Note:** Your activity card may look different. Copilot won't always produce the same results.

Expand Down Expand Up @@ -93,3 +94,10 @@ If you don't get feedback, here are some things to check:
- If Mona found a mistake, simply make a correction and push your changes again. Mona will check your work as many times as needed.

</details>

<details>
<summary>Bonus content? 🧐</summary><br/>

> **Insider Tip:** Try adding an issue comment asking @professortocat about Copilot Agent mode. 😉

</details>
124 changes: 124 additions & 0 deletions .github/steps/3b-copilot-agent-mode.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,124 @@
### :keyboard: Bonus Activity - Preview of GitHub Copilot Agent Mode

Nice! You found this hidden bonus level! 🎮 👾

If you have been keeping an eye on Github, you may have heard about **Agent** mode.
It's a public preview feature for GitHub Copilot.

But... it's only for _Insiders_! 😎🤫

But... good news. Anyone can access the Insiders version if they know the tricks. Yay! 🧐🎉

> [!IMPORTANT]
> This activity is optional and ungraded.
> Since the Insiders version is updated daily, please expect to see differences or have breaking changes.

### What is "Agent" Mode?

**Agent** mode enhances Copilot by automatically providing it feedback, typically the types of feedback you would provide after reviewing Copilot's suggested edits.

**Agent** mode gives Copilot a feedback loop, enabling it to inspect its own results for issues, bugs, inconsistency, etc. in the code and even the terminal! This allows it to automatically revise its work in many situations. Similarly this means **Agent** mode can
typically handle more complex and multi-step tasks.

That's just a brief intro and there is much more to learn, but that's for a dedicated future exercise. (hint)

Now, let's give **Agent** mode a try! 👩‍🚀

### :keyboard: Activity: Switch to Insiders mode

If you are not familiar with the Insiders program, please use the below steps to switch your VS Code to the **Insiders** version and your Copilot extension to the **Pre-release** version.

> [!NOTE]
> While switching you will may likely receive an error messages about extension incompatability. This will be resolved after both versions are changed.

1. Ensure you are in a browser-based instance of VS Code (your Codespace).

> **Tip:** This allows switching to **Insiders** mode without installing another version on your local computer.

1. In the bottom left, click the **Manage** icon and select the **Switch to Insiders Version...** option.

<img width="300" alt="image" src="https://github.com/user-attachments/assets/11580b67-9891-4aa9-9a7c-04aff1e7ef9c" />

1. In the left navigation, select the **Extensions** tab.
Find the **GitHub Copilot** entry, click the **Manage** icon, and select **Switch to Pre-Release Version**.

<img width="300" alt="image" src="https://github.com/user-attachments/assets/39e1d9ae-ba50-4cd7-b6b6-eb51aa0a35aa" />

A greeen tag will be added in the top left to indicate the pre-release version.

<img width="160" alt="image" src="https://github.com/user-attachments/assets/21ee8307-0c6d-4e8e-965d-cfd729edfe4c" />

### :keyboard: Activity: Test out Copilot Agent mode! 🧑‍🚀

Let's experiment with some more open-ended requests that will add more functionality to our web application. Remember, AI assistants often produce different results, even if the same prompt is provided. If you don't get the desired results, you can try other models or provided followup feedback to refine the results.

1. Ensure you using **both** the insiders version of VS Code and the pre-release version of the GitHub Copilot extension.

1. Open the **Copilot** side panel and use the dropdown menu to switch to **Agent** mode.

<img width="250" alt="image" src="https://github.com/user-attachments/assets/201e08ab-14a0-48bf-824e-ba4f8f43f8ab" />

1. Time for our test! Let's ask Copilot to add functionality for removing participants.

> <img width="13px" src="https://github.com/user-attachments/assets/98fd5d2e-ea29-4a4a-9212-c7050e177a69" /> **Prompt**
>
> ```prompt
> #codebase Please add a delete icon next to each participant and hide the bullet points.
> When clicked, it will unregister that participant from the activity.
> ```

- If you try this prompt in **Edit** mode, you will propbably find that the changes to the frontend and backend were made in a theoretical way. Although no syntax or runtime errors occurred, the changes were not compatible and didn't achieve the goal.
- In **Agent** mode, Copilot reviewed its own work and refined it to ensure all changes were error free and coordinated together.

1. When Copilot is finished, restart the debugger and inspect the results. If you like the results, press the **Keep** button. If not, try providing Copilot some feedback to refined the results.

1. Ask Copilot to fix a registration bug.

> <img width="13px" src="https://github.com/user-attachments/assets/98fd5d2e-ea29-4a4a-9212-c7050e177a69" /> **Prompt**
>
> ```prompt
> #codebase I've noticed there seems to be a bug.
> When a participant is registered, the page must be refreshed to see the change on the activity.
> ```

- If you try this prompt in **Edit** mode, it may or may not work.

1. When Copilot is finished, inspect the results. If you like the results, press the **Keep** button. If not, try providing Copilot some feedback.

### :keyboard: Activity: Test out Copilot Agent mode, _again_! 🧑‍🚀🚀

Just for fun, let's try something even more difficult and open-ended to see what happens!

> [!TIP]
> In our experiments, we got working results most of the time, but not every time.
> You might try other models or pausing to provide Copilot feedback.

1. (optional) If it is available for you, you might try another model such as `Claude 3.5 Sonnet`.

<img width="250" alt="image" src="https://github.com/user-attachments/assets/16125b88-8428-4f62-9c1b-5761e26ed888" />

1. Ask Copilot to install a local database service.

> <img width="13px" src="https://github.com/user-attachments/assets/98fd5d2e-ea29-4a4a-9212-c7050e177a69" /> **Prompt**
>
> ```prompt
> Please install a local mongodb server for development reasons.
> Afterward, run a command that lists the collections to verify the service is active and working.
> Do not modify our program yet.
> ```

- We purposly made the default development environment not ready for installing a local MongoDB server.
- You will see Copilot make mistakes, analyze the error messages, and ask to run various extra commands to make the environment suitable. Nice!

1. Ask Copilot to change our app to use the database service. 🤯

> <img width="13px" src="https://github.com/user-attachments/assets/98fd5d2e-ea29-4a4a-9212-c7050e177a69" /> **Prompt**
>
> ```prompt
> #codebase I don't like that we are storing the data in memory.
> Let's switch to using mongodb.
> For now use the local development instance.
> Please prepopulate the database with the existing hardcoded json activities, keeping the activity name as the key.
> ```

1. That's your preview for now. We hope it was fun and please check back soon on the [Skills page](https://skills.github.com) for a dedicated exercise to explore even more of Agent Mode! 🧑‍🚀 🚀
1 change: 1 addition & 0 deletions .github/workflows/2-first-introduction.yml
Original file line number Diff line number Diff line change
Expand Up @@ -165,5 +165,6 @@ jobs:
run: |
gh workflow disable "Step 2"
gh workflow enable "Step 3"
gh workflow enable "Step 3b"
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
82 changes: 82 additions & 0 deletions .github/workflows/3b-copilot-agent-mode.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
name: Step 3b # Copilot Agent Mode

on:
issue_comment:
types: [created]

permissions:
contents: read
actions: write
issues: write

env:
# Keywords required in the issue comment to allow this workflow to run
REQUIRED_ISSUE_COMMENT_KEYWORDS: "@professortocat,Agent"
STEP_3B_FILE: ".github/steps/3b-copilot-agent-mode.md"

jobs:
required_issue_comment_keywords:
name: Check issue comment text for required keywords
runs-on: ubuntu-latest

steps:
- name: Stop early if missing the expected keywords, case insensitive
shell: bash
run: |
required_keywords=(${REQUIRED_ISSUE_COMMENT_KEYWORDS//,/ })
comment_body_lower=$(echo "$COMMENT_BODY" | tr '[:upper:]' '[:lower:]')
for keyword in "${required_keywords[@]}"; do
keyword_lower=$(echo "$keyword" | tr '[:upper:]' '[:lower:]')
if [[ ! "$comment_body_lower" =~ $keyword_lower ]]; then
exit 1
fi
done
env:
COMMENT_BODY: ${{ github.event.comment.body }}

find_exercise:
name: Find exercise by issue title
runs-on: ubuntu-latest

outputs:
issue-url: ${{ steps.get-issue-url.outputs.ISSUE_URL }}

steps:
- id: get-issue-url
run: |
# Get the issue url from the event or search for it.
if [ -n "${{ github.event.issue }}" ]; then
issue_url="${{ github.event.issue.html_url }}"
else
issue_url=$(gh issue list --repo $REPO --search "in:title Exercise:" --json url,title --jq '.[].url')
fi

# Save to output
echo "ISSUE_URL=$issue_url" >> $GITHUB_OUTPUT
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
REPO: ${{ github.repository }}

post_step_3b_content:
name: Post step 3b content
needs: [find_exercise, required_issue_comment_keywords]
runs-on: ubuntu-latest
env:
ISSUE_URL: ${{ needs.find_exercise.outputs.issue-url }}

steps:
- name: Checkout
uses: actions/checkout@v4

- name: Create comment - add step content
run: |
gh issue comment "$ISSUE_URL" \
--body-file "$STEP_3B_FILE"
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}

- name: Disable current workflow
run: |
gh workflow disable "Step 3b"
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
2 changes: 1 addition & 1 deletion .github/workflows/4-copilot-on-github.yml
Original file line number Diff line number Diff line change
Expand Up @@ -165,7 +165,7 @@ jobs:

- name: Disable current workflow
run: |
gh workflow disable "Step 4a"
gh workflow disable "Step 4"
gh workflow disable "Step 4b"
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}