Skip to content

Commit

Permalink
add getzmqnotifications integration test
Browse files Browse the repository at this point in the history
  • Loading branch information
antonilol committed Apr 24, 2024
1 parent b8fa99d commit a9be191
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 2 deletions.
4 changes: 3 additions & 1 deletion integration_test/run.sh
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,9 @@ bitcoind -regtest $BLOCKFILTERARG $FALLBACKFEEARG \
-rpcport=12349 \
-server=1 \
-txindex=1 \
-printtoconsole=0 &
-printtoconsole=0 \
-zmqpubrawblock=tcp://0.0.0.0:28332 \
-zmqpubrawtx=tcp://0.0.0.0:28333 &
PID2=$!

# Let it connect to the other node.
Expand Down
33 changes: 32 additions & 1 deletion integration_test/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ use bitcoin::{
Transaction, TxIn, TxOut, Txid, Witness,
};
use bitcoincore_rpc::bitcoincore_rpc_json::{
GetBlockTemplateModes, GetBlockTemplateRules, ScanTxOutRequest,
GetBlockTemplateModes, GetBlockTemplateRules, GetZmqNotificationsResult, ScanTxOutRequest,
};

lazy_static! {
Expand Down Expand Up @@ -226,6 +226,7 @@ fn main() {
test_add_ban(&cl);
test_set_network_active(&cl);
test_get_index_info(&cl);
test_get_zmq_notifications(&cl);
test_stop(cl);
}

Expand Down Expand Up @@ -1426,6 +1427,36 @@ fn test_get_index_info(cl: &Client) {
}
}

fn test_get_zmq_notifications(cl: &Client) {
let mut zmq_info = cl.get_zmq_notifications().unwrap();

// it doesn't matter in which order Bitcoin Core returns the result,
// but checking it is easier if it has a known order

// sort_by_key does not allow returning references to parameters of the compare function
// (removing the lifetime from the return type mimics this behavior, but we don't want it)
fn compare_fn(result: &GetZmqNotificationsResult) -> impl Ord + '_ {
(&result.address, &result.notification_type, result.hwm)
}
zmq_info.sort_by(|a, b| compare_fn(a).cmp(&compare_fn(b)));

assert!(
zmq_info
== [
GetZmqNotificationsResult {
notification_type: "pubrawblock".to_owned(),
address: "tcp://0.0.0.0:28332".to_owned(),
hwm: 1000
},
GetZmqNotificationsResult {
notification_type: "pubrawtx".to_owned(),
address: "tcp://0.0.0.0:28333".to_owned(),
hwm: 1000
},
]
);
}

fn test_stop(cl: Client) {
println!("Stopping: '{}'", cl.stop().unwrap());
}

0 comments on commit a9be191

Please sign in to comment.