Skip to content

Commit

Permalink
Initial commit
Browse files Browse the repository at this point in the history
  • Loading branch information
LouisTsai-Csie authored Oct 3, 2024
0 parents commit 8f16a28
Show file tree
Hide file tree
Showing 15 changed files with 278 additions and 0 deletions.
69 changes: 69 additions & 0 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
name: Autograding Tests
'on':
- push
- repository_dispatch
permissions:
checks: write
actions: read
contents: read
jobs:
run-autograding-tests:
runs-on: ubuntu-latest
if: github.actor != 'github-classroom[bot]'
steps:
- name: Code Verification
uses: actions/checkout@v4
- name: Foundry Installation
uses: foundry-rs/foundry-toolchain@v1
with:
version: nightly
- name: Forge Installation
run: |
cd hw
forge install
id: test

## Problem Template
# - name: Problem <id>
# id: problem-<id>
# uses: classroom-resources/autograding-command-grader@v1
# with:
# test-name: Problem <id>
# command: cd hw && forge test --mt <foundry-test-name>
# timeout: <time-limit>
# max-score: <max-score>


## Modify Problem 1 Configuration
- name: Problem 1
id: problem-1
uses: classroom-resources/autograding-command-grader@v1
with:
test-name: Problem 1
command: cd hw && forge test --mt test_Increment
timeout: 10
max-score: 10

## Modify Problem 2 Configuration
- name: Problem 2
id: problem-2
uses: classroom-resources/autograding-command-grader@v1
with:
test-name: Problem 2
command: cd hw && forge test --mt testFuzz_SetNumber
timeout: 10
max-score: 10

## Add More Problem Below
## Problem 3 ...
## Problem 4 ...

## Modify Autograding Reporter
## If new problems are added, remember to add new grading actions below
- name: Autograding Reporter
uses: classroom-resources/autograding-grading-reporter@v1
env:
PROBLEM-1_RESULTS: "${{steps.problem-1.outputs.result}}"
PROBLEM-2_RESULTS: "${{steps.problem-2.outputs.result}}"
with:
runners: problem-1, problem-2
3 changes: 3 additions & 0 deletions .gitmodules
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
[submodule "hw/lib/forge-std"]
path = hw/lib/forge-std
url = https://github.com/foundry-rs/forge-std
62 changes: 62 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
# HW-Template

Assignment Template for GitHub Classroom

## Introduction

This tutorial will guide you through creating your assignment locally and configuring it on GitHub Classroom. Follow the step-by-step instructions carefully to ensure each step is completed correctly.

## Create An Assignment on GitHub
1. Create a new repository by clicking the `Use this template` button.
2. Rename the repository using the format `2024-Fall-HW*`.
3. Choose repository visibility; `Public` is recommended.
4. Design your assignment in the `src/` and `test/` folders.
- Grading should be based on whether the Foundry tests pass or fail.
- Do not support analyzing output content for grading.
- If you install external libraries, run `forge remappings` to link them.
5. Update the autograding configuration in `.github/workflows/test.yml`.
- Copy the `Problem Template` and adjust the `name`, `id`, `test-name`, `command`, `timeout`, and `max-score`.
- Add a new entry in `Autograding Reporter` (at the end of the YAML configuration).
6. Commit the changes and push them to GitHub.
7. Check the GitHub Actions and open the `Autograding Tests` workflow to ensure the auto-grading succeeds.

![auto-grading-result](./images/auto-grading-result.png)

## Create An Assignemnt on GitHub Classroom

1. Go to the relevant GitHub Classroom page.
2. Click the green `+ New Assignment` button.
3. Set up the `Assignment basics` section.
- Enter the assignment title using the format `2024-Fall-HW*``.
- Select deadline, and select `This is a cutoff date`[1].
- Select individual / group assignment
4. Setup `Starter code and environment` section
- Select the repo for this assignment in the `Find a GitHub repository section`.
- Choose repo visibility, recommend `Private`[2] access.
5. Setup `Grading and feedback` section
- Leave the `Add autograding tests` section empty, as grading rules are already configured.
- Enter protected file path, recommend adding `.github/**/*` since grading rules should not be altered[3].
- Select `Enable feedback pull requests` to create PR on each assignment.
6. Finish assignment creation, send the invitation code to the students and starting coding!


NOTE:
[1] Once the cutoff date option is selected, student will lose write access to their repository after deadline.
[2] `Private` access means students will create private repositories when receiving the invitation link.
[3] For CTF problems, the `src/` folder should be locked. If students need to fill in blanks in the source contract, consider locking the corresponding test files.

## Check the Assignment Status on GitHub Classroom

1. Check the students' repositories by clicking the `Repository` button on the right side.
2. Provide feedback by clicking the `Feedback` button on the right side and leave comments on the PR.
3. Verify whether students have submitted the assignment and review grading results.
4. Check if students have altered any protected files or folders.

There are several examples:

- Students not submit the assignment.
![hw-status-not-submitted](./images/hw-status-not-submitted.png)
- Students complete the assignment
![hw-status-submitted](./images/hw-status-submitted.png)
- Student change the protected files and folders
![hw-status-modify-files](./images/hw-status-modify-files.png)
14 changes: 14 additions & 0 deletions hw/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
# Compiler files
cache/
out/

# Ignores development broadcast logs
!/broadcast
/broadcast/*/31337/
/broadcast/**/dry-run/

# Docs
docs/

# Dotenv file
.env
66 changes: 66 additions & 0 deletions hw/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
## Foundry

**Foundry is a blazing fast, portable and modular toolkit for Ethereum application development written in Rust.**

Foundry consists of:

- **Forge**: Ethereum testing framework (like Truffle, Hardhat and DappTools).
- **Cast**: Swiss army knife for interacting with EVM smart contracts, sending transactions and getting chain data.
- **Anvil**: Local Ethereum node, akin to Ganache, Hardhat Network.
- **Chisel**: Fast, utilitarian, and verbose solidity REPL.

## Documentation

https://book.getfoundry.sh/

## Usage

### Build

```shell
$ forge build
```

### Test

```shell
$ forge test
```

### Format

```shell
$ forge fmt
```

### Gas Snapshots

```shell
$ forge snapshot
```

### Anvil

```shell
$ anvil
```

### Deploy

```shell
$ forge script script/Counter.s.sol:CounterScript --rpc-url <your_rpc_url> --private-key <your_private_key>
```

### Cast

```shell
$ cast <subcommand>
```

### Help

```shell
$ forge --help
$ anvil --help
$ cast --help
```
6 changes: 6 additions & 0 deletions hw/foundry.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
[profile.default]
src = "src"
out = "out"
libs = ["lib"]

# See more config options https://github.com/foundry-rs/foundry/blob/master/crates/config/README.md#all-options
1 change: 1 addition & 0 deletions hw/lib/forge-std
Submodule forge-std added at 07263d
Empty file added hw/remappings.txt
Empty file.
19 changes: 19 additions & 0 deletions hw/script/Counter.s.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.13;

import {Script, console} from "forge-std/Script.sol";
import {Counter} from "../src/Counter.sol";

contract CounterScript is Script {
Counter public counter;

function setUp() public {}

function run() public {
vm.startBroadcast();

counter = new Counter();

vm.stopBroadcast();
}
}
14 changes: 14 additions & 0 deletions hw/src/Counter.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.13;

contract Counter {
uint256 public number;

function setNumber(uint256 newNumber) public {
number = newNumber;
}

function increment() public {
number++;
}
}
24 changes: 24 additions & 0 deletions hw/test/Counter.t.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.13;

import {Test, console} from "forge-std/Test.sol";
import {Counter} from "../src/Counter.sol";

contract CounterTest is Test {
Counter public counter;

function setUp() public {
counter = new Counter();
counter.setNumber(0);
}

function test_Increment() public {
counter.increment();
assertEq(counter.number(), 1);
}

function testFuzz_SetNumber(uint256 x) public {
counter.setNumber(x);
assertEq(counter.number(), x);
}
}
Binary file added images/auto-grading-result.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added images/hw-status-modify-files.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added images/hw-status-not-submitted.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added images/hw-status-submitted.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit 8f16a28

Please sign in to comment.