mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-10 01:47:58 +00:00
3d669f97c6
* WIP extrinsic api updates * First pass done; now to get things compiling again * document and tweak new structs/traits * cargo check --all-targets now compiles without issue * Polkadot and Substrate take different extra params; support both * Fix transaction format (missing byte from AccountId -> Address) and fmt * Tweak Signer trait * Tweak comments and such in extrinsic params * check all examples against newer polkadot, add new one with params, import path tweaks * clippy fix, and save an allocation when signing * Remove unnecessary Default clauses * Tidy up and fix comments. Panic if payload size >4GB * fix typo
82 lines
2.3 KiB
Rust
82 lines
2.3 KiB
Rust
// Copyright 2019-2022 Parity Technologies (UK) Ltd.
|
|
// This file is part of subxt.
|
|
//
|
|
// subxt is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// subxt is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with subxt. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
use crate::{
|
|
node_runtime::{
|
|
runtime_types,
|
|
sudo,
|
|
DispatchError,
|
|
},
|
|
pair_signer,
|
|
test_context,
|
|
};
|
|
use sp_keyring::AccountKeyring;
|
|
|
|
type Call = runtime_types::node_runtime::Call;
|
|
type BalancesCall = runtime_types::pallet_balances::pallet::Call;
|
|
|
|
#[async_std::test]
|
|
async fn test_sudo() -> Result<(), subxt::Error<DispatchError>> {
|
|
let alice = pair_signer(AccountKeyring::Alice.pair());
|
|
let bob = AccountKeyring::Bob.to_account_id().into();
|
|
let cxt = test_context().await;
|
|
|
|
let call = Call::Balances(BalancesCall::transfer {
|
|
dest: bob,
|
|
value: 10_000,
|
|
});
|
|
|
|
let found_event = cxt
|
|
.api
|
|
.tx()
|
|
.sudo()
|
|
.sudo(call)
|
|
.sign_and_submit_then_watch_default(&alice)
|
|
.await?
|
|
.wait_for_finalized_success()
|
|
.await?
|
|
.has::<sudo::events::Sudid>()?;
|
|
|
|
assert!(found_event);
|
|
Ok(())
|
|
}
|
|
|
|
#[async_std::test]
|
|
async fn test_sudo_unchecked_weight() -> Result<(), subxt::Error<DispatchError>> {
|
|
let alice = pair_signer(AccountKeyring::Alice.pair());
|
|
let bob = AccountKeyring::Bob.to_account_id().into();
|
|
let cxt = test_context().await;
|
|
|
|
let call = Call::Balances(BalancesCall::transfer {
|
|
dest: bob,
|
|
value: 10_000,
|
|
});
|
|
|
|
let found_event = cxt
|
|
.api
|
|
.tx()
|
|
.sudo()
|
|
.sudo_unchecked_weight(call, 0)
|
|
.sign_and_submit_then_watch_default(&alice)
|
|
.await?
|
|
.wait_for_finalized_success()
|
|
.await?
|
|
.has::<sudo::events::Sudid>()?;
|
|
|
|
assert!(found_event);
|
|
Ok(())
|
|
}
|