mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-12 05:44:53 +00:00
695d1f0ecf
* Remove subxt Removes ~20 crates from our Cargo.lock. Removes downloading the metadata and enables removing the getMetadata RPC route (relevant to #379). Moves forward #337. Done now due to distinctions in the subxt 0.32 API surface which make it justifiable to not update. * fmt, update due to deny triggering on a yanked crate * Correct the handling of substrate_block_notifier now that it's ephemeral, not long-lived * Correct URL in tests/coordinator from ws to http
61 lines
2 KiB
Rust
61 lines
2 KiB
Rust
pub mod tx;
|
|
pub mod validator_sets;
|
|
pub mod in_instructions;
|
|
pub mod dex;
|
|
|
|
#[macro_export]
|
|
macro_rules! serai_test {
|
|
($($name: ident: $test: expr)*) => {
|
|
$(
|
|
#[tokio::test]
|
|
async fn $name() {
|
|
use dockertest::{
|
|
PullPolicy, StartPolicy, LogOptions, LogAction, LogPolicy, LogSource, Image,
|
|
TestBodySpecification, DockerTest,
|
|
};
|
|
|
|
serai_docker_tests::build("serai".to_string());
|
|
|
|
let handle = concat!("serai_client-serai_node-", stringify!($name));
|
|
|
|
let composition = TestBodySpecification::with_image(
|
|
Image::with_repository("serai-dev-serai").pull_policy(PullPolicy::Never),
|
|
)
|
|
.replace_cmd(vec![
|
|
"serai-node".to_string(),
|
|
"--dev".to_string(),
|
|
"--unsafe-rpc-external".to_string(),
|
|
"--rpc-cors".to_string(),
|
|
"all".to_string(),
|
|
])
|
|
.set_publish_all_ports(true)
|
|
.set_handle(handle)
|
|
.set_start_policy(StartPolicy::Strict)
|
|
.set_log_options(Some(LogOptions {
|
|
action: LogAction::Forward,
|
|
policy: LogPolicy::Always,
|
|
source: LogSource::Both,
|
|
}));
|
|
|
|
let mut test = DockerTest::new().with_network(dockertest::Network::Isolated);
|
|
test.provide_container(composition);
|
|
test.run_async(|ops| async move {
|
|
// Sleep until the Substrate RPC starts
|
|
let serai_rpc = ops.handle(handle).host_port(9944).unwrap();
|
|
let serai_rpc = format!("http://{}:{}", serai_rpc.0, serai_rpc.1);
|
|
// Bound execution to 60 seconds
|
|
for _ in 0 .. 60 {
|
|
tokio::time::sleep(core::time::Duration::from_secs(1)).await;
|
|
let Ok(client) = Serai::new(serai_rpc.clone()).await else { continue };
|
|
if client.latest_finalized_block_hash().await.is_err() {
|
|
continue;
|
|
}
|
|
break;
|
|
}
|
|
#[allow(clippy::redundant_closure_call)]
|
|
$test(Serai::new(serai_rpc).await.unwrap()).await;
|
|
}).await;
|
|
}
|
|
)*
|
|
}
|
|
}
|