rpc: use minimal mode by default
This commit is contained in:
parent
fb0e71946f
commit
eac4a6df68
|
@ -673,7 +673,7 @@ pub mod test {
|
||||||
#[test]
|
#[test]
|
||||||
fn test_accounts_cluster_bench() {
|
fn test_accounts_cluster_bench() {
|
||||||
solana_logger::setup();
|
solana_logger::setup();
|
||||||
let validator_config = ValidatorConfig::default();
|
let validator_config = ValidatorConfig::default_for_test();
|
||||||
let num_nodes = 1;
|
let num_nodes = 1;
|
||||||
let mut config = ClusterConfig {
|
let mut config = ClusterConfig {
|
||||||
cluster_lamports: 10_000_000,
|
cluster_lamports: 10_000_000,
|
||||||
|
|
|
@ -29,7 +29,7 @@ fn test_bench_tps_local_cluster(config: Config) {
|
||||||
node_stakes: vec![999_990; NUM_NODES],
|
node_stakes: vec![999_990; NUM_NODES],
|
||||||
cluster_lamports: 200_000_000,
|
cluster_lamports: 200_000_000,
|
||||||
validator_configs: make_identical_validator_configs(
|
validator_configs: make_identical_validator_configs(
|
||||||
&ValidatorConfig::default(),
|
&ValidatorConfig::default_for_test(),
|
||||||
NUM_NODES,
|
NUM_NODES,
|
||||||
),
|
),
|
||||||
native_instruction_processors,
|
native_instruction_processors,
|
||||||
|
|
|
@ -228,6 +228,14 @@ impl Default for ValidatorConfig {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl ValidatorConfig {
|
||||||
|
pub fn default_for_test() -> Self {
|
||||||
|
let mut config = Self::default();
|
||||||
|
config.rpc_config.full_api = true;
|
||||||
|
config
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// `ValidatorStartProgress` contains status information that is surfaced to the node operator over
|
// `ValidatorStartProgress` contains status information that is surfaced to the node operator over
|
||||||
// the admin RPC channel to help them to follow the general progress of node startup without
|
// the admin RPC channel to help them to follow the general progress of node startup without
|
||||||
// having to watch log messages.
|
// having to watch log messages.
|
||||||
|
@ -650,7 +658,7 @@ impl Validator {
|
||||||
leader_schedule_cache.clone(),
|
leader_schedule_cache.clone(),
|
||||||
max_complete_transaction_status_slot,
|
max_complete_transaction_status_slot,
|
||||||
)),
|
)),
|
||||||
if config.rpc_config.minimal_api {
|
if !config.rpc_config.full_api {
|
||||||
None
|
None
|
||||||
} else {
|
} else {
|
||||||
let (trigger, pubsub_service) = PubSubService::new(
|
let (trigger, pubsub_service) = PubSubService::new(
|
||||||
|
@ -1765,7 +1773,7 @@ mod tests {
|
||||||
let voting_keypair = Arc::new(Keypair::new());
|
let voting_keypair = Arc::new(Keypair::new());
|
||||||
let config = ValidatorConfig {
|
let config = ValidatorConfig {
|
||||||
rpc_addrs: Some((validator_node.info.rpc, validator_node.info.rpc_pubsub)),
|
rpc_addrs: Some((validator_node.info.rpc, validator_node.info.rpc_pubsub)),
|
||||||
..ValidatorConfig::default()
|
..ValidatorConfig::default_for_test()
|
||||||
};
|
};
|
||||||
let start_progress = Arc::new(RwLock::new(ValidatorStartProgress::default()));
|
let start_progress = Arc::new(RwLock::new(ValidatorStartProgress::default()));
|
||||||
let validator = Validator::new(
|
let validator = Validator::new(
|
||||||
|
@ -1847,7 +1855,7 @@ mod tests {
|
||||||
let vote_account_keypair = Keypair::new();
|
let vote_account_keypair = Keypair::new();
|
||||||
let config = ValidatorConfig {
|
let config = ValidatorConfig {
|
||||||
rpc_addrs: Some((validator_node.info.rpc, validator_node.info.rpc_pubsub)),
|
rpc_addrs: Some((validator_node.info.rpc, validator_node.info.rpc_pubsub)),
|
||||||
..ValidatorConfig::default()
|
..ValidatorConfig::default_for_test()
|
||||||
};
|
};
|
||||||
Validator::new(
|
Validator::new(
|
||||||
validator_node,
|
validator_node,
|
||||||
|
@ -1890,7 +1898,7 @@ mod tests {
|
||||||
|
|
||||||
let (genesis_config, _mint_keypair) = create_genesis_config(1);
|
let (genesis_config, _mint_keypair) = create_genesis_config(1);
|
||||||
let bank = Arc::new(Bank::new_for_tests(&genesis_config));
|
let bank = Arc::new(Bank::new_for_tests(&genesis_config));
|
||||||
let mut config = ValidatorConfig::default();
|
let mut config = ValidatorConfig::default_for_test();
|
||||||
let rpc_override_health_check = Arc::new(AtomicBool::new(false));
|
let rpc_override_health_check = Arc::new(AtomicBool::new(false));
|
||||||
let start_progress = Arc::new(RwLock::new(ValidatorStartProgress::default()));
|
let start_progress = Arc::new(RwLock::new(ValidatorStartProgress::default()));
|
||||||
|
|
||||||
|
|
|
@ -50,7 +50,7 @@ To enable specific scenarios, the cluster needs to be booted with special config
|
||||||
For example:
|
For example:
|
||||||
|
|
||||||
```text
|
```text
|
||||||
let mut validator_config = ValidatorConfig::default();
|
let mut validator_config = ValidatorConfig::default_for_test();
|
||||||
let local = LocalCluster::new_with_config(
|
let local = LocalCluster::new_with_config(
|
||||||
num_nodes,
|
num_nodes,
|
||||||
10_000,
|
10_000,
|
||||||
|
@ -66,7 +66,7 @@ For example, there is a bug that shows that the cluster fails when it is flooded
|
||||||
Configure the RPC service:
|
Configure the RPC service:
|
||||||
|
|
||||||
```text
|
```text
|
||||||
let mut validator_config = ValidatorConfig::default();
|
let mut validator_config = ValidatorConfig::default_for_test();
|
||||||
validator_config.rpc_config.enable_rpc_gossip_push = true;
|
validator_config.rpc_config.enable_rpc_gossip_push = true;
|
||||||
validator_config.rpc_config.enable_rpc_gossip_refresh_active_set = true;
|
validator_config.rpc_config.enable_rpc_gossip_refresh_active_set = true;
|
||||||
```
|
```
|
||||||
|
|
|
@ -122,7 +122,7 @@ impl LocalCluster {
|
||||||
node_stakes: stakes,
|
node_stakes: stakes,
|
||||||
cluster_lamports,
|
cluster_lamports,
|
||||||
validator_configs: make_identical_validator_configs(
|
validator_configs: make_identical_validator_configs(
|
||||||
&ValidatorConfig::default(),
|
&ValidatorConfig::default_for_test(),
|
||||||
num_nodes,
|
num_nodes,
|
||||||
),
|
),
|
||||||
..ClusterConfig::default()
|
..ClusterConfig::default()
|
||||||
|
|
|
@ -257,7 +257,7 @@ pub fn run_cluster_partition<C>(
|
||||||
let enable_partition = Arc::new(AtomicBool::new(true));
|
let enable_partition = Arc::new(AtomicBool::new(true));
|
||||||
let mut validator_config = ValidatorConfig {
|
let mut validator_config = ValidatorConfig {
|
||||||
enable_partition: Some(enable_partition.clone()),
|
enable_partition: Some(enable_partition.clone()),
|
||||||
..ValidatorConfig::default()
|
..ValidatorConfig::default_for_test()
|
||||||
};
|
};
|
||||||
|
|
||||||
// Returns:
|
// Returns:
|
||||||
|
@ -375,13 +375,13 @@ pub fn test_faulty_node(
|
||||||
|
|
||||||
let error_validator_config = ValidatorConfig {
|
let error_validator_config = ValidatorConfig {
|
||||||
broadcast_stage_type: faulty_node_type,
|
broadcast_stage_type: faulty_node_type,
|
||||||
..ValidatorConfig::default()
|
..ValidatorConfig::default_for_test()
|
||||||
};
|
};
|
||||||
let mut validator_configs = Vec::with_capacity(num_nodes);
|
let mut validator_configs = Vec::with_capacity(num_nodes);
|
||||||
|
|
||||||
// First validator is the bootstrap leader with the malicious broadcast logic.
|
// First validator is the bootstrap leader with the malicious broadcast logic.
|
||||||
validator_configs.push(error_validator_config);
|
validator_configs.push(error_validator_config);
|
||||||
validator_configs.resize_with(num_nodes, ValidatorConfig::default);
|
validator_configs.resize_with(num_nodes, ValidatorConfig::default_for_test);
|
||||||
|
|
||||||
let mut validator_keys = Vec::with_capacity(num_nodes);
|
let mut validator_keys = Vec::with_capacity(num_nodes);
|
||||||
validator_keys.resize_with(num_nodes, || (Arc::new(Keypair::new()), true));
|
validator_keys.resize_with(num_nodes, || (Arc::new(Keypair::new()), true));
|
||||||
|
|
|
@ -87,7 +87,10 @@ fn test_local_cluster_start_and_exit_with_config() {
|
||||||
solana_logger::setup();
|
solana_logger::setup();
|
||||||
const NUM_NODES: usize = 1;
|
const NUM_NODES: usize = 1;
|
||||||
let mut config = ClusterConfig {
|
let mut config = ClusterConfig {
|
||||||
validator_configs: make_identical_validator_configs(&ValidatorConfig::default(), NUM_NODES),
|
validator_configs: make_identical_validator_configs(
|
||||||
|
&ValidatorConfig::default_for_test(),
|
||||||
|
NUM_NODES,
|
||||||
|
),
|
||||||
node_stakes: vec![3; NUM_NODES],
|
node_stakes: vec![3; NUM_NODES],
|
||||||
cluster_lamports: 100,
|
cluster_lamports: 100,
|
||||||
ticks_per_slot: 8,
|
ticks_per_slot: 8,
|
||||||
|
@ -107,7 +110,7 @@ fn test_ledger_cleanup_service() {
|
||||||
let num_nodes = 3;
|
let num_nodes = 3;
|
||||||
let validator_config = ValidatorConfig {
|
let validator_config = ValidatorConfig {
|
||||||
max_ledger_shreds: Some(100),
|
max_ledger_shreds: Some(100),
|
||||||
..ValidatorConfig::default()
|
..ValidatorConfig::default_for_test()
|
||||||
};
|
};
|
||||||
let mut config = ClusterConfig {
|
let mut config = ClusterConfig {
|
||||||
cluster_lamports: 10_000,
|
cluster_lamports: 10_000,
|
||||||
|
@ -293,7 +296,7 @@ fn test_leader_failure_4() {
|
||||||
solana_logger::setup_with_default(RUST_LOG_FILTER);
|
solana_logger::setup_with_default(RUST_LOG_FILTER);
|
||||||
error!("test_leader_failure_4");
|
error!("test_leader_failure_4");
|
||||||
let num_nodes = 4;
|
let num_nodes = 4;
|
||||||
let validator_config = ValidatorConfig::default();
|
let validator_config = ValidatorConfig::default_for_test();
|
||||||
let mut config = ClusterConfig {
|
let mut config = ClusterConfig {
|
||||||
cluster_lamports: 10_000,
|
cluster_lamports: 10_000,
|
||||||
node_stakes: vec![100; 4],
|
node_stakes: vec![100; 4],
|
||||||
|
@ -384,7 +387,7 @@ fn test_cluster_partition_1_1_1() {
|
||||||
fn test_two_unbalanced_stakes() {
|
fn test_two_unbalanced_stakes() {
|
||||||
solana_logger::setup_with_default(RUST_LOG_FILTER);
|
solana_logger::setup_with_default(RUST_LOG_FILTER);
|
||||||
error!("test_two_unbalanced_stakes");
|
error!("test_two_unbalanced_stakes");
|
||||||
let validator_config = ValidatorConfig::default();
|
let validator_config = ValidatorConfig::default_for_test();
|
||||||
let num_ticks_per_second = 100;
|
let num_ticks_per_second = 100;
|
||||||
let num_ticks_per_slot = 10;
|
let num_ticks_per_slot = 10;
|
||||||
let num_slots_per_epoch = MINIMUM_SLOTS_PER_EPOCH as u64;
|
let num_slots_per_epoch = MINIMUM_SLOTS_PER_EPOCH as u64;
|
||||||
|
@ -423,7 +426,10 @@ fn test_forwarding() {
|
||||||
let mut config = ClusterConfig {
|
let mut config = ClusterConfig {
|
||||||
node_stakes: vec![999_990, 3],
|
node_stakes: vec![999_990, 3],
|
||||||
cluster_lamports: 2_000_000,
|
cluster_lamports: 2_000_000,
|
||||||
validator_configs: make_identical_validator_configs(&ValidatorConfig::default(), 2),
|
validator_configs: make_identical_validator_configs(
|
||||||
|
&ValidatorConfig::default_for_test(),
|
||||||
|
2,
|
||||||
|
),
|
||||||
..ClusterConfig::default()
|
..ClusterConfig::default()
|
||||||
};
|
};
|
||||||
let cluster = LocalCluster::new(&mut config, SocketAddrSpace::Unspecified);
|
let cluster = LocalCluster::new(&mut config, SocketAddrSpace::Unspecified);
|
||||||
|
@ -454,7 +460,7 @@ fn test_restart_node() {
|
||||||
error!("test_restart_node");
|
error!("test_restart_node");
|
||||||
let slots_per_epoch = MINIMUM_SLOTS_PER_EPOCH * 2;
|
let slots_per_epoch = MINIMUM_SLOTS_PER_EPOCH * 2;
|
||||||
let ticks_per_slot = 16;
|
let ticks_per_slot = 16;
|
||||||
let validator_config = ValidatorConfig::default();
|
let validator_config = ValidatorConfig::default_for_test();
|
||||||
let mut cluster = LocalCluster::new(
|
let mut cluster = LocalCluster::new(
|
||||||
&mut ClusterConfig {
|
&mut ClusterConfig {
|
||||||
node_stakes: vec![100; 1],
|
node_stakes: vec![100; 1],
|
||||||
|
@ -498,7 +504,10 @@ fn test_mainnet_beta_cluster_type() {
|
||||||
cluster_type: ClusterType::MainnetBeta,
|
cluster_type: ClusterType::MainnetBeta,
|
||||||
node_stakes: vec![100; 1],
|
node_stakes: vec![100; 1],
|
||||||
cluster_lamports: 1_000,
|
cluster_lamports: 1_000,
|
||||||
validator_configs: make_identical_validator_configs(&ValidatorConfig::default(), 1),
|
validator_configs: make_identical_validator_configs(
|
||||||
|
&ValidatorConfig::default_for_test(),
|
||||||
|
1,
|
||||||
|
),
|
||||||
..ClusterConfig::default()
|
..ClusterConfig::default()
|
||||||
};
|
};
|
||||||
let cluster = LocalCluster::new(&mut config, SocketAddrSpace::Unspecified);
|
let cluster = LocalCluster::new(&mut config, SocketAddrSpace::Unspecified);
|
||||||
|
@ -1577,7 +1586,7 @@ fn test_fake_shreds_broadcast_leader() {
|
||||||
#[test]
|
#[test]
|
||||||
fn test_wait_for_max_stake() {
|
fn test_wait_for_max_stake() {
|
||||||
solana_logger::setup_with_default(RUST_LOG_FILTER);
|
solana_logger::setup_with_default(RUST_LOG_FILTER);
|
||||||
let validator_config = ValidatorConfig::default();
|
let validator_config = ValidatorConfig::default_for_test();
|
||||||
let mut config = ClusterConfig {
|
let mut config = ClusterConfig {
|
||||||
cluster_lamports: 10_000,
|
cluster_lamports: 10_000,
|
||||||
node_stakes: vec![100; 4],
|
node_stakes: vec![100; 4],
|
||||||
|
@ -1600,7 +1609,7 @@ fn test_no_voting() {
|
||||||
solana_logger::setup_with_default(RUST_LOG_FILTER);
|
solana_logger::setup_with_default(RUST_LOG_FILTER);
|
||||||
let validator_config = ValidatorConfig {
|
let validator_config = ValidatorConfig {
|
||||||
voting_disabled: true,
|
voting_disabled: true,
|
||||||
..ValidatorConfig::default()
|
..ValidatorConfig::default_for_test()
|
||||||
};
|
};
|
||||||
let mut config = ClusterConfig {
|
let mut config = ClusterConfig {
|
||||||
cluster_lamports: 10_000,
|
cluster_lamports: 10_000,
|
||||||
|
@ -1653,7 +1662,7 @@ fn test_optimistic_confirmation_violation_detection() {
|
||||||
cluster_lamports: 100_000,
|
cluster_lamports: 100_000,
|
||||||
node_stakes: node_stakes.clone(),
|
node_stakes: node_stakes.clone(),
|
||||||
validator_configs: make_identical_validator_configs(
|
validator_configs: make_identical_validator_configs(
|
||||||
&ValidatorConfig::default(),
|
&ValidatorConfig::default_for_test(),
|
||||||
node_stakes.len(),
|
node_stakes.len(),
|
||||||
),
|
),
|
||||||
validator_keys: Some(validator_keys),
|
validator_keys: Some(validator_keys),
|
||||||
|
@ -1774,7 +1783,7 @@ fn test_validator_saves_tower() {
|
||||||
|
|
||||||
let validator_config = ValidatorConfig {
|
let validator_config = ValidatorConfig {
|
||||||
require_tower: true,
|
require_tower: true,
|
||||||
..ValidatorConfig::default()
|
..ValidatorConfig::default_for_test()
|
||||||
};
|
};
|
||||||
let validator_identity_keypair = Arc::new(Keypair::new());
|
let validator_identity_keypair = Arc::new(Keypair::new());
|
||||||
let validator_id = validator_identity_keypair.pubkey();
|
let validator_id = validator_identity_keypair.pubkey();
|
||||||
|
@ -1968,7 +1977,7 @@ fn test_slot_hash_expiry() {
|
||||||
// We want B to not vote (we are trying to simulate its votes not landing until it gets to the
|
// We want B to not vote (we are trying to simulate its votes not landing until it gets to the
|
||||||
// minority fork)
|
// minority fork)
|
||||||
let mut validator_configs =
|
let mut validator_configs =
|
||||||
make_identical_validator_configs(&ValidatorConfig::default(), node_stakes.len());
|
make_identical_validator_configs(&ValidatorConfig::default_for_test(), node_stakes.len());
|
||||||
validator_configs[1].voting_disabled = true;
|
validator_configs[1].voting_disabled = true;
|
||||||
|
|
||||||
let mut config = ClusterConfig {
|
let mut config = ClusterConfig {
|
||||||
|
@ -2149,7 +2158,7 @@ fn do_test_future_tower(cluster_mode: ClusterMode) {
|
||||||
cluster_lamports: 100_000,
|
cluster_lamports: 100_000,
|
||||||
node_stakes: node_stakes.clone(),
|
node_stakes: node_stakes.clone(),
|
||||||
validator_configs: make_identical_validator_configs(
|
validator_configs: make_identical_validator_configs(
|
||||||
&ValidatorConfig::default(),
|
&ValidatorConfig::default_for_test(),
|
||||||
node_stakes.len(),
|
node_stakes.len(),
|
||||||
),
|
),
|
||||||
validator_keys: Some(validator_keys),
|
validator_keys: Some(validator_keys),
|
||||||
|
@ -2260,7 +2269,7 @@ fn test_hard_fork_invalidates_tower() {
|
||||||
cluster_lamports: 100_000,
|
cluster_lamports: 100_000,
|
||||||
node_stakes: node_stakes.clone(),
|
node_stakes: node_stakes.clone(),
|
||||||
validator_configs: make_identical_validator_configs(
|
validator_configs: make_identical_validator_configs(
|
||||||
&ValidatorConfig::default(),
|
&ValidatorConfig::default_for_test(),
|
||||||
node_stakes.len(),
|
node_stakes.len(),
|
||||||
),
|
),
|
||||||
validator_keys: Some(validator_keys),
|
validator_keys: Some(validator_keys),
|
||||||
|
@ -2392,7 +2401,7 @@ fn test_restart_tower_rollback() {
|
||||||
cluster_lamports: 100_000,
|
cluster_lamports: 100_000,
|
||||||
node_stakes: node_stakes.clone(),
|
node_stakes: node_stakes.clone(),
|
||||||
validator_configs: make_identical_validator_configs(
|
validator_configs: make_identical_validator_configs(
|
||||||
&ValidatorConfig::default(),
|
&ValidatorConfig::default_for_test(),
|
||||||
node_stakes.len(),
|
node_stakes.len(),
|
||||||
),
|
),
|
||||||
validator_keys: Some(validator_keys),
|
validator_keys: Some(validator_keys),
|
||||||
|
@ -2758,7 +2767,7 @@ fn run_test_load_program_accounts(scan_commitment: CommitmentConfig) {
|
||||||
cluster_lamports: 100_000,
|
cluster_lamports: 100_000,
|
||||||
node_stakes: node_stakes.clone(),
|
node_stakes: node_stakes.clone(),
|
||||||
validator_configs: make_identical_validator_configs(
|
validator_configs: make_identical_validator_configs(
|
||||||
&ValidatorConfig::default(),
|
&ValidatorConfig::default_for_test(),
|
||||||
node_stakes.len(),
|
node_stakes.len(),
|
||||||
),
|
),
|
||||||
validator_keys: Some(validator_keys),
|
validator_keys: Some(validator_keys),
|
||||||
|
@ -2861,7 +2870,7 @@ impl SnapshotValidatorConfig {
|
||||||
snapshot_config: Some(snapshot_config),
|
snapshot_config: Some(snapshot_config),
|
||||||
account_paths: account_storage_paths,
|
account_paths: account_storage_paths,
|
||||||
accounts_hash_interval_slots,
|
accounts_hash_interval_slots,
|
||||||
..ValidatorConfig::default()
|
..ValidatorConfig::default_for_test()
|
||||||
};
|
};
|
||||||
|
|
||||||
SnapshotValidatorConfig {
|
SnapshotValidatorConfig {
|
||||||
|
|
|
@ -129,7 +129,7 @@ fn do_test_optimistic_confirmation_violation_with_or_without_tower(with_tower: b
|
||||||
// below only for slots <= `next_slot_on_a`, validator A will not know how it's last vote chains
|
// below only for slots <= `next_slot_on_a`, validator A will not know how it's last vote chains
|
||||||
// to the otehr forks, and may violate switching proofs on restart.
|
// to the otehr forks, and may violate switching proofs on restart.
|
||||||
let mut validator_configs =
|
let mut validator_configs =
|
||||||
make_identical_validator_configs(&ValidatorConfig::default(), node_stakes.len());
|
make_identical_validator_configs(&ValidatorConfig::default_for_test(), node_stakes.len());
|
||||||
|
|
||||||
validator_configs[0].voting_disabled = true;
|
validator_configs[0].voting_disabled = true;
|
||||||
validator_configs[2].voting_disabled = true;
|
validator_configs[2].voting_disabled = true;
|
||||||
|
|
|
@ -844,7 +844,10 @@ fn test_listener_startup() {
|
||||||
node_stakes: vec![100; 1],
|
node_stakes: vec![100; 1],
|
||||||
cluster_lamports: 1_000,
|
cluster_lamports: 1_000,
|
||||||
num_listeners: 3,
|
num_listeners: 3,
|
||||||
validator_configs: make_identical_validator_configs(&ValidatorConfig::default(), 1),
|
validator_configs: make_identical_validator_configs(
|
||||||
|
&ValidatorConfig::default_for_test(),
|
||||||
|
1,
|
||||||
|
),
|
||||||
..ClusterConfig::default()
|
..ClusterConfig::default()
|
||||||
};
|
};
|
||||||
let cluster = LocalCluster::new(&mut config, SocketAddrSpace::Unspecified);
|
let cluster = LocalCluster::new(&mut config, SocketAddrSpace::Unspecified);
|
||||||
|
|
|
@ -129,6 +129,7 @@ args+=(
|
||||||
--no-poh-speed-test
|
--no-poh-speed-test
|
||||||
--no-os-network-limits-test
|
--no-os-network-limits-test
|
||||||
--no-wait-for-vote-to-start-leader
|
--no-wait-for-vote-to-start-leader
|
||||||
|
--full-rpc-api
|
||||||
)
|
)
|
||||||
default_arg --gossip-port 8001
|
default_arg --gossip-port 8001
|
||||||
default_arg --log -
|
default_arg --log -
|
||||||
|
|
|
@ -248,6 +248,7 @@ default_arg --identity "$identity"
|
||||||
default_arg --vote-account "$vote_account"
|
default_arg --vote-account "$vote_account"
|
||||||
default_arg --ledger "$ledger_dir"
|
default_arg --ledger "$ledger_dir"
|
||||||
default_arg --log -
|
default_arg --log -
|
||||||
|
default_arg --full-rpc-api
|
||||||
|
|
||||||
if [[ $maybeRequireTower = true ]]; then
|
if [[ $maybeRequireTower = true ]]; then
|
||||||
default_arg --require-tower
|
default_arg --require-tower
|
||||||
|
|
|
@ -145,7 +145,7 @@ fn setup_snapshot_validator_config(
|
||||||
account_paths: account_storage_paths,
|
account_paths: account_storage_paths,
|
||||||
accounts_hash_interval_slots: snapshot_interval_slots,
|
accounts_hash_interval_slots: snapshot_interval_slots,
|
||||||
accountsdb_repl_service_config,
|
accountsdb_repl_service_config,
|
||||||
..ValidatorConfig::default()
|
..ValidatorConfig::default_for_test()
|
||||||
};
|
};
|
||||||
|
|
||||||
SnapshotValidatorConfig {
|
SnapshotValidatorConfig {
|
||||||
|
@ -160,7 +160,10 @@ fn test_local_cluster_start_and_exit_with_config(socket_addr_space: SocketAddrSp
|
||||||
solana_logger::setup();
|
solana_logger::setup();
|
||||||
const NUM_NODES: usize = 1;
|
const NUM_NODES: usize = 1;
|
||||||
let mut config = ClusterConfig {
|
let mut config = ClusterConfig {
|
||||||
validator_configs: make_identical_validator_configs(&ValidatorConfig::default(), NUM_NODES),
|
validator_configs: make_identical_validator_configs(
|
||||||
|
&ValidatorConfig::default_for_test(),
|
||||||
|
NUM_NODES,
|
||||||
|
),
|
||||||
node_stakes: vec![3; NUM_NODES],
|
node_stakes: vec![3; NUM_NODES],
|
||||||
cluster_lamports: 100,
|
cluster_lamports: 100,
|
||||||
ticks_per_slot: 8,
|
ticks_per_slot: 8,
|
||||||
|
|
|
@ -149,7 +149,7 @@ pub struct JsonRpcConfig {
|
||||||
pub rpc_threads: usize,
|
pub rpc_threads: usize,
|
||||||
pub rpc_niceness_adj: i8,
|
pub rpc_niceness_adj: i8,
|
||||||
pub rpc_bigtable_timeout: Option<Duration>,
|
pub rpc_bigtable_timeout: Option<Duration>,
|
||||||
pub minimal_api: bool,
|
pub full_api: bool,
|
||||||
pub obsolete_v1_7_api: bool,
|
pub obsolete_v1_7_api: bool,
|
||||||
pub rpc_scan_and_fix_roots: bool,
|
pub rpc_scan_and_fix_roots: bool,
|
||||||
}
|
}
|
||||||
|
|
|
@ -380,7 +380,7 @@ impl JsonRpcService {
|
||||||
(None, None)
|
(None, None)
|
||||||
};
|
};
|
||||||
|
|
||||||
let minimal_api = config.minimal_api;
|
let full_api = config.full_api;
|
||||||
let obsolete_v1_7_api = config.obsolete_v1_7_api;
|
let obsolete_v1_7_api = config.obsolete_v1_7_api;
|
||||||
let (request_processor, receiver) = JsonRpcRequestProcessor::new(
|
let (request_processor, receiver) = JsonRpcRequestProcessor::new(
|
||||||
config,
|
config,
|
||||||
|
@ -424,7 +424,7 @@ impl JsonRpcService {
|
||||||
let mut io = MetaIoHandler::default();
|
let mut io = MetaIoHandler::default();
|
||||||
|
|
||||||
io.extend_with(rpc_minimal::MinimalImpl.to_delegate());
|
io.extend_with(rpc_minimal::MinimalImpl.to_delegate());
|
||||||
if !minimal_api {
|
if full_api {
|
||||||
io.extend_with(rpc_bank::BankDataImpl.to_delegate());
|
io.extend_with(rpc_bank::BankDataImpl.to_delegate());
|
||||||
io.extend_with(rpc_accounts::AccountsDataImpl.to_delegate());
|
io.extend_with(rpc_accounts::AccountsDataImpl.to_delegate());
|
||||||
io.extend_with(rpc_full::FullImpl.to_delegate());
|
io.extend_with(rpc_full::FullImpl.to_delegate());
|
||||||
|
|
|
@ -84,7 +84,6 @@ impl Default for TestValidatorNodeConfig {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Default)]
|
|
||||||
pub struct TestValidatorGenesis {
|
pub struct TestValidatorGenesis {
|
||||||
fee_rate_governor: FeeRateGovernor,
|
fee_rate_governor: FeeRateGovernor,
|
||||||
ledger_path: Option<PathBuf>,
|
ledger_path: Option<PathBuf>,
|
||||||
|
@ -109,6 +108,37 @@ pub struct TestValidatorGenesis {
|
||||||
pub accounts_db_caching_enabled: bool,
|
pub accounts_db_caching_enabled: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl Default for TestValidatorGenesis {
|
||||||
|
fn default() -> Self {
|
||||||
|
Self {
|
||||||
|
fee_rate_governor: FeeRateGovernor::default(),
|
||||||
|
ledger_path: Option::<PathBuf>::default(),
|
||||||
|
tower_storage: Option::<Arc<dyn TowerStorage>>::default(),
|
||||||
|
rent: Rent::default(),
|
||||||
|
rpc_config: JsonRpcConfig {
|
||||||
|
full_api: true,
|
||||||
|
..JsonRpcConfig::default()
|
||||||
|
},
|
||||||
|
pubsub_config: PubSubConfig::default(),
|
||||||
|
rpc_ports: Option::<(u16, u16)>::default(),
|
||||||
|
warp_slot: Option::<Slot>::default(),
|
||||||
|
no_bpf_jit: bool::default(),
|
||||||
|
accounts: HashMap::<Pubkey, AccountSharedData>::default(),
|
||||||
|
programs: Vec::<ProgramInfo>::default(),
|
||||||
|
ticks_per_slot: Option::<u64>::default(),
|
||||||
|
epoch_schedule: Option::<EpochSchedule>::default(),
|
||||||
|
node_config: TestValidatorNodeConfig::default(),
|
||||||
|
validator_exit: Arc::<RwLock<Exit>>::default(),
|
||||||
|
start_progress: Arc::<RwLock<ValidatorStartProgress>>::default(),
|
||||||
|
authorized_voter_keypairs: Arc::<RwLock<Vec<Arc<Keypair>>>>::default(),
|
||||||
|
max_ledger_shreds: Option::<u64>::default(),
|
||||||
|
max_genesis_archive_unpacked_size: Option::<u64>::default(),
|
||||||
|
accountsdb_plugin_config_files: Option::<Vec<PathBuf>>::default(),
|
||||||
|
accounts_db_caching_enabled: bool::default(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl TestValidatorGenesis {
|
impl TestValidatorGenesis {
|
||||||
pub fn ledger_path<P: Into<PathBuf>>(&mut self, ledger_path: P) -> &mut Self {
|
pub fn ledger_path<P: Into<PathBuf>>(&mut self, ledger_path: P) -> &mut Self {
|
||||||
self.ledger_path = Some(ledger_path.into());
|
self.ledger_path = Some(ledger_path.into());
|
||||||
|
@ -630,7 +660,7 @@ impl TestValidator {
|
||||||
rocksdb_compaction_interval: Some(100), // Compact every 100 slots
|
rocksdb_compaction_interval: Some(100), // Compact every 100 slots
|
||||||
max_ledger_shreds: config.max_ledger_shreds,
|
max_ledger_shreds: config.max_ledger_shreds,
|
||||||
no_wait_for_vote_to_start_leader: true,
|
no_wait_for_vote_to_start_leader: true,
|
||||||
..ValidatorConfig::default()
|
..ValidatorConfig::default_for_test()
|
||||||
};
|
};
|
||||||
if let Some(ref tower_storage) = config.tower_storage {
|
if let Some(ref tower_storage) = config.tower_storage {
|
||||||
validator_config.tower_storage = tower_storage.clone();
|
validator_config.tower_storage = tower_storage.clone();
|
||||||
|
|
|
@ -665,7 +665,7 @@ pub mod test {
|
||||||
fn test_transaction_dos() {
|
fn test_transaction_dos() {
|
||||||
solana_logger::setup();
|
solana_logger::setup();
|
||||||
|
|
||||||
let validator_config = ValidatorConfig::default();
|
let validator_config = ValidatorConfig::default_for_test();
|
||||||
let num_nodes = 1;
|
let num_nodes = 1;
|
||||||
let mut config = ClusterConfig {
|
let mut config = ClusterConfig {
|
||||||
cluster_lamports: 10_000_000,
|
cluster_lamports: 10_000_000,
|
||||||
|
|
|
@ -576,8 +576,16 @@ pub fn main() {
|
||||||
Arg::with_name("minimal_rpc_api")
|
Arg::with_name("minimal_rpc_api")
|
||||||
.long("--minimal-rpc-api")
|
.long("--minimal-rpc-api")
|
||||||
.takes_value(false)
|
.takes_value(false)
|
||||||
|
.hidden(true)
|
||||||
.help("Only expose the RPC methods required to serve snapshots to other nodes"),
|
.help("Only expose the RPC methods required to serve snapshots to other nodes"),
|
||||||
)
|
)
|
||||||
|
.arg(
|
||||||
|
Arg::with_name("full_rpc_api")
|
||||||
|
.long("--full-rpc-api")
|
||||||
|
.conflicts_with("minimal_rpc_api")
|
||||||
|
.takes_value(false)
|
||||||
|
.help("Expose RPC methods for querying chain state and transaction history"),
|
||||||
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::with_name("obsolete_v1_7_rpc_api")
|
Arg::with_name("obsolete_v1_7_rpc_api")
|
||||||
.long("--enable-rpc-obsolete_v1_7")
|
.long("--enable-rpc-obsolete_v1_7")
|
||||||
|
@ -2123,6 +2131,10 @@ pub fn main() {
|
||||||
None
|
None
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if matches.is_present("minimal_rpc_api") {
|
||||||
|
warn!("--minimal-rpc-api is now the default behavior. This flag is deprecated and can be removed from the launch args")
|
||||||
|
}
|
||||||
|
|
||||||
let mut validator_config = ValidatorConfig {
|
let mut validator_config = ValidatorConfig {
|
||||||
require_tower: matches.is_present("require_tower"),
|
require_tower: matches.is_present("require_tower"),
|
||||||
tower_storage,
|
tower_storage,
|
||||||
|
@ -2144,7 +2156,7 @@ pub fn main() {
|
||||||
faucet_addr: matches.value_of("rpc_faucet_addr").map(|address| {
|
faucet_addr: matches.value_of("rpc_faucet_addr").map(|address| {
|
||||||
solana_net_utils::parse_host_port(address).expect("failed to parse faucet address")
|
solana_net_utils::parse_host_port(address).expect("failed to parse faucet address")
|
||||||
}),
|
}),
|
||||||
minimal_api: matches.is_present("minimal_rpc_api"),
|
full_api: matches.is_present("full_rpc_api"),
|
||||||
obsolete_v1_7_api: matches.is_present("obsolete_v1_7_rpc_api"),
|
obsolete_v1_7_api: matches.is_present("obsolete_v1_7_rpc_api"),
|
||||||
max_multiple_accounts: Some(value_t_or_exit!(
|
max_multiple_accounts: Some(value_t_or_exit!(
|
||||||
matches,
|
matches,
|
||||||
|
|
Loading…
Reference in New Issue