mirror of
https://github.com/comit-network/xmr-btc-swap.git
synced 2025-08-08 06:22:39 -04:00
adding new unfinished RPC tests
This commit is contained in:
parent
008596aa1b
commit
88aee1966d
6 changed files with 325 additions and 88 deletions
127
Cargo.lock
generated
127
Cargo.lock
generated
|
@ -124,6 +124,16 @@ dependencies = [
|
||||||
"tokio",
|
"tokio",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "async-lock"
|
||||||
|
version = "2.6.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "c8101efe8695a6c17e02911402145357e718ac92d3ff88ae8419e84b1707b685"
|
||||||
|
dependencies = [
|
||||||
|
"event-listener",
|
||||||
|
"futures-lite",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "async-trait"
|
name = "async-trait"
|
||||||
version = "0.1.59"
|
version = "0.1.59"
|
||||||
|
@ -1308,6 +1318,21 @@ version = "0.3.25"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "00f5fb52a06bdcadeb54e8d3671f8888a39697dcb0b81b23b55174030427f4eb"
|
checksum = "00f5fb52a06bdcadeb54e8d3671f8888a39697dcb0b81b23b55174030427f4eb"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "futures-lite"
|
||||||
|
version = "1.12.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "7694489acd39452c77daa48516b894c153f192c3578d5a839b62c58099fcbf48"
|
||||||
|
dependencies = [
|
||||||
|
"fastrand",
|
||||||
|
"futures-core",
|
||||||
|
"futures-io",
|
||||||
|
"memchr",
|
||||||
|
"parking",
|
||||||
|
"pin-project-lite 0.2.9",
|
||||||
|
"waker-fn",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "futures-macro"
|
name = "futures-macro"
|
||||||
version = "0.3.25"
|
version = "0.3.25"
|
||||||
|
@ -1658,12 +1683,9 @@ checksum = "d87c48c02e0dc5e3b849a2041db3029fd066650f8f717c07bf8ed78ccb895cac"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"http",
|
"http",
|
||||||
"hyper",
|
"hyper",
|
||||||
"log",
|
|
||||||
"rustls 0.20.2",
|
"rustls 0.20.2",
|
||||||
"rustls-native-certs 0.6.2",
|
|
||||||
"tokio",
|
"tokio",
|
||||||
"tokio-rustls 0.23.1",
|
"tokio-rustls 0.23.1",
|
||||||
"webpki-roots 0.22.2",
|
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
@ -1817,28 +1839,31 @@ version = "0.16.2"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "7d291e3a5818a2384645fd9756362e6d89cf0541b0b916fa7702ea4a9833608e"
|
checksum = "7d291e3a5818a2384645fd9756362e6d89cf0541b0b916fa7702ea4a9833608e"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"jsonrpsee-core 0.16.2",
|
"jsonrpsee-core",
|
||||||
"jsonrpsee-server",
|
"jsonrpsee-server",
|
||||||
"jsonrpsee-types 0.16.2",
|
"jsonrpsee-types",
|
||||||
|
"jsonrpsee-ws-client",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "jsonrpsee-core"
|
name = "jsonrpsee-client-transport"
|
||||||
version = "0.15.1"
|
version = "0.16.2"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "f3dc3e9cf2ba50b7b1d7d76a667619f82846caa39e8e8daa8a4962d74acaddca"
|
checksum = "965de52763f2004bc91ac5bcec504192440f0b568a5d621c59d9dbd6f886c3fb"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
|
||||||
"async-trait",
|
|
||||||
"beef",
|
|
||||||
"futures-channel",
|
|
||||||
"futures-util",
|
"futures-util",
|
||||||
"hyper",
|
"http",
|
||||||
"jsonrpsee-types 0.15.1",
|
"jsonrpsee-core",
|
||||||
"serde",
|
"jsonrpsee-types",
|
||||||
"serde_json",
|
"pin-project 1.0.5",
|
||||||
|
"rustls-native-certs 0.6.2",
|
||||||
|
"soketto",
|
||||||
"thiserror",
|
"thiserror",
|
||||||
|
"tokio",
|
||||||
|
"tokio-rustls 0.23.1",
|
||||||
|
"tokio-util 0.7.3",
|
||||||
"tracing",
|
"tracing",
|
||||||
|
"webpki-roots 0.22.2",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
@ -1849,13 +1874,15 @@ checksum = "a4e70b4439a751a5de7dd5ed55eacff78ebf4ffe0fc009cb1ebb11417f5b536b"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"arrayvec 0.7.2",
|
"arrayvec 0.7.2",
|
||||||
|
"async-lock",
|
||||||
"async-trait",
|
"async-trait",
|
||||||
"beef",
|
"beef",
|
||||||
"futures-channel",
|
"futures-channel",
|
||||||
|
"futures-timer",
|
||||||
"futures-util",
|
"futures-util",
|
||||||
"globset",
|
"globset",
|
||||||
"hyper",
|
"hyper",
|
||||||
"jsonrpsee-types 0.16.2",
|
"jsonrpsee-types",
|
||||||
"parking_lot 0.12.0",
|
"parking_lot 0.12.0",
|
||||||
"rand 0.8.3",
|
"rand 0.8.3",
|
||||||
"rustc-hash",
|
"rustc-hash",
|
||||||
|
@ -1867,26 +1894,6 @@ dependencies = [
|
||||||
"tracing",
|
"tracing",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "jsonrpsee-http-client"
|
|
||||||
version = "0.15.1"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "52f7c0e2333ab2115c302eeb4f137c8a4af5ab609762df68bbda8f06496677c9"
|
|
||||||
dependencies = [
|
|
||||||
"async-trait",
|
|
||||||
"hyper",
|
|
||||||
"hyper-rustls",
|
|
||||||
"jsonrpsee-core 0.15.1",
|
|
||||||
"jsonrpsee-types 0.15.1",
|
|
||||||
"rustc-hash",
|
|
||||||
"serde",
|
|
||||||
"serde_json",
|
|
||||||
"thiserror",
|
|
||||||
"tokio",
|
|
||||||
"tracing",
|
|
||||||
"tracing-futures",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "jsonrpsee-server"
|
name = "jsonrpsee-server"
|
||||||
version = "0.16.2"
|
version = "0.16.2"
|
||||||
|
@ -1897,8 +1904,8 @@ dependencies = [
|
||||||
"futures-util",
|
"futures-util",
|
||||||
"http",
|
"http",
|
||||||
"hyper",
|
"hyper",
|
||||||
"jsonrpsee-core 0.16.2",
|
"jsonrpsee-core",
|
||||||
"jsonrpsee-types 0.16.2",
|
"jsonrpsee-types",
|
||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"soketto",
|
"soketto",
|
||||||
|
@ -1909,20 +1916,6 @@ dependencies = [
|
||||||
"tracing",
|
"tracing",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "jsonrpsee-types"
|
|
||||||
version = "0.15.1"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "e290bba767401b646812f608c099b922d8142603c9e73a50fb192d3ac86f4a0d"
|
|
||||||
dependencies = [
|
|
||||||
"anyhow",
|
|
||||||
"beef",
|
|
||||||
"serde",
|
|
||||||
"serde_json",
|
|
||||||
"thiserror",
|
|
||||||
"tracing",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "jsonrpsee-types"
|
name = "jsonrpsee-types"
|
||||||
version = "0.16.2"
|
version = "0.16.2"
|
||||||
|
@ -1937,6 +1930,18 @@ dependencies = [
|
||||||
"tracing",
|
"tracing",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "jsonrpsee-ws-client"
|
||||||
|
version = "0.16.2"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "0b83daeecfc6517cfe210df24e570fb06213533dfb990318fae781f4c7119dd9"
|
||||||
|
dependencies = [
|
||||||
|
"http",
|
||||||
|
"jsonrpsee-client-transport",
|
||||||
|
"jsonrpsee-core",
|
||||||
|
"jsonrpsee-types",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "keccak"
|
name = "keccak"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
|
@ -2743,6 +2748,12 @@ dependencies = [
|
||||||
"stable_deref_trait",
|
"stable_deref_trait",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "parking"
|
||||||
|
version = "2.0.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "427c3892f9e783d91cc128285287e70a59e206ca452770ece88a76f7a3eddd72"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "parking_lot"
|
name = "parking_lot"
|
||||||
version = "0.11.2"
|
version = "0.11.2"
|
||||||
|
@ -4210,8 +4221,8 @@ dependencies = [
|
||||||
"hyper",
|
"hyper",
|
||||||
"itertools",
|
"itertools",
|
||||||
"jsonrpsee",
|
"jsonrpsee",
|
||||||
"jsonrpsee-core 0.16.2",
|
"jsonrpsee-core",
|
||||||
"jsonrpsee-http-client",
|
"jsonrpsee-types",
|
||||||
"libp2p",
|
"libp2p",
|
||||||
"monero",
|
"monero",
|
||||||
"monero-harness",
|
"monero-harness",
|
||||||
|
@ -4996,6 +5007,12 @@ dependencies = [
|
||||||
"libc",
|
"libc",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "waker-fn"
|
||||||
|
version = "1.1.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "9d5b2c62b4012a3e1eca5a7e077d13b3bf498c4073e33ccd58626607748ceeca"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "want"
|
name = "want"
|
||||||
version = "0.3.0"
|
version = "0.3.0"
|
||||||
|
|
|
@ -80,8 +80,9 @@ bitcoin-harness = "0.2.2"
|
||||||
get-port = "3"
|
get-port = "3"
|
||||||
hyper = "0.14"
|
hyper = "0.14"
|
||||||
monero-harness = { path = "../monero-harness" }
|
monero-harness = { path = "../monero-harness" }
|
||||||
|
jsonrpsee = { version = "0.16.2", features = [ "ws-client" ] }
|
||||||
|
jsonrpsee-types = { version = "0.16.2" }
|
||||||
port_check = "0.1"
|
port_check = "0.1"
|
||||||
jsonrpsee-http-client = "0.15.1"
|
|
||||||
proptest = "1"
|
proptest = "1"
|
||||||
serde_cbor = "0.11"
|
serde_cbor = "0.11"
|
||||||
spectral = "0.6"
|
spectral = "0.6"
|
||||||
|
|
|
@ -222,10 +222,10 @@ impl Request {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
Method::GetSeller => {
|
Method::GetSeller => {
|
||||||
let swap_id = self.params.swap_id.unwrap();
|
let swap_id = self.params.swap_id.with_context(|| "A swap_id is needed")?;
|
||||||
let peerId = context.db.get_peer_id(swap_id).await?;
|
let peerId = context.db.get_peer_id(swap_id).await.with_context(|| "Could not get PeerID")?;
|
||||||
|
|
||||||
let addresses = context.db.get_addresses(peerId).await?;
|
let addresses = context.db.get_addresses(peerId).await.with_context(|| "Could not get addressess")?;
|
||||||
|
|
||||||
json!({
|
json!({
|
||||||
"peerId": peerId.to_base58(),
|
"peerId": peerId.to_base58(),
|
||||||
|
@ -233,7 +233,7 @@ impl Request {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
Method::SwapStartDate => {
|
Method::SwapStartDate => {
|
||||||
let swap_id = self.params.swap_id.unwrap();
|
let swap_id = self.params.swap_id.with_context(|| "A swap_id is needed")?;
|
||||||
|
|
||||||
let start_date = context
|
let start_date = context
|
||||||
.db
|
.db
|
||||||
|
|
|
@ -8,8 +8,8 @@ pub mod methods;
|
||||||
|
|
||||||
#[derive(Debug, Error)]
|
#[derive(Debug, Error)]
|
||||||
pub enum Error {
|
pub enum Error {
|
||||||
#[error("example")]
|
#[error("Could not parse key value from params")]
|
||||||
ExampleError,
|
ParseError,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn run_server(
|
pub async fn run_server(
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
use crate::api::{Context};
|
use crate::api::{Context};
|
||||||
use crate::api::request::{Params, Request, Method, Shutdown};
|
use crate::api::request::{Params, Request, Method, Shutdown};
|
||||||
//use crate::rpc::Error;
|
|
||||||
use anyhow::Result;
|
use anyhow::Result;
|
||||||
use crate::{bitcoin, monero};
|
use crate::{bitcoin, monero};
|
||||||
use crate::{bitcoin::bitcoin_address, monero::monero_address};
|
use crate::{bitcoin::bitcoin_address, monero::monero_address};
|
||||||
|
@ -10,6 +9,7 @@ use std::collections::HashMap;
|
||||||
use std::str::FromStr;
|
use std::str::FromStr;
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
use uuid::Uuid;
|
use uuid::Uuid;
|
||||||
|
use crate::rpc::Error;
|
||||||
|
|
||||||
pub fn register_modules(context: Arc<Context>) -> RpcModule<Arc<Context>> {
|
pub fn register_modules(context: Arc<Context>) -> RpcModule<Arc<Context>> {
|
||||||
let mut module = RpcModule::new(context);
|
let mut module = RpcModule::new(context);
|
||||||
|
@ -30,38 +30,35 @@ pub fn register_modules(context: Arc<Context>) -> RpcModule<Arc<Context>> {
|
||||||
.unwrap();
|
.unwrap();
|
||||||
module
|
module
|
||||||
.register_async_method("get_seller", |params, context| async move {
|
.register_async_method("get_seller", |params, context| async move {
|
||||||
let params: HashMap<String, String> = params.parse()?;
|
let params: HashMap<String, Uuid> = params.parse()?;
|
||||||
|
|
||||||
let swap_id = Uuid::from_str(params.get("swap_id").ok_or_else(|| {
|
let swap_id = params.get("swap_id").ok_or_else(|| {
|
||||||
jsonrpsee_core::Error::Custom("Does not contain swap_id".to_string())
|
jsonrpsee_core::Error::Custom("Does not contain swap_id".to_string())
|
||||||
})?)
|
})?;
|
||||||
.map_err(|err| jsonrpsee_core::Error::Custom(err.to_string()))?;
|
|
||||||
|
|
||||||
get_seller(swap_id, &context).await
|
get_seller(*swap_id, &context).await
|
||||||
})
|
})
|
||||||
.unwrap();
|
.unwrap();
|
||||||
module
|
module
|
||||||
.register_async_method("get_swap_start_date", |params, context| async move {
|
.register_async_method("get_swap_start_date", |params, context| async move {
|
||||||
let params: HashMap<String, String> = params.parse()?;
|
let params: HashMap<String, Uuid> = params.parse()?;
|
||||||
|
|
||||||
let swap_id = Uuid::from_str(params.get("swap_id").ok_or_else(|| {
|
let swap_id = params.get("swap_id").ok_or_else(|| {
|
||||||
jsonrpsee_core::Error::Custom("Does not contain swap_id".to_string())
|
jsonrpsee_core::Error::Custom("Does not contain swap_id".to_string())
|
||||||
})?)
|
})?;
|
||||||
.map_err(|err| jsonrpsee_core::Error::Custom(err.to_string()))?;
|
|
||||||
|
|
||||||
get_swap_start_date(swap_id, &context).await
|
get_swap_start_date(*swap_id, &context).await
|
||||||
})
|
})
|
||||||
.unwrap();
|
.unwrap();
|
||||||
module
|
module
|
||||||
.register_async_method("resume_swap", |params, context| async move {
|
.register_async_method("resume_swap", |params, context| async move {
|
||||||
let params: HashMap<String, String> = params.parse()?;
|
let params: HashMap<String, Uuid> = params.parse()?;
|
||||||
|
|
||||||
let swap_id = Uuid::from_str(params.get("swap_id").ok_or_else(|| {
|
let swap_id = params.get("swap_id").ok_or_else(|| {
|
||||||
jsonrpsee_core::Error::Custom("Does not contain swap_id".to_string())
|
jsonrpsee_core::Error::Custom("Does not contain swap_id".to_string())
|
||||||
})?)
|
})?;
|
||||||
.map_err(|err| jsonrpsee_core::Error::Custom(err.to_string()))?;
|
|
||||||
|
|
||||||
resume_swap(swap_id, &context).await
|
resume_swap(*swap_id, &context).await
|
||||||
})
|
})
|
||||||
.unwrap();
|
.unwrap();
|
||||||
module
|
module
|
||||||
|
@ -130,14 +127,12 @@ pub fn register_modules(context: Arc<Context>) -> RpcModule<Arc<Context>> {
|
||||||
.unwrap();
|
.unwrap();
|
||||||
module
|
module
|
||||||
.register_async_method("list_sellers", |params, context| async move {
|
.register_async_method("list_sellers", |params, context| async move {
|
||||||
let params: HashMap<String, String> = params.parse()?;
|
let params: HashMap<String, Multiaddr> = params.parse()?;
|
||||||
let rendezvous_point =
|
let rendezvous_point = params.get("rendezvous_point").ok_or_else(|| {
|
||||||
Multiaddr::from_str(params.get("rendezvous_point").ok_or_else(|| {
|
|
||||||
jsonrpsee_core::Error::Custom("Does not contain rendezvous_point".to_string())
|
jsonrpsee_core::Error::Custom("Does not contain rendezvous_point".to_string())
|
||||||
})?)
|
})?;
|
||||||
.map_err(|err| jsonrpsee_core::Error::Custom(err.to_string()))?;
|
|
||||||
|
|
||||||
list_sellers(rendezvous_point, &context).await
|
list_sellers(rendezvous_point.clone(), &context).await
|
||||||
})
|
})
|
||||||
.unwrap();
|
.unwrap();
|
||||||
module
|
module
|
||||||
|
|
|
@ -7,17 +7,36 @@ use swap::api::request::{Request, Params, Method, Shutdown};
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
use tokio::time::{interval, timeout};
|
use tokio::time::{interval, timeout};
|
||||||
use std::time::Duration;
|
use std::time::Duration;
|
||||||
pub use jsonrpsee_http_client as http_client;
|
use jsonrpsee::ws_client::WsClientBuilder;
|
||||||
|
use jsonrpsee_core::{client::ClientT, params::ObjectParams};
|
||||||
|
use jsonrpsee::{rpc_params, RpcModule};
|
||||||
|
use jsonrpsee_types::error::CallError;
|
||||||
use tokio::sync::broadcast;
|
use tokio::sync::broadcast;
|
||||||
|
use swap::cli::command::{Bitcoin, Monero};
|
||||||
|
use std::collections::HashMap;
|
||||||
|
use uuid::Uuid;
|
||||||
|
use serde_json::{json, Value};
|
||||||
|
use sequential_test::sequential;
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
|
|
||||||
|
const SERVER_ADDRESS: &str = "127.0.0.1:1234";
|
||||||
|
|
||||||
pub async fn initialize_context() -> (Arc<Context>, Request) {
|
pub async fn initialize_context() -> (Arc<Context>, Request) {
|
||||||
let (is_testnet, debug, json) = (true, false, false);
|
let (is_testnet, debug, json) = (true, false, false);
|
||||||
//let data_dir = data::data_dir_from(None, is_testnet).unwrap();
|
//let data_dir = data::data_dir_from(None, is_testnet).unwrap();
|
||||||
let server_address = None;
|
let server_address = None;
|
||||||
let (tx, _) = broadcast::channel(1);
|
let (tx, _) = broadcast::channel(1);
|
||||||
|
|
||||||
|
let bitcoin = Bitcoin {
|
||||||
|
bitcoin_electrum_rpc_url: None,
|
||||||
|
bitcoin_target_block: None,
|
||||||
|
};
|
||||||
|
|
||||||
|
let monero = Monero {
|
||||||
|
monero_daemon_address: None,
|
||||||
|
};
|
||||||
|
|
||||||
let mut request = Request {
|
let mut request = Request {
|
||||||
params: Params::default(),
|
params: Params::default(),
|
||||||
cmd: Method::StartDaemon,
|
cmd: Method::StartDaemon,
|
||||||
|
@ -25,7 +44,7 @@ pub async fn initialize_context() -> (Arc<Context>, Request) {
|
||||||
};
|
};
|
||||||
|
|
||||||
let context = Context::build(
|
let context = Context::build(
|
||||||
None,
|
Some(bitcoin),
|
||||||
None,
|
None,
|
||||||
None,
|
None,
|
||||||
None,
|
None,
|
||||||
|
@ -41,7 +60,8 @@ pub async fn initialize_context() -> (Arc<Context>, Request) {
|
||||||
|
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
pub async fn start_server() {
|
#[sequential]
|
||||||
|
pub async fn can_start_server() {
|
||||||
let (ctx, mut request) = initialize_context().await;
|
let (ctx, mut request) = initialize_context().await;
|
||||||
let move_ctx = Arc::clone(&ctx);
|
let move_ctx = Arc::clone(&ctx);
|
||||||
tokio::spawn(async move {
|
tokio::spawn(async move {
|
||||||
|
@ -49,8 +69,212 @@ pub async fn start_server() {
|
||||||
});
|
});
|
||||||
tokio::time::sleep(Duration::from_secs(3)).await;
|
tokio::time::sleep(Duration::from_secs(3)).await;
|
||||||
ctx.shutdown.send(());
|
ctx.shutdown.send(());
|
||||||
tokio::time::sleep(Duration::from_secs(3)).await;
|
|
||||||
assert!(true);
|
assert!(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[tokio::test]
|
||||||
|
#[sequential]
|
||||||
|
pub async fn get_bitcoin_balance() {
|
||||||
|
let (ctx, mut request) = initialize_context().await;
|
||||||
|
let move_ctx = Arc::clone(&ctx);
|
||||||
|
tokio::spawn(async move {
|
||||||
|
request.call(Arc::clone(&move_ctx)).await;
|
||||||
|
});
|
||||||
|
|
||||||
|
let url = format!("ws://{}", SERVER_ADDRESS);
|
||||||
|
tokio::time::sleep(Duration::from_secs(3)).await;
|
||||||
|
|
||||||
|
let client = WsClientBuilder::default().build(&url).await.unwrap();
|
||||||
|
let response: HashMap<String, i32> = client.request("get_bitcoin_balance", rpc_params!["id"]).await.unwrap();
|
||||||
|
|
||||||
|
assert_eq!(response, HashMap::from([("balance".to_string(), 0)]));
|
||||||
|
ctx.shutdown.send(());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[tokio::test]
|
||||||
|
#[sequential]
|
||||||
|
pub async fn get_history() {
|
||||||
|
let (ctx, mut request) = initialize_context().await;
|
||||||
|
let move_ctx = Arc::clone(&ctx);
|
||||||
|
tokio::spawn(async move {
|
||||||
|
request.call(Arc::clone(&move_ctx)).await;
|
||||||
|
});
|
||||||
|
|
||||||
|
let url = format!("ws://{}", SERVER_ADDRESS);
|
||||||
|
tokio::time::sleep(Duration::from_secs(3)).await;
|
||||||
|
|
||||||
|
let client = WsClientBuilder::default().build(&url).await.unwrap();
|
||||||
|
let mut params = ObjectParams::new();
|
||||||
|
|
||||||
|
let response: HashMap<String, Vec<(Uuid, String)>> = client.request("get_history", params).await.unwrap();
|
||||||
|
let swaps: Vec<(Uuid, String)> = Vec::new();
|
||||||
|
|
||||||
|
assert_eq!(response, HashMap::from([("swaps".to_string(), swaps)]));
|
||||||
|
ctx.shutdown.send(());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[tokio::test]
|
||||||
|
#[sequential]
|
||||||
|
pub async fn get_raw_history() {
|
||||||
|
let (ctx, mut request) = initialize_context().await;
|
||||||
|
let move_ctx = Arc::clone(&ctx);
|
||||||
|
tokio::spawn(async move {
|
||||||
|
request.call(Arc::clone(&move_ctx)).await;
|
||||||
|
});
|
||||||
|
|
||||||
|
let url = format!("ws://{}", SERVER_ADDRESS);
|
||||||
|
tokio::time::sleep(Duration::from_secs(3)).await;
|
||||||
|
|
||||||
|
let client = WsClientBuilder::default().build(&url).await.unwrap();
|
||||||
|
let mut params = ObjectParams::new();
|
||||||
|
let raw_history: HashMap<Uuid, String> = HashMap::new();
|
||||||
|
|
||||||
|
let response: HashMap<String, HashMap<Uuid, String>> = client.request("get_raw_history", params).await.unwrap();
|
||||||
|
|
||||||
|
assert_eq!(response, HashMap::from([("raw_history".to_string(), raw_history)]));
|
||||||
|
ctx.shutdown.send(());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[tokio::test]
|
||||||
|
#[sequential]
|
||||||
|
pub async fn get_seller() {
|
||||||
|
let (ctx, mut request) = initialize_context().await;
|
||||||
|
let move_ctx = Arc::clone(&ctx);
|
||||||
|
tokio::spawn(async move {
|
||||||
|
request.call(Arc::clone(&move_ctx)).await;
|
||||||
|
});
|
||||||
|
|
||||||
|
let url = format!("ws://{}", SERVER_ADDRESS);
|
||||||
|
tokio::time::sleep(Duration::from_secs(3)).await;
|
||||||
|
|
||||||
|
let client = WsClientBuilder::default().build(&url).await.unwrap();
|
||||||
|
let mut params = ObjectParams::new();
|
||||||
|
|
||||||
|
let response: Result<HashMap<String, String>, _> = client.request("get_seller", params).await;
|
||||||
|
|
||||||
|
// We should ideally match the expected error and panic if it's different one, but the request returns a custom error (to investigate)
|
||||||
|
// Err(jsonrpsee_core::Error::Call(CallError::InvalidParams(e))) => (),
|
||||||
|
// Err(e) => panic!("ErrorType was not ParseError but {e:?}"),
|
||||||
|
|
||||||
|
match response {
|
||||||
|
Err(e) => (),
|
||||||
|
_ => panic!("Expected an error when swap_id is missing"),
|
||||||
|
}
|
||||||
|
|
||||||
|
let mut params = ObjectParams::new();
|
||||||
|
params.insert("swap_id", "invalid_swap_000");
|
||||||
|
|
||||||
|
let response: Result<HashMap<String, String>, _> = client.request("get_seller", params).await;
|
||||||
|
|
||||||
|
match response {
|
||||||
|
Err(e) => (),
|
||||||
|
_ => panic!("Expected an error swap_id is malformed"),
|
||||||
|
}
|
||||||
|
|
||||||
|
let mut params = ObjectParams::new();
|
||||||
|
params.insert("swap_id", "existing_swap");
|
||||||
|
|
||||||
|
let response: Result<HashMap<String, String>, _> = client.request("get_seller", params).await;
|
||||||
|
|
||||||
|
match response {
|
||||||
|
Ok(hash) => (),
|
||||||
|
Err(e) => panic!("Expected a HashMap with correct params, got an error: {}", e),
|
||||||
|
}
|
||||||
|
ctx.shutdown.send(());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[tokio::test]
|
||||||
|
#[sequential]
|
||||||
|
pub async fn get_swap_start_date() {
|
||||||
|
let (ctx, mut request) = initialize_context().await;
|
||||||
|
let move_ctx = Arc::clone(&ctx);
|
||||||
|
tokio::spawn(async move {
|
||||||
|
request.call(Arc::clone(&move_ctx)).await;
|
||||||
|
});
|
||||||
|
|
||||||
|
let url = format!("ws://{}", SERVER_ADDRESS);
|
||||||
|
tokio::time::sleep(Duration::from_secs(3)).await;
|
||||||
|
|
||||||
|
let client = WsClientBuilder::default().build(&url).await.unwrap();
|
||||||
|
let mut params = ObjectParams::new();
|
||||||
|
|
||||||
|
let response: Result<HashMap<String, String>, _> = client.request("get_swap_start_date", params).await;
|
||||||
|
|
||||||
|
// We should ideally match the expected error and panic if it's different one, but the request returns a custom error (to investigate)
|
||||||
|
// Err(jsonrpsee_core::Error::Call(CallError::InvalidParams(e))) => (),
|
||||||
|
// Err(e) => panic!("ErrorType was not ParseError but {e:?}"),
|
||||||
|
|
||||||
|
match response {
|
||||||
|
Err(e) => (),
|
||||||
|
_ => panic!("Expected an error when swap_id is missing"),
|
||||||
|
}
|
||||||
|
|
||||||
|
let mut params = ObjectParams::new();
|
||||||
|
params.insert("swap_id", "invalid_swap_000");
|
||||||
|
|
||||||
|
let response: Result<HashMap<String, String>, _> = client.request("get_swap_start_date", params).await;
|
||||||
|
|
||||||
|
match response {
|
||||||
|
Err(e) => (),
|
||||||
|
_ => panic!("Expected an error when swap_id is malformed"),
|
||||||
|
}
|
||||||
|
|
||||||
|
let mut params = ObjectParams::new();
|
||||||
|
params.insert("swap_id", "existing_swap");
|
||||||
|
|
||||||
|
let response: Result<HashMap<String, String>, _> = client.request("get_swap_start_date", params).await;
|
||||||
|
|
||||||
|
match response {
|
||||||
|
Ok(hash) => (),
|
||||||
|
Err(e) => panic!("Expected a HashMap, got an error: {}", e),
|
||||||
|
}
|
||||||
|
ctx.shutdown.send(());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[tokio::test]
|
||||||
|
#[sequential]
|
||||||
|
pub async fn resume_swap() {
|
||||||
|
let (ctx, mut request) = initialize_context().await;
|
||||||
|
let move_ctx = Arc::clone(&ctx);
|
||||||
|
tokio::spawn(async move {
|
||||||
|
request.call(Arc::clone(&move_ctx)).await;
|
||||||
|
});
|
||||||
|
|
||||||
|
let url = format!("ws://{}", SERVER_ADDRESS);
|
||||||
|
tokio::time::sleep(Duration::from_secs(3)).await;
|
||||||
|
|
||||||
|
let client = WsClientBuilder::default().build(&url).await.unwrap();
|
||||||
|
let mut params = ObjectParams::new();
|
||||||
|
|
||||||
|
let response: Result<HashMap<String, String>, _> = client.request("get_swap_start_date", params).await;
|
||||||
|
|
||||||
|
// We should ideally match the expected error and panic if it's different one, but the request returns a custom error (to investigate)
|
||||||
|
// Err(jsonrpsee_core::Error::Call(CallError::InvalidParams(e))) => (),
|
||||||
|
// Err(e) => panic!("ErrorType was not ParseError but {e:?}"),
|
||||||
|
|
||||||
|
match response {
|
||||||
|
Err(e) => (),
|
||||||
|
_ => panic!("Expected an error when swap_id is missing"),
|
||||||
|
}
|
||||||
|
|
||||||
|
let mut params = ObjectParams::new();
|
||||||
|
params.insert("swap_id", "invalid_swap_000");
|
||||||
|
|
||||||
|
let response: Result<HashMap<String, String>, _> = client.request("get_swap_start_date", params).await;
|
||||||
|
|
||||||
|
match response {
|
||||||
|
Err(e) => (),
|
||||||
|
_ => panic!("Expected an error when swap_id is malformed"),
|
||||||
|
}
|
||||||
|
|
||||||
|
let mut params = ObjectParams::new();
|
||||||
|
params.insert("swap_id", "existing_swap");
|
||||||
|
|
||||||
|
let response: Result<HashMap<String, String>, _> = client.request("get_swap_start_date", params).await;
|
||||||
|
|
||||||
|
match response {
|
||||||
|
Ok(hash) => (),
|
||||||
|
Err(e) => panic!("Expected a HashMap, got an error: {}", e),
|
||||||
|
}
|
||||||
|
ctx.shutdown.send(());
|
||||||
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue