Skip to content

Commit

Permalink
Return FT tests
Browse files Browse the repository at this point in the history
  • Loading branch information
mrLSD committed Mar 8, 2023
1 parent 4ece9e1 commit 532766c
Show file tree
Hide file tree
Showing 9 changed files with 5,907 additions and 12 deletions.
3,943 changes: 3,943 additions & 0 deletions Cargo.lock

Large diffs are not rendered by default.

1,793 changes: 1,793 additions & 0 deletions res/mock_evm/Cargo.lock

Large diffs are not rendered by default.

3 changes: 2 additions & 1 deletion res/mock_evm/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,8 @@ crate-type = ["cdylib", "rlib"]
[dependencies]
aurora-workspace-types = { path = "../../workspace-types" }
hex = "0.4.3"
near-sdk = "4.0"
near-sdk = "4.1"
near-contract-standards = "4.1"
serde = { version = "1", features = ["derive"] }
getrandom = {version = "0.2", default-features = false, features = ["custom"]}

Expand Down
4 changes: 4 additions & 0 deletions res/mock_evm/rust-toolchain.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
[toolchain]
channel = "1.64.0"
components = ["rustfmt", "clippy"]
targets = ["wasm32-unknown-unknown"]
17 changes: 15 additions & 2 deletions res/mock_evm/src/metadata.rs
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
use crate::{MockEvmContract, MockEvmContractExt};
use aurora_workspace_types::input::{IsUsedProofCallArgs, StorageBalance};
use aurora_workspace_types::{output::TransactionStatus, AccountId, Raw};
use near_contract_standards::fungible_token::metadata::FungibleTokenMetadata;
use near_sdk::{borsh, near_bindgen};

use crate::{MockEvmContract, MockEvmContractExt};

