Skip to content

Commit

Permalink
homework 2
Browse files Browse the repository at this point in the history
  • Loading branch information
LouisTsai-Csie committed Aug 26, 2024
1 parent 4977ba9 commit 41d269d
Show file tree
Hide file tree
Showing 31 changed files with 1,156 additions and 133 deletions.
63 changes: 49 additions & 14 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -34,36 +34,71 @@ jobs:
# max-score: <max-score>


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

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

## Add More Problem Below
## Problem 3 ...
## Problem 4 ...
- name: UUPS
id: problem-3
uses: classroom-resources/autograding-command-grader@v1
with:
test-name: UUPS
command: cd hw && forge test --mc UUPSTest --mt testExploit
timeout: 10
max-score: 15

- name: Transparent
id: problem-4
uses: classroom-resources/autograding-command-grader@v1
with:
test-name: Transparent
command: cd hw && forge test --mc Transparent --mt testExploit
timeout: 10
max-score: 15

- name: GPU
id: problem-5
uses: classroom-resources/autograding-command-grader@v1
with:
test-name: GPU
command: cd hw && forge test --mc GPUTest --mt testExploit
timeout: 10
max-score: 15

- name: Multisig
id: problem-6
uses: classroom-resources/autograding-command-grader@v1
with:
test-name: Multisig
command: cd hw && forge test --mc MultisigTest --mt testExploit
timeout: 10
max-score: 20

## 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}}"
PROBLEM-3_RESULTS: "${{steps.problem-3.outputs.result}}"
PROBLEM-4_RESULTS: "${{steps.problem-4.outputs.result}}"
PROBLEM-5_RESULTS: "${{steps.problem-5.outputs.result}}"
PROBLEM-6_RESULTS: "${{steps.problem-6.outputs.result}}"
with:
runners: problem-1, problem-2
runners: problem-1, problem-2, problem-3, problem-4, problem-5, problem-6

3 changes: 3 additions & 0 deletions .gitmodules
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
[submodule "hw/lib/forge-std"]
path = hw/lib/forge-std
url = https://github.com/foundry-rs/forge-std
[submodule "hw/lib/openzeppelin-contracts"]
path = hw/lib/openzeppelin-contracts
url = https://github.com/OpenZeppelin/openzeppelin-contracts
3 changes: 3 additions & 0 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"solidity.compileUsingRemoteVersion": "v0.8.9+commit.e5eed63a"
}
63 changes: 1 addition & 62 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,62 +1 @@
# 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)
# 2024-Fall-DeFi-2024
1 change: 1 addition & 0 deletions hw/lib/openzeppelin-contracts
Submodule openzeppelin-contracts added at eb4e86
5 changes: 5 additions & 0 deletions hw/remappings.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
@openzeppelin/contracts/=lib/openzeppelin-contracts/contracts/
ds-test/=lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/src/
erc4626-tests/=lib/openzeppelin-contracts/lib/erc4626-tests/
forge-std/=lib/openzeppelin-contracts/lib/forge-std/src/
openzeppelin-contracts/=lib/openzeppelin-contracts/
19 changes: 0 additions & 19 deletions hw/script/Counter.s.sol

This file was deleted.

14 changes: 0 additions & 14 deletions hw/src/Counter.sol

This file was deleted.

90 changes: 90 additions & 0 deletions hw/src/Logic/GPU.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

interface IERC20 {
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(address indexed owner, address indexed spender, uint256 value);

function totalSupply() external view returns (uint256);
function balanceOf(address account) external view returns (uint256);
function transfer(address to, uint256 amount) external returns (bool);
function allowance(address owner, address spender) external view returns (uint256);
function approve(address spender, uint256 amount) external returns (bool);
function transferFrom(address from, address to, uint256 amount) external returns (bool);
}

contract GPUToken is IERC20 {
string public name;
string public symbol;
uint8 public decimals = 18;
uint256 private _totalSupply;
address internal admin;

mapping(address => uint256) private _balances;
mapping(address => mapping(address => uint256)) private _allowances;

constructor(string memory _name, string memory _symbol) {
name = _name;
symbol = _symbol;
admin = msg.sender;
}

function totalSupply() external view override returns (uint256) {
return _totalSupply;
}

function balanceOf(address account) external view override returns (uint256) {
return _balances[account];
}

function transfer(address to, uint256 amount) external override returns (bool) {
_transfer(msg.sender, to, amount);
return true;
}

function allowance(address owner, address spender) external view override returns (uint256) {
return _allowances[owner][spender];
}

function approve(address spender, uint256 amount) external override returns (bool) {
_approve(msg.sender, spender, amount);
return true;
}

function transferFrom(address from, address to, uint256 amount) external override returns (bool) {
_approve(from, msg.sender, _allowances[from][msg.sender] - amount);
_transfer(from, to, amount);
return true;
}

function _transfer(address from, address to, uint256 amount) internal {
require(from != address(0), "ERC20: transfer from the zero address");
require(to != address(0), "ERC20: transfer to the zero address");
require(_balances[from] >= amount, "ERC20: transfer amount exceeds balance");

uint256 value = _balances[from];
uint256 fromBalance = value - amount;
uint256 toBalance = value + amount;

_balances[from] = fromBalance;
_balances[to] = toBalance;
emit Transfer(from, to, amount);
}

function mint(address account, uint256 amount) public {
require(admin == msg.sender, "caller not admin");
require(account != address(0), "ERC20: mint to the zero address");

_totalSupply += amount;
_balances[account] += amount;
emit Transfer(address(0), account, amount);
}

function _approve(address owner, address spender, uint256 amount) internal {
require(owner != address(0), "ERC20: approve from the zero address");
require(spender != address(0), "ERC20: approve to the zero address");

_allowances[owner][spender] = amount;
emit Approval(owner, spender, amount);
}
}
Loading

0 comments on commit 41d269d

Please sign in to comment.