mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-20 17:54:38 +00:00
Latest hyper-rustls, remove async-recursion
I didn't remove async-recursion when I updated the repo to 1.77 as I forgot we used it in the tests. I still had to add some Box::pins, which may have been a valid option, on the prior Rust version, yet at least resolves everything now. Also updates everything which doesn't introduce further depends.
This commit is contained in:
parent
63521f6a96
commit
93be7a3067
6 changed files with 233 additions and 241 deletions
371
Cargo.lock
generated
371
Cargo.lock
generated
File diff suppressed because it is too large
Load diff
|
@ -23,7 +23,7 @@ hyper-util = { version = "0.1", default-features = false, features = ["http1", "
|
||||||
http-body-util = { version = "0.1", default-features = false }
|
http-body-util = { version = "0.1", default-features = false }
|
||||||
tokio = { version = "1", default-features = false }
|
tokio = { version = "1", default-features = false }
|
||||||
|
|
||||||
hyper-rustls = { version = "0.26", default-features = false, features = ["http1", "ring", "rustls-native-certs", "native-tokio"], optional = true }
|
hyper-rustls = { version = "0.27", default-features = false, features = ["http1", "ring", "rustls-native-certs", "native-tokio"], optional = true }
|
||||||
|
|
||||||
zeroize = { version = "1", optional = true }
|
zeroize = { version = "1", optional = true }
|
||||||
base64ct = { version = "1", features = ["alloc"], optional = true }
|
base64ct = { version = "1", features = ["alloc"], optional = true }
|
||||||
|
|
|
@ -20,7 +20,6 @@ workspace = true
|
||||||
hex = "0.4"
|
hex = "0.4"
|
||||||
|
|
||||||
async-trait = "0.1"
|
async-trait = "0.1"
|
||||||
async-recursion = "1"
|
|
||||||
zeroize = { version = "1", default-features = false }
|
zeroize = { version = "1", default-features = false }
|
||||||
rand_core = { version = "0.6", default-features = false }
|
rand_core = { version = "0.6", default-features = false }
|
||||||
|
|
||||||
|
|
|
@ -135,7 +135,6 @@ pub(crate) async fn new_test(test_body: impl TestBody) {
|
||||||
*OUTER_OPS.get_or_init(|| Mutex::new(None)).lock().await = None;
|
*OUTER_OPS.get_or_init(|| Mutex::new(None)).lock().await = None;
|
||||||
|
|
||||||
// Spawns a coordinator, if one has yet to be spawned, or else runs the test.
|
// Spawns a coordinator, if one has yet to be spawned, or else runs the test.
|
||||||
#[async_recursion::async_recursion]
|
|
||||||
async fn spawn_coordinator_or_run_test(inner_ops: DockerOperations) {
|
async fn spawn_coordinator_or_run_test(inner_ops: DockerOperations) {
|
||||||
// If the outer operations have yet to be set, these *are* the outer operations
|
// If the outer operations have yet to be set, these *are* the outer operations
|
||||||
let outer_ops = OUTER_OPS.get().unwrap();
|
let outer_ops = OUTER_OPS.get().unwrap();
|
||||||
|
@ -178,7 +177,10 @@ pub(crate) async fn new_test(test_body: impl TestBody) {
|
||||||
test.provide_container(composition);
|
test.provide_container(composition);
|
||||||
|
|
||||||
drop(context_lock);
|
drop(context_lock);
|
||||||
test.run_async(spawn_coordinator_or_run_test).await;
|
fn recurse(ops: DockerOperations) -> core::pin::Pin<Box<impl Send + Future<Output = ()>>> {
|
||||||
|
Box::pin(spawn_coordinator_or_run_test(ops))
|
||||||
|
}
|
||||||
|
test.run_async(recurse).await;
|
||||||
} else {
|
} else {
|
||||||
let outer_ops = outer_ops.lock().await.take().unwrap();
|
let outer_ops = outer_ops.lock().await.take().unwrap();
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,6 @@ workspace = true
|
||||||
hex = "0.4"
|
hex = "0.4"
|
||||||
|
|
||||||
async-trait = "0.1"
|
async-trait = "0.1"
|
||||||
async-recursion = "1"
|
|
||||||
|
|
||||||
zeroize = { version = "1", default-features = false }
|
zeroize = { version = "1", default-features = false }
|
||||||
rand_core = { version = "0.6", default-features = false }
|
rand_core = { version = "0.6", default-features = false }
|
||||||
|
|
|
@ -161,8 +161,10 @@ pub(crate) async fn new_test(test_body: impl TestBody) {
|
||||||
*OUTER_OPS.get_or_init(|| Mutex::new(None)).lock().await = None;
|
*OUTER_OPS.get_or_init(|| Mutex::new(None)).lock().await = None;
|
||||||
|
|
||||||
// Spawns a coordinator, if one has yet to be spawned, or else runs the test.
|
// Spawns a coordinator, if one has yet to be spawned, or else runs the test.
|
||||||
#[async_recursion::async_recursion]
|
pub(crate) fn spawn_coordinator_or_run_test(
|
||||||
async fn spawn_coordinator_or_run_test(inner_ops: DockerOperations) {
|
inner_ops: DockerOperations,
|
||||||
|
) -> core::pin::Pin<Box<impl Send + Future<Output = ()>>> {
|
||||||
|
Box::pin(async {
|
||||||
// If the outer operations have yet to be set, these *are* the outer operations
|
// If the outer operations have yet to be set, these *are* the outer operations
|
||||||
let outer_ops = OUTER_OPS.get().unwrap();
|
let outer_ops = OUTER_OPS.get().unwrap();
|
||||||
if outer_ops.lock().await.is_none() {
|
if outer_ops.lock().await.is_none() {
|
||||||
|
@ -209,6 +211,7 @@ pub(crate) async fn new_test(test_body: impl TestBody) {
|
||||||
let outer_ops = outer_ops.lock().await.take().unwrap();
|
let outer_ops = outer_ops.lock().await.take().unwrap();
|
||||||
test_body.body(outer_ops, handles.clone()).await;
|
test_body.body(outer_ops, handles.clone()).await;
|
||||||
}
|
}
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
test.run_async(spawn_coordinator_or_run_test).await;
|
test.run_async(spawn_coordinator_or_run_test).await;
|
||||||
|
|
Loading…
Reference in a new issue