mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-26 13:27:57 +00:00
a9c73113a8
* implement events handling, implement parent_id for spans & events * add events to sp_io::storage * update test * add tests * adjust limit * let tracing crate handle parent_ids * re-enable current-id tracking * add test for threads with CurrentSpan * fix log level * remove redundant check for non wasm traces * remove duplicate definition in test * Adding conditional events API * prefer explicit parent_id over current, enhance test * limit changes to client::tracing event implementation * remove From impl due to fallback required on parent_id * make tracing codecable * replace with global tracing * new tracing interface * impl TracingSubscriber in client * implement access to global TracingSubscriber from primitives * span for wasm * increment towards Wasm Tracing Subscriber implementation * increment, remove sp-tracing from runtime-interface * increment, it compiles * attained original functionality with new mechanism * implement remaining TracingSubscriber functions * remove spans from decl_module * add handling for encoded values * Revert "replace with global tracing" This reverts commit 8824a60deea54d9b437407a21c8ceaf6a1902ee5. * Wasm Side Tracing * tracing on wasm * enable tracing wasm on node-runtime * export all the macros in std * tracing subscriber on wasm-side only * pass spans and events over and record them * reactivate previous code and cleanup * further cleaning up * extend the span macros, activate through executive * tracking the actual extrinsic, too * style * fixing tests * spaces -> tabs * attempting to reactivate params * activate our tests in CI * some passing * tests passing * with core lazy * global tracer for wasm side with pass over * fixing metadata referencing * remove const_fn feature requirement * reenable dispatch traces * reset client tracing * further cleaning up * fixing runtime-test * move tracing-build setup into runtime-test * Merge DebugWriter from tracing and frame-support, move to sp-std * remove dangling fixme * Docs for tracing primitives * cleaning up a bit more * Wasm interface docs * optimise docs.rs setup * adding tracing flags to uncomment * remove brace * fixing imports * fixing broken syntax * add required modules * nicer formatting * better target management * adding low level storage tracing events into frame * add custom Debug impl for WasmMetadata * cloning profiler * adding info about cloning profiler * using in-scope for within calls * proper time tracing, cleaning up println * allow to disable tracing on runtime_interface-macro * disable tracing for wasm-tracing-interface * simplify wasm-tracing-api * update client to new interface * fixing docs and tests for sp-tracing * update integration tests * re-activating enter_span * dropping FIXME, it's documented * fix formatting * fix formatting * fix imports * more debug info * inform wasm about it being disabled by returning 1 * only one tracer, but enabled multi-all support * make trait pub again for tests * Apply suggestions from code review Co-authored-by: Niklas Adolfsson <niklasadolfsson1@gmail.com> * fixing wasm doc tests for proper usage * remove unnecessary import * fixing formatting * minor style fixes * downgrading wabt * update error message for UI * Fix interface test * next attempt to fix macros * geee * revert tracing on hashed for future PR * remove local macros, use originals * we are able to convert to static items * implement more WasmValue types * adding support to convert str, debug and encoded values * more minor fixes * revert unsafe 'static making * fix indentation * remove commented lines * bump all them tracing versions * cleaning up docs and info * document new flag * the new layered system handles span cloning better * Apply suggestions from code review Co-authored-by: David <dvdplm@gmail.com> Co-authored-by: Matt Rutherford <mattrutherford@users.noreply.github.com> Co-authored-by: Niklas Adolfsson <niklasadolfsson1@gmail.com> Co-authored-by: David <dvdplm@gmail.com>
211 lines
6.3 KiB
Rust
211 lines
6.3 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) 2019-2020 Parity Technologies (UK) Ltd.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
//! Integration tests for runtime interface primitives
|
|
#![cfg(test)]
|
|
|
|
use sp_runtime_interface::*;
|
|
|
|
use sp_runtime_interface_test_wasm::{wasm_binary_unwrap, test_api::HostFunctions};
|
|
use sp_runtime_interface_test_wasm_deprecated::wasm_binary_unwrap as wasm_binary_deprecated_unwrap;
|
|
|
|
use sp_wasm_interface::HostFunctions as HostFunctionsT;
|
|
use sc_executor::CallInWasm;
|
|
|
|
use std::{collections::HashSet, sync::{Arc, Mutex}};
|
|
|
|
type TestExternalities = sp_state_machine::TestExternalities<sp_runtime::traits::BlakeTwo256, u64>;
|
|
|
|
fn call_wasm_method_with_result<HF: HostFunctionsT>(
|
|
binary: &[u8],
|
|
method: &str,
|
|
) -> Result<TestExternalities, String> {
|
|
let mut ext = TestExternalities::default();
|
|
let mut ext_ext = ext.ext();
|
|
let mut host_functions = HF::host_functions();
|
|
host_functions.extend(sp_io::SubstrateHostFunctions::host_functions());
|
|
|
|
let executor = sc_executor::WasmExecutor::new(
|
|
sc_executor::WasmExecutionMethod::Interpreted,
|
|
Some(8),
|
|
host_functions,
|
|
8,
|
|
);
|
|
executor.call_in_wasm(
|
|
binary,
|
|
None,
|
|
method,
|
|
&[],
|
|
&mut ext_ext,
|
|
sp_core::traits::MissingHostFunctions::Disallow,
|
|
).map_err(|e| format!("Failed to execute `{}`: {}", method, e))?;
|
|
Ok(ext)
|
|
}
|
|
|
|
fn call_wasm_method<HF: HostFunctionsT>(binary: &[u8], method: &str) -> TestExternalities {
|
|
call_wasm_method_with_result::<HF>(binary, method).unwrap()
|
|
}
|
|
|
|
#[test]
|
|
fn test_return_data() {
|
|
call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_return_data");
|
|
}
|
|
|
|
#[test]
|
|
fn test_return_option_data() {
|
|
call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_return_option_data");
|
|
}
|
|
|
|
#[test]
|
|
fn test_set_storage() {
|
|
let mut ext = call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_set_storage");
|
|
|
|
let expected = "world";
|
|
assert_eq!(expected.as_bytes(), &ext.ext().storage("hello".as_bytes()).unwrap()[..]);
|
|
}
|
|
|
|
#[test]
|
|
fn test_return_value_into_mutable_reference() {
|
|
call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_return_value_into_mutable_reference");
|
|
}
|
|
|
|
#[test]
|
|
fn test_get_and_return_array() {
|
|
call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_get_and_return_array");
|
|
}
|
|
|
|
#[test]
|
|
fn test_array_as_mutable_reference() {
|
|
call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_array_as_mutable_reference");
|
|
}
|
|
|
|
#[test]
|
|
fn test_return_input_public_key() {
|
|
call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_return_input_public_key");
|
|
}
|
|
|
|
#[test]
|
|
fn host_function_not_found() {
|
|
let err = call_wasm_method_with_result::<()>(&wasm_binary_unwrap()[..], "test_return_data").unwrap_err();
|
|
|
|
assert!(err.contains("Instantiation: Export "));
|
|
assert!(err.contains(" not found"));
|
|
}
|
|
|
|
#[test]
|
|
#[should_panic(expected = "Invalid utf8 data provided")]
|
|
fn test_invalid_utf8_data_should_return_an_error() {
|
|
call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_invalid_utf8_data_should_return_an_error");
|
|
}
|
|
|
|
#[test]
|
|
fn test_overwrite_native_function_implementation() {
|
|
call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_overwrite_native_function_implementation");
|
|
}
|
|
|
|
#[test]
|
|
fn test_u128_i128_as_parameter_and_return_value() {
|
|
call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_u128_i128_as_parameter_and_return_value");
|
|
}
|
|
|
|
#[test]
|
|
fn test_vec_return_value_memory_is_freed() {
|
|
call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_vec_return_value_memory_is_freed");
|
|
}
|
|
|
|
#[test]
|
|
fn test_encoded_return_value_memory_is_freed() {
|
|
call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_encoded_return_value_memory_is_freed");
|
|
}
|
|
|
|
#[test]
|
|
fn test_array_return_value_memory_is_freed() {
|
|
call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_array_return_value_memory_is_freed");
|
|
}
|
|
|
|
#[test]
|
|
fn test_versionining_with_new_host_works() {
|
|
// We call to the new wasm binary with new host function.
|
|
call_wasm_method::<HostFunctions>(
|
|
&wasm_binary_unwrap()[..],
|
|
"test_versionning_works",
|
|
);
|
|
|
|
// we call to the old wasm binary with a new host functions
|
|
// old versions of host functions should be called and test should be ok!
|
|
call_wasm_method::<HostFunctions>(
|
|
&wasm_binary_deprecated_unwrap()[..],
|
|
"test_versionning_works",
|
|
);
|
|
}
|
|
|
|
#[test]
|
|
fn test_tracing() {
|
|
use std::fmt;
|
|
use tracing::{span::Id as SpanId};
|
|
use tracing_core::field::{Field, Visit};
|
|
|
|
#[derive(Clone)]
|
|
struct TracingSubscriber(Arc<Mutex<Inner>>);
|
|
|
|
struct FieldConsumer(&'static str, Option<String>);
|
|
impl Visit for FieldConsumer {
|
|
|
|
fn record_debug(&mut self, field: &Field, value: &dyn fmt::Debug) {
|
|
if field.name() == self.0 {
|
|
self.1 = Some(format!("{:?}", value))
|
|
}
|
|
}
|
|
}
|
|
|
|
#[derive(Default)]
|
|
struct Inner {
|
|
spans: HashSet<String>,
|
|
}
|
|
|
|
impl tracing::subscriber::Subscriber for TracingSubscriber {
|
|
fn enabled(&self, _: &tracing::Metadata) -> bool { true }
|
|
|
|
fn new_span(&self, span: &tracing::span::Attributes) -> tracing::Id {
|
|
let mut inner = self.0.lock().unwrap();
|
|
let id = SpanId::from_u64((inner.spans.len() + 1) as _);
|
|
let mut f = FieldConsumer("name", None);
|
|
span.record(&mut f);
|
|
inner.spans.insert(f.1.unwrap_or_else(||span.metadata().name().to_owned()));
|
|
id
|
|
}
|
|
|
|
fn record(&self, _: &SpanId, _: &tracing::span::Record) {}
|
|
|
|
fn record_follows_from(&self, _: &SpanId, _: &SpanId) {}
|
|
|
|
fn event(&self, _: &tracing::Event) {}
|
|
|
|
fn enter(&self, _: &SpanId) {}
|
|
|
|
fn exit(&self, _: &SpanId) {}
|
|
}
|
|
|
|
let subscriber = TracingSubscriber(Default::default());
|
|
let _guard = tracing::subscriber::set_default(subscriber.clone());
|
|
|
|
// Call some method to generate a trace
|
|
call_wasm_method::<HostFunctions>(&wasm_binary_unwrap()[..], "test_return_data");
|
|
|
|
let inner = subscriber.0.lock().unwrap();
|
|
assert!(inner.spans.contains("return_input_version_1"));
|
|
} |