Skip to content

Commit

Permalink
Test connection setup between pool and template_provider
Browse files Browse the repository at this point in the history
Starts a Template Provider and Pool and checks that both roles send the
corrects messages on first connection.
  • Loading branch information
jbesraa committed Oct 3, 2024
1 parent dc01703 commit 940ead7
Show file tree
Hide file tree
Showing 4 changed files with 36 additions and 4 deletions.
4 changes: 4 additions & 0 deletions .github/workflows/test.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,10 @@ jobs:
cargo build --manifest-path=roles/Cargo.toml
cargo build --manifest-path=utils/Cargo.toml
- name: Roles Integration Tests
run: |
cargo test --manifest-path=roles/Cargo.toml --verbose --test '*' -- --nocapture
- name: Run sv1-client-and-server example
run: |
cargo run --manifest-path=examples/sv1-client-and-server/Cargo.toml --bin client_and_server -- 60
Expand Down
2 changes: 1 addition & 1 deletion roles/Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

12 changes: 9 additions & 3 deletions roles/tests-integration/tests/common/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -214,7 +214,11 @@ impl TestPoolSv2 {
template_provider_address: Option<SocketAddr>,
) -> Self {
use pool_sv2::mining_pool::{CoinbaseOutput, Configuration};
let pool_port = get_available_port();
let pool_port = if let Some(listen_addr) = listening_address {
listen_addr.port()
} else {
get_available_port()
};
let listening_address = listening_address
.unwrap_or(SocketAddr::from_str(&format!("127.0.0.1:{}", pool_port)).unwrap());
let is_pool_port_open = is_port_open(listening_address);
Expand Down Expand Up @@ -243,8 +247,10 @@ impl TestPoolSv2 {
cert_validity_sec,
pool_signature,
);
let template_provider_config =
pool_sv2::mining_pool::TemplateProviderConfig::new(tp_address, None);
let template_provider_config = pool_sv2::mining_pool::TemplateProviderConfig::new(
tp_address,
Some(authority_public_key),
);
let authority_config =
pool_sv2::mining_pool::AuthorityConfig::new(authority_public_key, authority_secret_key);
let config = Configuration::new(
Expand Down
22 changes: 22 additions & 0 deletions roles/tests-integration/tests/pool_integration.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
mod common;

use const_sv2::{
MESSAGE_TYPE_COINBASE_OUTPUT_DATA_SIZE, MESSAGE_TYPE_NEW_TEMPLATE,
MESSAGE_TYPE_SETUP_CONNECTION, MESSAGE_TYPE_SETUP_CONNECTION_SUCCESS,
MESSAGE_TYPE_SET_NEW_PREV_HASH,
};

#[tokio::test]
async fn success_pool_template_provider_connection() {
let sniffer_addr = common::get_available_address();
let tp_addr = common::get_available_address();
let pool_addr = common::get_available_address();
let _tp = common::start_template_provider(tp_addr.port()).await;
let sniffer = common::start_sniffer(tp_addr, sniffer_addr).await;
let _ = common::start_pool(Some(pool_addr), Some(sniffer_addr)).await;
assert!(sniffer.expect_downstream_message(MESSAGE_TYPE_SETUP_CONNECTION));
assert!(sniffer.expect_upstream_message(MESSAGE_TYPE_SETUP_CONNECTION_SUCCESS));
assert!(sniffer.expect_downstream_message(MESSAGE_TYPE_COINBASE_OUTPUT_DATA_SIZE));
assert!(sniffer.expect_upstream_message(MESSAGE_TYPE_NEW_TEMPLATE));
assert!(sniffer.expect_upstream_message(MESSAGE_TYPE_SET_NEW_PREV_HASH));
}

0 comments on commit 940ead7

Please sign in to comment.