groom Fullnode's new_with_bank() to match new() more

This commit is contained in:
Rob Walker 2018-09-10 23:38:40 -07:00
parent a8fdb8a5a7
commit b52230097e
3 changed files with 12 additions and 39 deletions

View File

@ -163,12 +163,9 @@ mod tests {
use logger; use logger;
use mint::Mint; use mint::Mint;
use netutil::get_ip_addr; use netutil::get_ip_addr;
use service::Service;
use signature::{Keypair, KeypairUtil}; use signature::{Keypair, KeypairUtil};
use std::fs::remove_dir_all; use std::fs::remove_dir_all;
use std::net::{SocketAddr, UdpSocket}; use std::net::{SocketAddr, UdpSocket};
use std::sync::atomic::{AtomicBool, Ordering};
use std::sync::Arc;
use std::time::Duration; use std::time::Duration;
use thin_client::ThinClient; use thin_client::ThinClient;
@ -262,7 +259,6 @@ mod tests {
let bank = Bank::new(&alice); let bank = Bank::new(&alice);
let bob_pubkey = Keypair::new().pubkey(); let bob_pubkey = Keypair::new().pubkey();
let carlos_pubkey = Keypair::new().pubkey(); let carlos_pubkey = Keypair::new().pubkey();
let exit = Arc::new(AtomicBool::new(false));
let leader_data = leader.info.clone(); let leader_data = leader.info.clone();
let ledger_path = tmp_ledger_path("send_airdrop"); let ledger_path = tmp_ledger_path("send_airdrop");
@ -273,7 +269,6 @@ mod tests {
&[], &[],
leader, leader,
None, None,
exit.clone(),
Some(&ledger_path), Some(&ledger_path),
false, false,
); );
@ -307,8 +302,7 @@ mod tests {
assert!(client.poll_for_signature(&bob_sig).is_ok()); assert!(client.poll_for_signature(&bob_sig).is_ok());
// restart the leader, drone should find the new one at the same gossip port // restart the leader, drone should find the new one at the same gossip port
exit.store(true, Ordering::Relaxed); server.close().unwrap();
server.join().unwrap();
let leader_keypair = Keypair::new(); let leader_keypair = Keypair::new();
let leader = Node::new_localhost_with_pubkey(leader_keypair.pubkey()); let leader = Node::new_localhost_with_pubkey(leader_keypair.pubkey());

View File

@ -61,7 +61,8 @@ impl Fullnode {
let entries = read_ledger(ledger_path, true).expect("opening ledger"); let entries = read_ledger(ledger_path, true).expect("opening ledger");
let entries = entries.map(|e| e.expect("failed to parse entry")); let entries = entries
.map(|e| e.unwrap_or_else(|err| panic!("failed to parse entry. error: {}", err)));
info!("processing ledger..."); info!("processing ledger...");
let (entry_height, ledger_tail) = bank.process_ledger(entries).expect("process_ledger"); let (entry_height, ledger_tail) = bank.process_ledger(entries).expect("process_ledger");
@ -76,7 +77,7 @@ impl Fullnode {
"starting... local gossip address: {} (advertising {})", "starting... local gossip address: {} (advertising {})",
local_gossip_addr, node.info.contact_info.ncp local_gossip_addr, node.info.contact_info.ncp
); );
let exit = Arc::new(AtomicBool::new(false));
let local_requests_addr = node.sockets.requests.local_addr().unwrap(); let local_requests_addr = node.sockets.requests.local_addr().unwrap();
let requests_addr = node.info.contact_info.rpu; let requests_addr = node.info.contact_info.rpu;
let leader_info = leader_addr.map(|i| NodeInfo::new_entry_point(&i)); let leader_info = leader_addr.map(|i| NodeInfo::new_entry_point(&i));
@ -87,7 +88,6 @@ impl Fullnode {
&ledger_tail, &ledger_tail,
node, node,
leader_info.as_ref(), leader_info.as_ref(),
exit,
Some(ledger_path), Some(ledger_path),
sigverify_disabled, sigverify_disabled,
); );
@ -167,14 +167,13 @@ impl Fullnode {
ledger_tail: &[Entry], ledger_tail: &[Entry],
mut node: Node, mut node: Node,
leader_info: Option<&NodeInfo>, leader_info: Option<&NodeInfo>,
exit: Arc<AtomicBool>,
ledger_path: Option<&str>, ledger_path: Option<&str>,
sigverify_disabled: bool, sigverify_disabled: bool,
) -> Self { ) -> Self {
if leader_info.is_none() { if leader_info.is_none() {
node.info.leader_id = node.info.id; node.info.leader_id = node.info.id;
} }
let exit = Arc::new(AtomicBool::new(false));
let bank = Arc::new(bank); let bank = Arc::new(bank);
let blob_recycler = BlobRecycler::default(); let blob_recycler = BlobRecycler::default();
let mut thread_hdls = vec![]; let mut thread_hdls = vec![];
@ -303,8 +302,6 @@ mod tests {
use mint::Mint; use mint::Mint;
use service::Service; use service::Service;
use signature::{Keypair, KeypairUtil}; use signature::{Keypair, KeypairUtil};
use std::sync::atomic::AtomicBool;
use std::sync::Arc;
#[test] #[test]
fn validator_exit() { fn validator_exit() {
@ -312,11 +309,9 @@ mod tests {
let tn = Node::new_localhost_with_pubkey(keypair.pubkey()); let tn = Node::new_localhost_with_pubkey(keypair.pubkey());
let alice = Mint::new(10_000); let alice = Mint::new(10_000);
let bank = Bank::new(&alice); let bank = Bank::new(&alice);
let exit = Arc::new(AtomicBool::new(false));
let entry = tn.info.clone(); let entry = tn.info.clone();
let v = Fullnode::new_with_bank(keypair, bank, 0, &[], tn, Some(&entry), exit, None, false); let v = Fullnode::new_with_bank(keypair, bank, 0, &[], tn, Some(&entry), None, false);
v.exit(); v.close().unwrap();
v.join().unwrap();
} }
#[test] #[test]
fn validator_parallel_exit() { fn validator_parallel_exit() {
@ -326,9 +321,8 @@ mod tests {
let tn = Node::new_localhost_with_pubkey(keypair.pubkey()); let tn = Node::new_localhost_with_pubkey(keypair.pubkey());
let alice = Mint::new(10_000); let alice = Mint::new(10_000);
let bank = Bank::new(&alice); let bank = Bank::new(&alice);
let exit = Arc::new(AtomicBool::new(false));
let entry = tn.info.clone(); let entry = tn.info.clone();
Fullnode::new_with_bank(keypair, bank, 0, &[], tn, Some(&entry), exit, None, false) Fullnode::new_with_bank(keypair, bank, 0, &[], tn, Some(&entry), None, false)
}) })
.collect(); .collect();
//each validator can exit in parallel to speed many sequential calls to `join` //each validator can exit in parallel to speed many sequential calls to `join`

View File

@ -438,11 +438,8 @@ mod tests {
use ledger::LedgerWriter; use ledger::LedgerWriter;
use logger; use logger;
use mint::Mint; use mint::Mint;
use service::Service;
use signature::{Keypair, KeypairUtil}; use signature::{Keypair, KeypairUtil};
use std::fs::remove_dir_all; use std::fs::remove_dir_all;
use std::sync::atomic::{AtomicBool, Ordering};
use std::sync::Arc;
use transaction::{Instruction, Plan}; use transaction::{Instruction, Plan};
fn tmp_ledger(name: &str, mint: &Mint) -> String { fn tmp_ledger(name: &str, mint: &Mint) -> String {
@ -468,7 +465,6 @@ mod tests {
let alice = Mint::new(10_000); let alice = Mint::new(10_000);
let bank = Bank::new(&alice); let bank = Bank::new(&alice);
let bob_pubkey = Keypair::new().pubkey(); let bob_pubkey = Keypair::new().pubkey();
let exit = Arc::new(AtomicBool::new(false));
let ledger_path = tmp_ledger("thin_client", &alice); let ledger_path = tmp_ledger("thin_client", &alice);
let server = Fullnode::new_with_bank( let server = Fullnode::new_with_bank(
@ -478,7 +474,6 @@ mod tests {
&[], &[],
leader, leader,
None, None,
exit.clone(),
Some(&ledger_path), Some(&ledger_path),
false, false,
); );
@ -500,8 +495,7 @@ mod tests {
client.poll_for_signature(&signature).unwrap(); client.poll_for_signature(&signature).unwrap();
let balance = client.get_balance(&bob_pubkey); let balance = client.get_balance(&bob_pubkey);
assert_eq!(balance.unwrap(), 500); assert_eq!(balance.unwrap(), 500);
exit.store(true, Ordering::Relaxed); server.close().unwrap();
server.join().unwrap();
remove_dir_all(ledger_path).unwrap(); remove_dir_all(ledger_path).unwrap();
} }
@ -515,7 +509,6 @@ mod tests {
let alice = Mint::new(10_000); let alice = Mint::new(10_000);
let bank = Bank::new(&alice); let bank = Bank::new(&alice);
let bob_pubkey = Keypair::new().pubkey(); let bob_pubkey = Keypair::new().pubkey();
let exit = Arc::new(AtomicBool::new(false));
let leader_data = leader.info.clone(); let leader_data = leader.info.clone();
let ledger_path = tmp_ledger("bad_sig", &alice); let ledger_path = tmp_ledger("bad_sig", &alice);
@ -526,7 +519,6 @@ mod tests {
&[], &[],
leader, leader,
None, None,
exit.clone(),
Some(&ledger_path), Some(&ledger_path),
false, false,
); );
@ -564,8 +556,7 @@ mod tests {
let balance = client.get_balance(&bob_pubkey); let balance = client.get_balance(&bob_pubkey);
assert_eq!(balance.unwrap(), 500); assert_eq!(balance.unwrap(), 500);
exit.store(true, Ordering::Relaxed); server.close().unwrap();
server.join().unwrap();
remove_dir_all(ledger_path).unwrap(); remove_dir_all(ledger_path).unwrap();
} }
@ -577,7 +568,6 @@ mod tests {
let alice = Mint::new(10_000); let alice = Mint::new(10_000);
let bank = Bank::new(&alice); let bank = Bank::new(&alice);
let bob_pubkey = Keypair::new().pubkey(); let bob_pubkey = Keypair::new().pubkey();
let exit = Arc::new(AtomicBool::new(false));
let leader_data = leader.info.clone(); let leader_data = leader.info.clone();
let ledger_path = tmp_ledger("client_check_signature", &alice); let ledger_path = tmp_ledger("client_check_signature", &alice);
@ -588,7 +578,6 @@ mod tests {
&[], &[],
leader, leader,
None, None,
exit.clone(),
Some(&ledger_path), Some(&ledger_path),
false, false,
); );
@ -613,8 +602,7 @@ mod tests {
assert!(client.check_signature(&signature)); assert!(client.check_signature(&signature));
exit.store(true, Ordering::Relaxed); server.close().unwrap();
server.join().unwrap();
remove_dir_all(ledger_path).unwrap(); remove_dir_all(ledger_path).unwrap();
} }
@ -640,7 +628,6 @@ mod tests {
let alice = Mint::new(10_000); let alice = Mint::new(10_000);
let bank = Bank::new(&alice); let bank = Bank::new(&alice);
let bob_keypair = Keypair::new(); let bob_keypair = Keypair::new();
let exit = Arc::new(AtomicBool::new(false));
let leader_data = leader.info.clone(); let leader_data = leader.info.clone();
let ledger_path = tmp_ledger("zero_balance_check", &alice); let ledger_path = tmp_ledger("zero_balance_check", &alice);
@ -651,7 +638,6 @@ mod tests {
&[], &[],
leader, leader,
None, None,
exit.clone(),
Some(&ledger_path), Some(&ledger_path),
false, false,
); );
@ -690,8 +676,7 @@ mod tests {
let balance = client.poll_get_balance(&bob_keypair.pubkey()); let balance = client.poll_get_balance(&bob_keypair.pubkey());
assert!(balance.is_err()); assert!(balance.is_err());
exit.store(true, Ordering::Relaxed); server.close().unwrap();
server.join().unwrap();
remove_dir_all(ledger_path).unwrap(); remove_dir_all(ledger_path).unwrap();
} }
} }