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(test): migrate unit tests to the new motsu layout #423

Draft
wants to merge 89 commits into
base: main
Choose a base branch
from

Conversation

qalisander
Copy link
Member

@qalisander qalisander commented Nov 28, 2024

This pr contains migration of unit test to the new layout of motsu unit tests, that will be introduced in OpenZeppelin/stylus-test-helpers#8 and OpenZeppelin/stylus-test-helpers#12

PR Checklist

  • Tests
  • Documentation
  • Changelog

Copy link

netlify bot commented Nov 28, 2024

Deploy Preview for contracts-stylus canceled.

Name Link
🔨 Latest commit 09944a7
🔍 Latest deploy log https://app.netlify.com/sites/contracts-stylus/deploys/67897bdb1132590008a64f6a

Comment on lines 6 to 17
#[cfg(test)]
pub fn msg_sender() -> Address {
motsu::prelude::Context::current()
.get_msg_sender()
.expect("msg_sender should be set")
}

/// Returns the address of the message sender.
#[cfg(not(test))]
pub fn msg_sender() -> Address {
msg::sender()
}
Copy link
Member Author

@qalisander qalisander Nov 28, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here is an example how msg_sender mock can be declared. This design is not perfect since motsu users should implement this mock for their own library manually or through macro.
Calling stylus sdk api msg::sender() won't work inside a test without mock due to this limitation.

Comment on lines 2547 to 2562
#[motsu::test]
fn on_erc721_received(
erc721: Contract<Erc721>,
receiver: Contract<Erc721ReceiverMock>,
) {
let alice = Account::random();
let token_id = random_token_id();
erc721
.sender(alice)
._safe_mint(receiver.address(), token_id, vec![0, 1, 2, 3].into())
.unwrap();

let received_token_id = receiver.sender(alice).received_token_id();

assert_eq!(received_token_id, token_id);
}
Copy link
Member Author

@qalisander qalisander Nov 28, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Overall the test case for Erc721Receiver can look like this

@qalisander qalisander marked this pull request as ready for review November 28, 2024 05:59
keccak-const.workspace = true
openzeppelin-stylus-proc.workspace = true

[dev-dependencies]
alloy-primitives = { workspace = true, features = ["arbitrary"] }
motsu.workspace = true
rand.workspace = true
stylus-sdk.workspace = true
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

stylus-sdk is listed both in dependencies and in dev-dependencies

Copy link
Member Author

@qalisander qalisander Dec 24, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since OL agreed to have a default feature for ENABLING hostio caching, now we should write stylus-sdk = { version = "0.7.0", default-features = false } on the workspace level, and stylus-sdk = { workspace = true, default-features = true } for [dependencies]. Because we need this caching for wasm compiled contracts, but can not run motsu tests with it.
And use it without default features for unit tests [dev-dependencies]

Copy link
Member Author

@qalisander qalisander Dec 24, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would better add a feature for disabling caching (not enabling). It would be more simple

@@ -41,6 +41,8 @@
//! accounts that have been granted it. We recommend using
//! `AccessControlDefaultAdminRules` to enforce additional security measures for
//! this role.
use alloc::vec::Vec;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why are we adding this import?

Comment on lines 92 to 98
pub use token::IErc20;
mod token {
#![allow(missing_docs)]
#![cfg_attr(coverage_nightly, coverage(off))]
stylus_sdk::stylus_proc::sol_interface! {
/// Interface of the ERC-20 token.
interface IErc20 {
function balanceOf(address account) external view returns (uint256);
}
sol_interface! {
/// Interface of the ERC-20 token.
#[allow(missing_docs)]
interface IErc20 {
function balanceOf(address account) external view returns (uint256);
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Won't coverage be reduced by including this?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeap. It will be reduced, currently the simplest way to compile it.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It doesn't compile if you do:

pub use token::IErc20;
mod token {
    #![allow(missing_docs)]
    #![cfg_attr(coverage_nightly, coverage(off))]
    stylus_sdk::prelude::sol_interface! {
        /// Interface of the ERC-20 token.
        interface IErc20 {
            function balanceOf(address account) external view returns (uint256);
        }
    }
}

? 😮

Copy link
Member Author

@qalisander qalisander Dec 24, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

IErc20 now made private. So it will de-sugar to struct IErc20, instead of pub struct IErc20. And visibility level will be just module wise

Copy link
Member Author

@qalisander qalisander Dec 24, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

May be try to change it again in stylus sdk.. pr

@qalisander qalisander changed the title feat(test): unit test external call mock POC feat(test): unit test external call mock Dec 24, 2024
@0xNeshi
Copy link
Collaborator

0xNeshi commented Jan 13, 2025

@qalisander should we close PR in this repo, since another one is open on the stylus-test-helpers repo?

@qalisander qalisander changed the title feat(test): unit test external call mock feat(test): migrate unit tests to the new motsu layout Jan 15, 2025
…ontract-deployment

# Conflicts:
#	Cargo.lock
#	Cargo.toml
#	contracts/src/finance/vesting_wallet.rs
#	contracts/src/token/erc1155/extensions/metadata_uri.rs
#	contracts/src/token/erc1155/extensions/uri_storage.rs
#	contracts/src/token/erc1155/mod.rs
#	contracts/src/token/erc1155/receiver.rs
#	contracts/src/token/erc20/extensions/permit.rs
#	contracts/src/token/erc721/extensions/burnable.rs
#	contracts/src/token/erc721/extensions/consecutive.rs
#	contracts/src/token/erc721/extensions/enumerable.rs
#	contracts/src/token/erc721/extensions/uri_storage.rs
#	contracts/src/token/erc721/mod.rs
#	examples/erc20-permit/tests/erc20permit.rs
@qalisander qalisander marked this pull request as draft January 15, 2025 18:30
@qalisander
Copy link
Member Author

@0xNeshi I'll keep migration to the new unit-test layout within this pr

Copy link
Collaborator

@bidzyyys bidzyyys left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This new motsu layout is great 🚀

@@ -118,7 +118,7 @@ jobs:
# target in this context means one of `--lib`, `--bin`, etc, and not the
# target triple.
- name: Cargo hack
run: cargo hack check --feature-powerset --depth 2 --release --target wasm32-unknown-unknown --skip std --workspace --exclude e2e --exclude basic-example-script --exclude benches
run: cargo hack check --feature-powerset --depth 2 --release --target wasm32-unknown-unknown --skip std --package openzeppelin-stylus
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why do we want this change?

Cargo.toml Outdated
@@ -28,8 +28,6 @@ default-members = [
"contracts",
"contracts-proc",
"lib/crypto",
"lib/motsu",
"lib/motsu-proc",
"lib/e2e-proc",
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Once we are removing lib/motsu and lib/motsu-proc this line also should be removed.

@@ -454,7 +454,7 @@ mod tests {
assert_eq!(owner, alice);

let res =
contract._add_token_to_owner_enumeration(alice, token_id, &erc721);
contract._add_token_to_owner_enumeration(alice, token_id, &*erc721);
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why do we need additional *?

@@ -48,3 +48,7 @@ impl AccessControlExample {
self.access._set_role_admin(role, new_admin_role)
}
}

impl AccessControlExample {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am not sure if we need this impl block.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants