1#![doc(
18 html_logo_url = "https://use.ink/img/crate-docs/logo.png",
19 html_favicon_url = "https://use.ink/crate-docs/favicon.png"
20)]
21
22mod backend;
23mod backend_calls;
24mod builders;
25mod client_utils;
26mod contract_build;
27mod contract_results;
28mod error;
29pub mod events;
30mod node_proc;
31#[cfg(feature = "sandbox")]
32mod sandbox_client;
33mod subxt_client;
34mod xts;
35
36pub use crate::contract_build::build_root_and_contract_dependencies;
37pub use backend::{
38 BuilderClient,
39 ChainBackend,
40 ContractsBackend,
41 E2EBackend,
42};
43pub use backend_calls::{
44 CallBuilder,
45 InstantiateBuilder,
46};
47pub use client_utils::ContractsRegistry;
48pub use contract_results::{
49 CallDryRunResult,
50 CallResult,
51 InstantiateDryRunResult,
52 InstantiationResult,
53 UploadResult,
54};
55pub use ink_e2e_macro::test;
56pub use node_proc::{
57 TestNodeProcess,
58 TestNodeProcessBuilder,
59};
60pub use pallet_revive::evm::CallTrace;
61#[cfg(feature = "sandbox")]
62pub use sandbox_client::{
63 preset,
64 Client as SandboxClient,
65};
66pub use sp_keyring::Sr25519Keyring;
67pub use subxt::{
68 self,
69 backend::rpc::RpcClient,
70};
71pub use subxt_client::{
72 CallBuilderFinal,
73 Client,
74 Error,
75};
76pub use subxt_signer::{
77 self,
78 sr25519::{
79 self,
80 dev::*,
81 Keypair,
82 },
83};
84pub use tokio;
85pub use tracing;
86pub use tracing_subscriber;
87
88#[cfg(feature = "sandbox")]
89pub use ink_sandbox::DefaultSandbox;
90
91use ink::codegen::ContractCallBuilder;
92use ink_env::{
93 call::FromAddr,
94 ContractEnv,
95 Environment,
96};
97use ink_primitives::{
98 Address,
99 DepositLimit,
100 H256,
101};
102pub use sp_weights::Weight;
103use std::{
104 cell::RefCell,
105 sync::Once,
106};
107use xts::ReviveApi;
108
109use ink_primitives::types::AccountIdMapper;
110pub use subxt::PolkadotConfig;
111
112pub static INIT: Once = Once::new();
114
115thread_local! {
118 pub static LOG_PREFIX: RefCell<String> = RefCell::new(String::from("no prefix set"));
123}
124
125pub fn log_prefix() -> String {
127 LOG_PREFIX.with(|log_prefix| log_prefix.borrow().clone())
128}
129
130pub fn log_info(msg: &str) {
132 tracing::info!("[{}] {}", log_prefix(), msg);
133}
134
135pub fn log_error(msg: &str) {
137 tracing::error!("[{}] {}", log_prefix(), msg);
138}
139
140pub fn account_id(account: Sr25519Keyring) -> ink_primitives::AccountId {
142 ink_primitives::AccountId::try_from(account.to_account_id().as_ref())
143 .expect("account keyring has a valid account id")
144}
145
146pub fn address<E: Environment>(account: Sr25519Keyring) -> Address {
153 AccountIdMapper::to_address(account.to_account_id().as_ref())
154}
155
156pub fn create_call_builder<Contract>(
158 acc_id: Address,
159) -> <Contract as ContractCallBuilder>::Type<ink::env::DefaultAbi>
160where
161 <Contract as ContractEnv>::Env: Environment,
162 Contract: ContractCallBuilder + ContractEnv,
163 <Contract as ContractCallBuilder>::Type<ink::env::DefaultAbi>: FromAddr,
164{
165 <<Contract as ContractCallBuilder>::Type<ink::env::DefaultAbi> as FromAddr>::from_addr(
166 acc_id,
167 )
168}
169
170pub fn create_call_builder_abi<Contract, Abi>(
172 acc_id: Address,
173) -> <Contract as ContractCallBuilder>::Type<Abi>
174where
175 <Contract as ContractEnv>::Env: Environment,
176 Contract: ContractCallBuilder + ContractEnv,
177 <Contract as ContractCallBuilder>::Type<Abi>: FromAddr,
178{
179 <<Contract as ContractCallBuilder>::Type<Abi> as FromAddr>::from_addr(acc_id)
180}
181
182fn balance_to_deposit_limit<E: Environment>(
183 b: <E as Environment>::Balance,
184) -> DepositLimit<<E as Environment>::Balance> {
185 DepositLimit::Balance(b)
186}
187
188fn deposit_limit_to_balance<E: Environment>(
189 l: DepositLimit<<E as Environment>::Balance>,
190) -> <E as Environment>::Balance {
191 match l {
192 DepositLimit::Balance(l) => l,
193 DepositLimit::UnsafeOnlyForDryRun => panic!("`Unchecked` is not supported"),
195 }
196}