use super::*; macro_rules! merge_state { ($layer:ident<$rt: ident> ($kind:literal, $expr: expr)) => { paste::paste! { #[test] fn [< test_ $rt:snake _ $kind:snake _merge_state >]() { [< $rt:snake _run >](async move { let mut t1_opts = NetTransportOptions::]>>::with_stream_layer_options("merge_state_node_1".into(), $expr); t1_opts.add_bind_address(next_socket_addr_v4(0)); let t1 = NetTransport::<_, SocketAddrResolver<[< $rt:camel Runtime >]>, _, Lpe<_, _>, [< $rt:camel Runtime >]>::new(t1_opts).await.unwrap(); let t1_opts = Options::lan(); merge_state::<_, NetTransport<_, SocketAddrResolver<[< $rt:camel Runtime >]>, _, Lpe<_, _>, [< $rt:camel Runtime >]>, _>(t1, t1_opts, "node1".into(), "node2".into(), "node3".into(), "node4".into()).await; }); } #[cfg(feature = "compression")] #[test] fn [< test_ $rt:snake _ $kind:snake _merge_state_with_compression >]() { [< $rt:snake _run >](async move { let mut t1_opts = NetTransportOptions::]>>::with_stream_layer_options("merge_state_node_1".into(), $expr).with_compressor(Some(Default::default())).with_offload_size(10); t1_opts.add_bind_address(next_socket_addr_v4(0)); let t1 = NetTransport::<_, SocketAddrResolver<[< $rt:camel Runtime >]>, _, Lpe<_, _>, [< $rt:camel Runtime >]>::new(t1_opts).await.unwrap(); let t1_opts = Options::lan(); merge_state::<_, NetTransport<_, SocketAddrResolver<[< $rt:camel Runtime >]>, _, Lpe<_, _>, [< $rt:camel Runtime >]>, _>(t1, t1_opts, "node1".into(), "node2".into(), "node3".into(), "node4".into()).await; }); } #[cfg(feature = "encryption")] #[test] fn [< test_ $rt:snake _ $kind:snake _merge_state_with_encryption >]() { [< $rt:snake _run >](async move { let mut t1_opts = NetTransportOptions::]>>::with_stream_layer_options("merge_state_node_1".into(), $expr).with_primary_key(Some(TEST_KEYS[0])).with_offload_size(10); t1_opts.add_bind_address(next_socket_addr_v4(0)); let t1 = NetTransport::<_, SocketAddrResolver<[< $rt:camel Runtime >]>, _, Lpe<_, _>, [< $rt:camel Runtime >]>::new(t1_opts).await.unwrap(); let t1_opts = Options::lan(); merge_state::<_, NetTransport<_, SocketAddrResolver<[< $rt:camel Runtime >]>, _, Lpe<_, _>, [< $rt:camel Runtime >]>, _>(t1, t1_opts, "node1".into(), "node2".into(), "node3".into(), "node4".into()).await; }); } #[cfg(all(feature = "encryption", feature = "compression"))] #[test] fn [< test_ $rt:snake _ $kind:snake _merge_state_with_compression_and_encryption >]() { [< $rt:snake _run >](async move { let mut t1_opts = NetTransportOptions::]>>::with_stream_layer_options("merge_state_node_1".into(), $expr).with_primary_key(Some(TEST_KEYS[0])).with_offload_size(10).with_compressor(Some(Default::default())); t1_opts.add_bind_address(next_socket_addr_v4(0)); let t1 = NetTransport::<_, SocketAddrResolver<[< $rt:camel Runtime >]>, _, Lpe<_, _>, [< $rt:camel Runtime >]>::new(t1_opts).await.unwrap(); let t1_opts = Options::lan(); merge_state::<_, NetTransport<_, SocketAddrResolver<[< $rt:camel Runtime >]>, _, Lpe<_, _>, [< $rt:camel Runtime >]>, _>(t1, t1_opts, "node1".into(), "node2".into(), "node3".into(), "node4".into()).await; }); } } }; } test_mods!(merge_state);