#[near_bindgen]
impl MockEvmContract {
pub fn get_version(&self) -> String {
Expand Down Expand Up @@ -31,6 +31,19 @@ impl MockEvmContract {
0
}

#[result_serializer(borsh)]
pub fn ft_metadata(&self) -> FungibleTokenMetadata {
FungibleTokenMetadata {
spec: "ft-1.0.0".to_string(),
name: "Ether".to_string(),
symbol: "ETH".to_string(),
icon: Some("".to_string()),
reference: None,
reference_hash: None,
decimals: 18,
}
}

#[result_serializer(borsh)]
pub fn get_view(&self, #[serializer(borsh)] _input: Raw) -> TransactionStatus {
TransactionStatus::Succeed(vec![])
Expand Down
1 change: 1 addition & 0 deletions workspace/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ borsh = { version = "0.9", default-features = false }
ethabi = { version = "18", optional = true }
ethereum-types = { version = "0.14", default-features = false, features = ["serialize"] }
near-sdk = "4.0"
near-contract-standards = "4.1"
near-primitives = "0.15"
serde = { version = "1", features = ["derive"] }
serde_json = "1"
Expand Down
74 changes: 71 additions & 3 deletions workspace/src/contract.rs
Original file line number Diff line number Diff line change
@@ -1,12 +1,16 @@
use crate::operation::{
Call, CallDeployCode, CallDeployErc20, CallEvm, CallFtOnTransfer, CallRegisterRelayer,
CallSubmit, View, ViewResultDetails,
Call, CallDeployCode, CallDeployErc20, CallEvm, CallFtOnTransfer, CallFtTransfer,
CallFtTransferCall, CallRegisterRelayer, CallStorageDeposit, CallStorageUnregister,
CallStorageWithdraw, CallSubmit, View, ViewResultDetails,
};
#[cfg(feature = "deposit-withdraw")]
use crate::operation::{CallDeposit, CallWithdraw};
use crate::{EngineCallTransaction, Result};
use aurora_engine::parameters::ViewCallArgs;
use aurora_engine::parameters::{GetStorageAtArgs, StorageBalance, TransactionStatus};
use aurora_engine::parameters::{
GetStorageAtArgs, StorageBalance, StorageDepositCallArgs, StorageWithdrawCallArgs,
TransactionStatus, TransferCallArgs, TransferCallCallArgs,
};
use aurora_workspace_types::input::IsUsedProofCallArgs;
use aurora_workspace_types::input::ProofInput;
#[cfg(feature = "deposit-withdraw")]
Expand All @@ -16,6 +20,7 @@ use aurora_workspace_types::{AccountId, Address, Raw, H256, U256};
use borsh::BorshSerialize;
#[cfg(feature = "ethabi")]
use ethabi::{ParamType, Token};
use near_contract_standards::fungible_token::metadata::FungibleTokenMetadata;
use near_sdk::json_types::U128;
use std::borrow::{Borrow, BorrowMut};
use std::marker::PhantomData;
Expand Down Expand Up @@ -246,6 +251,22 @@ impl<U: UserFunctions> EvmAccount<U> {
CallWithdraw(self.near_call(&Call::Withdraw).args_borsh(args))
}

pub fn ft_transfer<R: AsRef<str>, A: Into<U128>>(
&self,
receiver_id: R,
amount: A,
memo: Option<String>,
) -> CallFtTransfer<'_> {
let args = TransferCallArgs {
// TODO: impl error
receiver_id: aurora_engine_types::account_id::AccountId::new(receiver_id.as_ref())
.unwrap(),
amount: aurora_engine_types::types::NEP141Wei::new(amount.into().0),
memo,
};
CallFtTransfer(self.near_call(&Call::FtTransfer).args_json(args))
}

pub fn ft_on_transfer<A: Into<U128>, R: AsRef<str>>(
&self,
sender_id: R,
Expand All @@ -260,6 +281,49 @@ impl<U: UserFunctions> EvmAccount<U> {
CallFtOnTransfer(self.near_call(&Call::FtOnTransfer).args_json(args))
}

pub fn ft_transfer_call<R: AsRef<str>>(
&self,
receiver_id: R,
amount: u128,
memo: Option<String>,
message: String,
) -> CallFtTransferCall<'_> {
let args = TransferCallCallArgs {
receiver_id: aurora_engine_types::account_id::AccountId::new(receiver_id.as_ref())
.unwrap(),
amount: aurora_engine_types::types::NEP141Wei::new(amount),
memo,
msg: message,
};
CallFtTransferCall(self.near_call(&Call::FtTransferCall).args_json(args))
}

// TODO we are not NEP-145 compliant
pub fn storage_deposit<A: AsRef<str>>(
&self,
account_id: Option<A>,
registration_only: Option<bool>,
) -> CallStorageDeposit<'_> {
let args = StorageDepositCallArgs {
account_id: account_id
.map(|a| aurora_engine_types::account_id::AccountId::new(a.as_ref()).unwrap()),
registration_only,
};
CallStorageDeposit(self.near_call(&Call::StorageDeposit).args_json(args))
}

pub fn storage_unregister(&self, force: bool) -> CallStorageUnregister<'_> {
let val = serde_json::json!({ "force": force });
CallStorageUnregister(self.near_call(&Call::StorageUnregister).args_json(val))
}

pub fn storage_withdraw(&self, amount: Option<u128>) -> CallStorageWithdraw<'_> {
let args = StorageWithdrawCallArgs {
amount: amount.map(aurora_engine_types::types::Yocto::new),
};
CallStorageWithdraw(self.near_call(&Call::StorageWithdraw).args_json(args))
}

pub async fn version(&self) -> Result<ViewResultDetails<String>> {
ViewResultDetails::try_from(self.near_view(&View::Version, vec![]).await?)
}
Expand Down Expand Up @@ -384,6 +448,10 @@ impl<U: UserFunctions> EvmAccount<U> {
ViewResultDetails::try_from(self.near_view(&View::FtBalanceOf, args).await?)
}

pub async fn ft_metadata(&self) -> Result<ViewResultDetails<FungibleTokenMetadata>> {
ViewResultDetails::try_from(self.near_view(&View::FtMetadata, vec![]).await?)
}

pub async fn eth_balance_of<A: Into<Address>>(
&self,
address: A,
Expand Down
32 changes: 31 additions & 1 deletion workspace/src/operation.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,14 @@ use crate::Result;
#[cfg(feature = "deposit-withdraw")]
use aurora_engine::parameters::WithdrawResult;
use aurora_engine::parameters::{StorageBalance, TransactionStatus};
use aurora_engine_sdk::promise::PromiseId;
use aurora_engine_types::types::Wei;
use aurora_workspace_types::AccountId;
use borsh::BorshDeserialize;
#[cfg(feature = "ethabi")]
use ethabi::{ParamType, Token};
use ethereum_types::{Address, H256, U256};
use near_contract_standards::fungible_token::metadata::FungibleTokenMetadata;
use workspaces::operations::CallTransaction;
use workspaces::result::ExecutionFinalResult;

Expand Down Expand Up @@ -52,7 +54,12 @@ impl_call_return![
(CallEvm, ExecutionSuccess<SubmitResult>, try_from_borsh),
(CallSubmit, ExecutionSuccess<SubmitResult>, try_from_borsh),
(CallRegisterRelayer, ExecutionSuccess<()>, try_from),
(CallFtOnTransfer, ExecutionSuccess<String>, try_from_json)
(CallFtOnTransfer, ExecutionSuccess<String>, try_from_json),
(CallFtTransfer, ExecutionSuccess<()>, try_from),
(CallFtTransferCall, ExecutionSuccess<PromiseId>, try_from),
(CallStorageDeposit, ExecutionSuccess<()>, try_from),
(CallStorageUnregister, ExecutionSuccess<()>, try_from),
(CallStorageWithdraw, ExecutionSuccess<()>, try_from)
];

#[cfg(feature = "deposit-withdraw")]
Expand All @@ -75,6 +82,11 @@ pub(crate) enum Call {
FtOnTransfer,
Withdraw,
Deposit,
FtTransfer,
FtTransferCall,
StorageDeposit,
StorageUnregister,
StorageWithdraw,
}

impl AsRef<str> for Call {
Expand All @@ -89,6 +101,11 @@ impl AsRef<str> for Call {
FtOnTransfer => "ft_on_transfer",
Withdraw => "withdraw",
Deposit => "deposit",
FtTransfer => "ft_transfer",
FtTransferCall => "ft_transfer_call",
StorageDeposit => "storage_deposit",
StorageUnregister => "storage_unregister",
StorageWithdraw => "storage_withdraw",
}
}
}
Expand Down Expand Up @@ -255,6 +272,19 @@ impl ViewResultDetails<U256> {
}
}

impl TryFrom<workspaces::result::ViewResultDetails> for ViewResultDetails<FungibleTokenMetadata> {
type Error = Error;

fn try_from(view: workspaces::result::ViewResultDetails) -> Result<Self> {
let result: FungibleTokenMetadata =
FungibleTokenMetadata::try_from_slice(view.result.as_slice())?;
Ok(Self {
result,
logs: view.logs,
})
}
}

impl TryFrom<workspaces::result::ViewResultDetails> for ViewResultDetails<StorageBalance> {
type Error = Error;

Expand Down
52 changes: 47 additions & 5 deletions workspace/tests/ft_tests.rs
Original file line number Diff line number Diff line change
@@ -1,15 +1,57 @@
use aurora_workspace_types::AccountId;
use near_sdk::json_types::U128;
use std::str::FromStr;

mod common;

#[tokio::test]
async fn test_ft_on_transfer() {
let contract = common::init_and_deploy_contract().await.unwrap();
async fn test_ft_transfer() -> anyhow::Result<()> {
let contract = common::init_and_deploy_contract().await?;

contract
.as_account()
.ft_transfer("some_account.test", 10, Some("some message".to_string()))
.transact()
.await?;

Ok(())
}

#[tokio::test]
async fn test_ft_on_transfer() -> anyhow::Result<()> {
let contract = common::init_and_deploy_contract().await?;

let res = contract
.as_account()
.ft_on_transfer("some_account.test", 100, String::new())
.ft_on_transfer(
AccountId::from_str("some_account.test").expect("Failed to make Account from str"),
U128::from(100),
String::new(),
)
.transact()
.await
.unwrap()
.await?
.into_value();

assert_eq!(0u8.to_string(), res);

Ok(())
}

#[tokio::test]
async fn test_ft_transfer_call() -> anyhow::Result<()> {
let contract = common::init_and_deploy_contract().await?;

let res = contract
.as_account()
.ft_transfer_call(
"receiver.test",
10,
Some("some memo".to_string()),
"some message".to_string(),
)
.transact()
.await?
.into_value();

Ok(())
}

0 comments on commit 532766c

Please sign in to comment.