mirror of
https://github.com/hinto-janai/gupax.git
synced 2025-01-22 09:14:29 +00:00
node: only fail test if failure rate is >50%
This commit is contained in:
parent
e0d22f3f9e
commit
31b1545d40
3 changed files with 34 additions and 6 deletions
6
.github/workflows/ping.yml
vendored
6
.github/workflows/ping.yml
vendored
|
@ -1,10 +1,14 @@
|
||||||
# This uses the unit test in the [node.rs] file to ping all REMOTE_NODES
|
# This uses the unit test in the [node.rs] file to ping all REMOTE_NODES
|
||||||
# and attempts to serialize their JSON data to make sure they are working.
|
# and attempts to serialize their JSON data to make sure they are working.
|
||||||
|
|
||||||
name: Daily Remote Node Ping
|
name: Remote Node Ping
|
||||||
on:
|
on:
|
||||||
schedule:
|
schedule:
|
||||||
- cron: "0 4 * * *"
|
- cron: "0 4 * * *"
|
||||||
|
push:
|
||||||
|
branches: [ "main" ]
|
||||||
|
pull_request:
|
||||||
|
branches: [ "main" ]
|
||||||
|
|
||||||
env:
|
env:
|
||||||
CARGO_TERM_COLOR: always
|
CARGO_TERM_COLOR: always
|
||||||
|
|
|
@ -7,7 +7,7 @@ Gupax is a GUI for mining [**Monero**](https://github.com/monero-project/monero)
|
||||||
|
|
||||||
[![Windows](https://github.com/hinto-janai/gupax/actions/workflows/windows.yml/badge.svg)](https://github.com/hinto-janai/gupax/actions/workflows/windows.yml) [![macOS](https://github.com/hinto-janai/gupax/actions/workflows/macos.yml/badge.svg)](https://github.com/hinto-janai/gupax/actions/workflows/macos.yml) [![Linux](https://github.com/hinto-janai/gupax/actions/workflows/linux.yml/badge.svg)](https://github.com/hinto-janai/gupax/actions/workflows/linux.yml)
|
[![Windows](https://github.com/hinto-janai/gupax/actions/workflows/windows.yml/badge.svg)](https://github.com/hinto-janai/gupax/actions/workflows/windows.yml) [![macOS](https://github.com/hinto-janai/gupax/actions/workflows/macos.yml/badge.svg)](https://github.com/hinto-janai/gupax/actions/workflows/macos.yml) [![Linux](https://github.com/hinto-janai/gupax/actions/workflows/linux.yml/badge.svg)](https://github.com/hinto-janai/gupax/actions/workflows/linux.yml)
|
||||||
|
|
||||||
[![Daily Remote Node Ping](https://github.com/hinto-janai/gupax/actions/workflows/ping.yml/badge.svg)](https://github.com/hinto-janai/gupax/actions/workflows/ping.yml)
|
[![Remote Node Ping](https://github.com/hinto-janai/gupax/actions/workflows/ping.yml/badge.svg)](https://github.com/hinto-janai/gupax/actions/workflows/ping.yml)
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
32
src/node.rs
32
src/node.rs
|
@ -446,9 +446,15 @@ mod test {
|
||||||
// Random User Agent
|
// Random User Agent
|
||||||
let rand_user_agent = crate::Pkg::get_user_agent();
|
let rand_user_agent = crate::Pkg::get_user_agent();
|
||||||
|
|
||||||
|
// Only fail this test if >50% of nodes fail.
|
||||||
|
const HALF_REMOTE_NODES: usize = REMOTE_NODE_LENGTH / 2;
|
||||||
|
// A string buffer to append the failed node data.
|
||||||
|
let mut failures = String::new();
|
||||||
|
let mut failure_count = 0;
|
||||||
|
|
||||||
let mut n = 1;
|
let mut n = 1;
|
||||||
for (ip, _, rpc, zmq) in REMOTE_NODES {
|
'outer: 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();
|
||||||
// Try 5 times before failure
|
// Try 5 times before failure
|
||||||
let mut i = 1;
|
let mut i = 1;
|
||||||
|
@ -463,8 +469,13 @@ mod test {
|
||||||
Ok(response) => break response,
|
Ok(response) => break response,
|
||||||
Err(e) => {
|
Err(e) => {
|
||||||
println!("{:#?}", e);
|
println!("{:#?}", e);
|
||||||
if i > 5 { panic!("Node failure: {}:{}:{}", ip, rpc, zmq); }
|
if i > 5 {
|
||||||
std::thread::sleep(std::time::Duration::from_secs(3));
|
use std::fmt::Write;
|
||||||
|
writeln!(failures, "Node failure: {ip}:{rpc}:{zmq}");
|
||||||
|
failure_count += 1;
|
||||||
|
continue 'outer;
|
||||||
|
}
|
||||||
|
std::thread::sleep(std::time::Duration::from_secs(2));
|
||||||
i += 1;
|
i += 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -475,5 +486,18 @@ mod test {
|
||||||
assert!(getinfo.jsonrpc == "2.0");
|
assert!(getinfo.jsonrpc == "2.0");
|
||||||
n += 1;
|
n += 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let failure_percent = failure_count as f32 / HALF_REMOTE_NODES as f32;
|
||||||
|
|
||||||
|
// If more than half the nodes fail, something
|
||||||
|
// is definitely wrong, fail this test.
|
||||||
|
if failure_count > HALF_REMOTE_NODES {
|
||||||
|
panic!("[{failure_percent:.2}% of nodes failed, failure log:\n{failures}");
|
||||||
|
// If some failures happened, log.
|
||||||
|
} else if failure_count != 0 {
|
||||||
|
eprintln!("[{failure_count}] nodes failed ({failure_percent:.2}%):\n{failures}");
|
||||||
|
} else {
|
||||||
|
println!("No nodes failed - all OK");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue