184 lines
5.7 KiB
Rust
184 lines
5.7 KiB
Rust
//! `zebrad` config-specific shared code for the `zebrad` acceptance tests.
|
|
//!
|
|
//! # Warning
|
|
//!
|
|
//! Test functions in this file will not be run.
|
|
//! This file is only for test library code.
|
|
|
|
use std::{
|
|
env,
|
|
net::SocketAddr,
|
|
path::{Path, PathBuf},
|
|
time::Duration,
|
|
};
|
|
|
|
use color_eyre::eyre::Result;
|
|
use tempfile::TempDir;
|
|
|
|
use zebra_chain::parameters::Network;
|
|
use zebra_test::{command::TestChild, net::random_known_port};
|
|
use zebrad::{
|
|
components::{mempool, sync, tracing},
|
|
config::ZebradConfig,
|
|
};
|
|
|
|
use crate::common::cached_state::DATABASE_FORMAT_CHECK_INTERVAL;
|
|
|
|
/// Returns a config with:
|
|
/// - a Zcash listener on an unused port on IPv4 localhost, and
|
|
/// - an ephemeral state,
|
|
/// - the minimum syncer lookahead limit, and
|
|
/// - shorter task intervals, to improve test coverage.
|
|
pub fn default_test_config(net: &Network) -> Result<ZebradConfig> {
|
|
const TEST_DURATION: Duration = Duration::from_secs(30);
|
|
|
|
let network = zebra_network::Config {
|
|
network: net.clone(),
|
|
// The OS automatically chooses an unused port.
|
|
listen_addr: "127.0.0.1:0".parse()?,
|
|
crawl_new_peer_interval: TEST_DURATION,
|
|
..zebra_network::Config::default()
|
|
};
|
|
|
|
let sync = sync::Config {
|
|
// Avoid downloading unnecessary blocks.
|
|
checkpoint_verify_concurrency_limit: sync::MIN_CHECKPOINT_CONCURRENCY_LIMIT,
|
|
..sync::Config::default()
|
|
};
|
|
|
|
let mempool = mempool::Config {
|
|
eviction_memory_time: TEST_DURATION,
|
|
..mempool::Config::default()
|
|
};
|
|
|
|
let consensus = zebra_consensus::Config::default();
|
|
|
|
let force_use_color = !matches!(
|
|
env::var("ZEBRA_FORCE_USE_COLOR"),
|
|
Err(env::VarError::NotPresent)
|
|
);
|
|
|
|
let mut tracing = tracing::Config::default();
|
|
tracing.force_use_color = force_use_color;
|
|
|
|
let mut state = zebra_state::Config::ephemeral();
|
|
state.debug_validity_check_interval = Some(DATABASE_FORMAT_CHECK_INTERVAL);
|
|
|
|
// These are the ZF funding stream addresses for mainnet and testnet.
|
|
#[allow(unused_mut)]
|
|
let mut mining = zebra_rpc::config::mining::Config::default();
|
|
|
|
#[cfg(feature = "getblocktemplate-rpcs")]
|
|
{
|
|
let miner_address = if network.network.is_a_test_network() {
|
|
// Assume test networks all use the same address prefix and format
|
|
"t27eWDgjFYJGVXmzrXeVjnb5J3uXDM9xH9v"
|
|
} else {
|
|
"t3dvVE3SQEi7kqNzwrfNePxZ1d4hUyztBA1"
|
|
};
|
|
|
|
mining.miner_address = Some(miner_address.parse().expect("hard-coded address is valid"));
|
|
}
|
|
|
|
Ok(ZebradConfig {
|
|
network,
|
|
state,
|
|
sync,
|
|
mempool,
|
|
consensus,
|
|
tracing,
|
|
mining,
|
|
..ZebradConfig::default()
|
|
})
|
|
}
|
|
|
|
pub fn persistent_test_config(network: &Network) -> Result<ZebradConfig> {
|
|
let mut config = default_test_config(network)?;
|
|
config.state.ephemeral = false;
|
|
Ok(config)
|
|
}
|
|
|
|
pub fn external_address_test_config(network: &Network) -> Result<ZebradConfig> {
|
|
let mut config = default_test_config(network)?;
|
|
config.network.external_addr = Some("127.0.0.1:0".parse()?);
|
|
Ok(config)
|
|
}
|
|
|
|
pub fn testdir() -> Result<TempDir> {
|
|
tempfile::Builder::new()
|
|
.prefix("zebrad_tests")
|
|
.tempdir()
|
|
.map_err(Into::into)
|
|
}
|
|
|
|
/// Get the directory where we have different config files.
|
|
pub fn configs_dir() -> PathBuf {
|
|
Path::new(env!("CARGO_MANIFEST_DIR")).join("tests/common/configs")
|
|
}
|
|
|
|
/// Given a config file name, return full path to it.
|
|
pub fn config_file_full_path(config_file: PathBuf) -> PathBuf {
|
|
let path = configs_dir().join(config_file);
|
|
Path::new(&path).into()
|
|
}
|
|
|
|
/// Returns a `zebrad` config with a random known RPC port.
|
|
///
|
|
/// Set `parallel_cpu_threads` to true to auto-configure based on the number of CPU cores.
|
|
pub fn random_known_rpc_port_config(
|
|
parallel_cpu_threads: bool,
|
|
network: &Network,
|
|
) -> Result<ZebradConfig> {
|
|
// [Note on port conflict](#Note on port conflict)
|
|
let listen_port = random_known_port();
|
|
rpc_port_config(listen_port, parallel_cpu_threads, network)
|
|
}
|
|
|
|
/// Returns a `zebrad` config with an OS-assigned RPC port.
|
|
///
|
|
/// Set `parallel_cpu_threads` to true to auto-configure based on the number of CPU cores.
|
|
pub fn os_assigned_rpc_port_config(
|
|
parallel_cpu_threads: bool,
|
|
network: &Network,
|
|
) -> Result<ZebradConfig> {
|
|
rpc_port_config(0, parallel_cpu_threads, network)
|
|
}
|
|
|
|
/// Returns a `zebrad` config with the provided RPC port.
|
|
///
|
|
/// Set `parallel_cpu_threads` to true to auto-configure based on the number of CPU cores.
|
|
pub fn rpc_port_config(
|
|
listen_port: u16,
|
|
parallel_cpu_threads: bool,
|
|
network: &Network,
|
|
) -> Result<ZebradConfig> {
|
|
let listen_ip = "127.0.0.1".parse().expect("hard-coded IP is valid");
|
|
let zebra_rpc_listener = SocketAddr::new(listen_ip, listen_port);
|
|
|
|
// Write a configuration that has the rpc listen_addr option set
|
|
// TODO: split this config into another function?
|
|
let mut config = default_test_config(network)?;
|
|
config.rpc.listen_addr = Some(zebra_rpc_listener);
|
|
if parallel_cpu_threads {
|
|
// Auto-configure to the number of CPU cores: most users configure this
|
|
config.rpc.parallel_cpu_threads = 0;
|
|
} else {
|
|
// Default config, users who want to detect port conflicts configure this
|
|
config.rpc.parallel_cpu_threads = 1;
|
|
}
|
|
|
|
Ok(config)
|
|
}
|
|
|
|
/// Reads Zebra's RPC server listen address from a testchild's logs
|
|
pub fn read_listen_addr_from_logs(
|
|
child: &mut TestChild<TempDir>,
|
|
expected_msg: &str,
|
|
) -> Result<SocketAddr> {
|
|
let line = child.expect_stdout_line_matches(expected_msg)?;
|
|
let rpc_addr_position =
|
|
line.find(expected_msg).expect("already checked for match") + expected_msg.len();
|
|
let rpc_addr = line[rpc_addr_position..].trim().to_string();
|
|
Ok(rpc_addr.parse()?)
|
|
}
|