node: try 5 times before failing test

This commit is contained in:
hinto-janaiyo 2023-02-12 11:40:08 -05:00
parent c5edfa5593
commit a1c2814a3d
No known key found for this signature in database
GPG key ID: B1C5A64B80691E45

View file

@ -475,13 +475,25 @@ mod test {
for (ip, _, rpc, zmq) in REMOTE_NODES { for (ip, _, rpc, zmq) in REMOTE_NODES {
println!("[{}/{}] {} | {} | {}", n, REMOTE_NODE_LENGTH, ip, rpc, zmq); println!("[{}/{}] {} | {} | {}", n, REMOTE_NODE_LENGTH, ip, rpc, zmq);
let client = client.clone(); let client = client.clone();
let request = Request::builder() // Try 5 times before failure
.method("POST") let mut i = 1;
.uri("http://".to_string() + ip + ":" + rpc + "/json_rpc") let mut response = loop {
.header("User-Agent", rand_user_agent) let request = Request::builder()
.body(hyper::Body::from(r#"{"jsonrpc":"2.0","id":"0","method":"get_info"}"#)) .method("POST")
.unwrap(); .uri("http://".to_string() + ip + ":" + rpc + "/json_rpc")
let mut response = client.request(request).await.unwrap(); .header("User-Agent", rand_user_agent)
.body(hyper::Body::from(r#"{"jsonrpc":"2.0","id":"0","method":"get_info"}"#))
.unwrap();
match client.request(request).await {
Ok(response) => break response,
Err(e) => {
println!("{:#?}", e);
if i > 5 { panic!("Node failure: {}:{}:{}", ip, rpc, zmq); }
std::thread::sleep(std::time::Duration::from_secs(3));
i += 1;
}
}
};
let body = hyper::body::to_bytes(response.body_mut()).await.unwrap(); let body = hyper::body::to_bytes(response.body_mut()).await.unwrap();
let getinfo: GetInfo = serde_json::from_slice(&body).unwrap(); let getinfo: GetInfo = serde_json::from_slice(&body).unwrap();
assert!(getinfo.id == "0"); assert!(getinfo.id == "0");