fix tests, add xmrig_set_mining test

This commit is contained in:
hinto.janai 2023-04-19 11:31:36 -04:00
parent 1fcb827181
commit 8fbd949342
No known key found for this signature in database
GPG key ID: D47CE05FA175A499
5 changed files with 36 additions and 26 deletions

View file

@ -614,7 +614,7 @@ These are community nodes that **DON'T** have ZMQ enabled but are fast and well-
### General Info ### General Info
You need [`cargo`](https://www.rust-lang.org/learn/get-started), Rust's build tool and package manager. You need [`cargo`](https://www.rust-lang.org/learn/get-started), Rust's build tool and package manager.
There are `40` unit tests, you should probably run: There are `41` unit tests, you should probably run:
``` ```
cargo test cargo test
``` ```

View file

@ -1405,7 +1405,6 @@ mod test {
#[test] #[test]
fn create_and_serde_gupax_p2pool_api() { fn create_and_serde_gupax_p2pool_api() {
use crate::disk::GupaxP2poolApi; use crate::disk::GupaxP2poolApi;
use crate::regex::P2poolRegex;
use crate::xmr::PayoutOrd; use crate::xmr::PayoutOrd;
use crate::xmr::AtomicUnit; use crate::xmr::AtomicUnit;
@ -1421,7 +1420,7 @@ mod test {
api.log = "NOTICE 2022-01-27 01:30:23.1377 P2Pool You received a payout of 0.000000000001 XMR in block 2642816".to_string(); api.log = "NOTICE 2022-01-27 01:30:23.1377 P2Pool You received a payout of 0.000000000001 XMR in block 2642816".to_string();
api.payout_u64 = 1; api.payout_u64 = 1;
api.xmr = AtomicUnit::from_u64(2); api.xmr = AtomicUnit::from_u64(2);
let (date, atomic_unit, block) = PayoutOrd::parse_raw_payout_line(&api.log, &P2poolRegex::new()); let (date, atomic_unit, block) = PayoutOrd::parse_raw_payout_line(&api.log);
let formatted_log_line = GupaxP2poolApi::format_payout(&date, &atomic_unit, &block); let formatted_log_line = GupaxP2poolApi::format_payout(&date, &atomic_unit, &block);
GupaxP2poolApi::write_to_all_files(&api, &formatted_log_line).unwrap(); GupaxP2poolApi::write_to_all_files(&api, &formatted_log_line).unwrap();
println!("AFTER WRITE: {:#?}", api); println!("AFTER WRITE: {:#?}", api);

View file

@ -2075,6 +2075,26 @@ mod test {
drop(p); drop(p);
} }
#[test]
fn set_xmrig_mining() {
use crate::helper::PubXmrigApi;
use std::sync::{Arc,Mutex};
let public = Arc::new(Mutex::new(PubXmrigApi::new()));
let output_parse = Arc::new(Mutex::new(String::from("[2022-02-12 12:49:30.311] net no active pools, stop mining")));
let output_pub = Arc::new(Mutex::new(String::new()));
let elapsed = std::time::Duration::from_secs(60);
let process = Arc::new(Mutex::new(Process::new(ProcessName::Xmrig, "".to_string(), PathBuf::new())));
process.lock().unwrap().state = ProcessState::Alive;
PubXmrigApi::update_from_output(&public, &output_parse, &output_pub, elapsed, &process);
println!("{:#?}", process);
assert!(process.lock().unwrap().state == ProcessState::NotMining);
let output_parse = Arc::new(Mutex::new(String::from("[2022-02-12 12:49:30.311] net new job from 192.168.2.1:3333 diff 402K algo rx/0 height 2241142 (11 tx)")));
PubXmrigApi::update_from_output(&public, &output_parse, &output_pub, elapsed, &process);
assert!(process.lock().unwrap().state == ProcessState::Alive);
}
#[test] #[test]
fn serde_priv_p2pool_local_api() { fn serde_priv_p2pool_local_api() {
let data = let data =

View file

@ -1887,25 +1887,6 @@ path_xmr: {:#?}\n
//---------------------------------------------------------------------------------------------------- TESTS //---------------------------------------------------------------------------------------------------- TESTS
#[cfg(test)] #[cfg(test)]
mod test { mod test {
#[test]
fn build_regex() {
use regex::Regex;
let r = crate::Regexes::new();
assert!(Regex::is_match(&r.name, "_this_ is... a n-a-m-e."));
assert!(Regex::is_match(&r.address, "44hintoFpuo3ugKfcqJvh5BmrsTRpnTasJmetKC4VXCt6QDtbHVuixdTtsm6Ptp7Y8haXnJ6j8Gj2dra8CKy5ewz7Vi9CYW"));
assert!(Regex::is_match(&r.ipv4, "192.168.1.2"));
assert!(Regex::is_match(&r.ipv4, "127.0.0.1"));
assert!(Regex::is_match(&r.domain, "my.node.com"));
assert!(Regex::is_match(&r.domain, "my.monero-node123.net"));
assert!(Regex::is_match(&r.domain, "www.my-node.org"));
assert!(Regex::is_match(&r.domain, "www.my-monero-node123.io"));
for i in 1..=65535 {
assert!(Regex::is_match(&r.port, &i.to_string()));
}
assert!(!Regex::is_match(&r.port, "0"));
assert!(!Regex::is_match(&r.port, "65536"));
}
#[test] #[test]
fn detect_benchmark_cpu() { fn detect_benchmark_cpu() {
use super::{Benchmark,cmp_f64}; use super::{Benchmark,cmp_f64};

View file

@ -119,10 +119,12 @@ impl XmrigRegex {
//---------------------------------------------------------------------------------------------------- TESTS //---------------------------------------------------------------------------------------------------- TESTS
#[cfg(test)] #[cfg(test)]
mod test { mod test {
use regex::Regex;
use super::*;
#[test] #[test]
fn build_regexes() { fn build_regexes() {
use regex::Regex; let r = Regexes::new();
let r = crate::Regexes::new();
assert!(Regex::is_match(&r.name, "_this_ is... a n-a-m-e.")); assert!(Regex::is_match(&r.name, "_this_ is... a n-a-m-e."));
assert!(Regex::is_match(&r.address, "44hintoFpuo3ugKfcqJvh5BmrsTRpnTasJmetKC4VXCt6QDtbHVuixdTtsm6Ptp7Y8haXnJ6j8Gj2dra8CKy5ewz7Vi9CYW")); assert!(Regex::is_match(&r.address, "44hintoFpuo3ugKfcqJvh5BmrsTRpnTasJmetKC4VXCt6QDtbHVuixdTtsm6Ptp7Y8haXnJ6j8Gj2dra8CKy5ewz7Vi9CYW"));
assert!(Regex::is_match(&r.ipv4, "192.168.1.2")); assert!(Regex::is_match(&r.ipv4, "192.168.1.2"));
@ -140,8 +142,7 @@ mod test {
#[test] #[test]
fn build_p2pool_regex() { fn build_p2pool_regex() {
use regex::Regex; let r = P2poolRegex::new();
let r = crate::P2poolRegex::new();
let text = "NOTICE 2022-11-11 11:11:11.1111 P2Pool You received a payout of 0.111111111111 XMR in block 1111111"; let text = "NOTICE 2022-11-11 11:11:11.1111 P2Pool You received a payout of 0.111111111111 XMR in block 1111111";
let text2 = "2022-11-11 11:11:11.1111 | 0.111111111111 XMR | Block 1,111,111"; let text2 = "2022-11-11 11:11:11.1111 | 0.111111111111 XMR | Block 1,111,111";
let text3 = "NOTICE 2020-12-11 12:35:41.3150 SideChain SYNCHRONIZED"; let text3 = "NOTICE 2020-12-11 12:35:41.3150 SideChain SYNCHRONIZED";
@ -153,4 +154,13 @@ mod test {
assert_eq!(r.block_comma.find(text2).unwrap().as_str(), "1,111,111"); assert_eq!(r.block_comma.find(text2).unwrap().as_str(), "1,111,111");
assert_eq!(r.synchronized.find(text3).unwrap().as_str(), "SYNCHRONIZED"); assert_eq!(r.synchronized.find(text3).unwrap().as_str(), "SYNCHRONIZED");
} }
#[test]
fn build_xmrig_regex() {
let r = XmrigRegex::new();
let text = "[2022-02-12 12:49:30.311] net no active pools, stop mining";
let text2 = "[2022-02-12 12:49:30.311] net new job from 192.168.2.1:3333 diff 402K algo rx/0 height 2241142 (11 tx)";
assert_eq!(r.not_mining.find(text).unwrap().as_str(), "no active pools, stop mining");
assert_eq!(r.new_job.find(text2).unwrap().as_str(), "new job");
}
} }