forked from CodeReviewDAO/dxd_codereview
-
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.
Merge pull request CodeReviewDAO#177 from deuszex/milestone-195
195-2 review
- Loading branch information
Showing
2 changed files
with
245 additions
and
0 deletions.
There are no files selected for viewing
117 changes: 117 additions & 0 deletions
117
...5 - CEP submissions for ERC-721, 1337, 777 ports/2 - ERC 777 upgrades/README.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,117 @@ | ||
Grant Proposal | [195 - 1.4 Upgrades and CEP submissions for ERC-721, 1337, and 777 ports](https://portal.devxdao.com/public-proposals/195) | ||
------------ | ------------- | ||
Milestone | 2 | ||
Milestone Title | ERC 777 Upgrades | ||
OP | David Tai | ||
Reviewer | Zoltán Róbert Lovas <[email protected]> | ||
|
||
# Milestone Details | ||
|
||
## Details & Acceptance Criteria | ||
|
||
**Details of what will be delivered in milestone:** | ||
|
||
- Wholesale replacement of deprecated ERC-20 with new 1.3 ERC-20 version now in pull request & review ( will have to wait until work on this is complete from casper's side, may take a few weeks) | ||
- Figure out whether or not we are supporting ERC-1820 standard or using simple callbacks | ||
- Work with Maciej to use the new ERC-20 crate (WIP) instead of copying all the ERC-20 code into the repo | ||
- Events added | ||
- Create a JS client | ||
- Relevant Testing & Docs | ||
- Release Crate | ||
- Tests for Casper's internal backwards compatibility system (when defined) | ||
|
||
**Acceptance criteria:** | ||
|
||
ERC 777 is sufficiently similar enough to ERC-20 repos that technical reviewers sign off | ||
|
||
**Additional notes regarding submission from OP:** | ||
|
||
## Milestone Submission | ||
|
||
The following milestone assets/artifacts were submitted for review: | ||
|
||
Repository | Revision Reviewed | ||
------------ | ------------- | ||
https://github.com/Rengo-Labs/CasperLabs-ERC777 | 054e6da | ||
|
||
|
||
# Install & Usage Testing Procedure and Findings | ||
|
||
Following the documentation installing and testing the project is easy and quick. | ||
|
||
## Overall Impression of usage testing | ||
|
||
Usage is in line with the expected quality and flow. | ||
|
||
Requirement | Finding | ||
------------ | ------------- | ||
Project builds without errors | PASS | ||
Documentation provides sufficient installation/execution instructions | PASS | ||
Project functionality meets/exceeds acceptance criteria and operates without error | PASS | ||
|
||
# Unit / Automated Testing | ||
|
||
There is an adaquate amount of tests that [run to completion with success.](assets/tests.md) | ||
|
||
Requirement | Finding | ||
------------ | ------------- | ||
Unit Tests - At least one positive path test | PASS | ||
Unit Tests - At least one negative path test | PASS | ||
Unit Tests - Additional path tests | PASS | ||
|
||
# Documentation | ||
|
||
### Code Documentation | ||
|
||
The codebase has enough documentation to help understand it. | ||
|
||
Requirement | Finding | ||
------------ | ------------- | ||
Code Documented | PASS | ||
|
||
### Project Documentation | ||
|
||
The project is extensively documented. Examples for intented usage are available. | ||
|
||
Requirement | Finding | ||
------------ | ------------- | ||
Usage Documented | PASS | ||
Example Documented | PASS | ||
|
||
## Overall Conclusion on Documentation | ||
|
||
Documentation of the project(s) should be enough for most users to be able to assess, compile, deploy, and use the project. | ||
|
||
# Open Source Practices | ||
|
||
## Licenses | ||
|
||
The repository contains an Apache-2.0 license. | ||
|
||
Requirement | Finding | ||
------------ | ------------- | ||
OSI-approved open source software license | PASS | ||
|
||
## Contribution Policies | ||
|
||
Contributing, security policy, or code of conduct related documents are present. | ||
Issues and Pull requests are enabled. | ||
|
||
Requirement | Finding | ||
------------ | ------------- | ||
OSS contribution best practices | PASS | ||
|
||
# Coding Standards | ||
|
||
## General Observations | ||
|
||
Project holds up to the expected standards and has enough documentation and tutorials to be usable. | ||
|
||
# Final Conclusion | ||
|
||
The milestone is complete as per the acceptance criteria as it is sufficiently similar to the structure of ERC20, and passes all the general criterias (documentation, tests, etc.) as well. | ||
|
||
# Recommendation | ||
|
||
Recommendation | PASS | ||
------------ | ------------- |
128 changes: 128 additions & 0 deletions
128
...P submissions for ERC-721, 1337, 777 ports/2 - ERC 777 upgrades/assets/tests.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,128 @@ | ||
``` | ||
make test | ||
cargo build --release --target wasm32-unknown-unknown -p erc777-token -p erc1820-registry -p erc777-recipient-contract -p erc777-sender-contract | ||
Compiling casper-erc777 v0.2.1 (CasperLabs-ERC777/erc777) | ||
Compiling erc777-token v0.0.1 (CasperLabs-ERC777/example/implementations/erc777-token) | ||
Finished release [optimized] target(s) in 20.48s | ||
wasm-strip target/wasm32-unknown-unknown/release/erc777_token.wasm 2>/dev/null | true; wasm-strip target/wasm32-unknown-unknown/release/erc1820_registry.wasm 2>/dev/null | true; wasm-strip target/wasm32-unknown-unknown/release/erc777_recipient_contract.wasm 2>/dev/null | true; wasm-strip target/wasm32-unknown-unknown/release/erc777_sender_contract.wasm 2>/dev/null | true; | ||
cargo test | ||
Compiling casper-erc777 v0.2.1 (CasperLabs-ERC777/erc777) | ||
Compiling erc777-sender-tests v0.0.1 (CasperLabs-ERC777/example/tests/erc777-sender-tests) | ||
Compiling erc777-tests v0.0.1 (CasperLabs-ERC777/example/tests/erc777-tests) | ||
Compiling erc777-recipient-tests v0.0.1 (CasperLabs-ERC777/example/tests/erc777-recipient-tests) | ||
Compiling erc20-tests v0.0.1 (CasperLabs-ERC777/example/tests/erc20-tests) | ||
Finished test [unoptimized + debuginfo] target(s) in 2m 36s | ||
Running unittests src/lib.rs (target/debug/deps/casper_erc1820-b21b20798f1c9ffa) | ||
running 0 tests | ||
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s | ||
Running unittests src/lib.rs (target/debug/deps/casper_erc777-2218461044877a0e) | ||
running 0 tests | ||
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s | ||
Running unittests src/lib.rs (target/debug/deps/casper_erc777_recipient-aa25bc5b1664ff5d) | ||
running 0 tests | ||
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s | ||
Running unittests src/lib.rs (target/debug/deps/casper_erc777_sender-dc113c818c8e8300) | ||
running 0 tests | ||
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s | ||
Running unittests src/integration_tests.rs (target/debug/deps/erc1820_tests-04a61298e9cd027f) | ||
running 7 tests | ||
test tests::should_not_set_manager - should panic ... ok | ||
test tests::should_not_register_an_implementer_with_same_caller_address - should panic ... ok | ||
test tests::should_not_register_an_implementer_with_address_zero - should panic ... ok | ||
test tests::should_not_register_an_implementer - should panic ... ok | ||
test tests::should_register_a_recipient ... ok | ||
test tests::should_register_a_sender ... ok | ||
test tests::should_set_manager ... ok | ||
test result: ok. 7 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 2.08s | ||
Running unittests src/integration_tests.rs (target/debug/deps/erc20_tests-47a987e23bd5da4e) | ||
running 6 tests | ||
test tests::should_install ... ok | ||
test tests::should_not_transfer_with_insufficient_balance - should panic ... ok | ||
test tests::should_not_transfer_from_more_than_approved - should panic ... ok | ||
test tests::should_transfer ... ok | ||
test tests::should_transfer_from ... ok | ||
test tests::should_transfer_full_amount ... ok | ||
test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 2.46s | ||
Running unittests src/integration_tests.rs (target/debug/deps/erc777_recipient_tests-0e7e607aa65b1743) | ||
running 9 tests | ||
test tests::should_install ... ok | ||
test tests::should_send_and_burn ... ok | ||
test tests::should_burn_on_behalf_of ... ok | ||
test tests::should_burn_from_erc777_recipient ... ok | ||
test tests::should_send_on_behalf_of ... ok | ||
test tests::should_throw_an_exception_by_not_having_assigned_operator_to_burn_tokens - should panic ... ok | ||
test tests::should_throw_an_exception_by_not_having_assigned_operator_to_send_tokens - should panic ... ok | ||
test tests::should_transfer_tokens_by_using_other_owner ... ok | ||
test tests::should_transfer_tokens_from_erc777_recipient ... ok | ||
test result: ok. 9 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 6.75s | ||
Running unittests src/integration_tests.rs (target/debug/deps/erc777_sender_tests-47801499b226fb30) | ||
running 8 tests | ||
test tests::should_install ... ok | ||
test tests::should_send_and_burn ... ok | ||
test tests::should_burn_on_behalf_of ... ok | ||
test tests::should_burn_from_erc777_sender ... ok | ||
test tests::should_send_on_behalf_of ... ok | ||
test tests::should_throw_an_exception_by_not_having_assigned_operator_to_burn_tokens - should panic ... ok | ||
test tests::should_throw_an_exception_by_not_having_assigned_operator_to_send_tokens - should panic ... ok | ||
test tests::should_transfer_tokens_from_erc777_sender ... ok | ||
test result: ok. 8 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 5.46s | ||
Running unittests src/integration_tests.rs (target/debug/deps/erc777_tests-bb58b40ea0d479ab) | ||
running 6 tests | ||
test tests::should_install ... ok | ||
test tests::should_send_on_behalf_of ... ok | ||
test tests::should_send_and_burn ... ok | ||
test tests::should_burn_on_behalf_of ... ok | ||
test tests::should_throw_an_exception_by_not_having_assigned_operator_to_burn_tokens - should panic ... ok | ||
test tests::should_throw_an_exception_by_not_having_assigned_operator_to_send_tokens - should panic ... ok | ||
test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 3.63s | ||
Doc-tests casper-erc1820 | ||
running 0 tests | ||
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s | ||
Doc-tests casper-erc777 | ||
running 0 tests | ||
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s | ||
Doc-tests casper-erc777-recipient | ||
running 0 tests | ||
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s | ||
Doc-tests casper-erc777-sender | ||
running 0 tests | ||
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s | ||
``` |