2018-12-07 20:44:59 -08:00
|
|
|
use assert_cmd::prelude::*;
|
2019-02-22 21:55:46 -08:00
|
|
|
use solana::blocktree::create_tmp_sample_blocktree;
|
|
|
|
use solana_sdk::genesis_block::GenesisBlock;
|
2019-02-21 18:46:04 -08:00
|
|
|
use solana_sdk::signature::{Keypair, KeypairUtil};
|
2018-12-07 20:44:59 -08:00
|
|
|
use std::process::Command;
|
|
|
|
use std::process::Output;
|
|
|
|
use std::sync::Arc;
|
|
|
|
|
|
|
|
fn run_ledger_tool(args: &[&str]) -> Output {
|
2019-01-29 11:10:48 -08:00
|
|
|
Command::cargo_bin(env!("CARGO_PKG_NAME"))
|
|
|
|
.unwrap()
|
|
|
|
.args(args)
|
|
|
|
.output()
|
|
|
|
.unwrap()
|
2018-12-07 20:44:59 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
fn count_newlines(chars: &[u8]) -> usize {
|
|
|
|
chars.iter().filter(|&c| *c == '\n' as u8).count()
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn bad_arguments() {
|
|
|
|
// At least a ledger path is required
|
|
|
|
assert!(!run_ledger_tool(&[]).status.success());
|
|
|
|
|
|
|
|
// Invalid ledger path should fail
|
|
|
|
assert!(!run_ledger_tool(&["-l", "invalid_ledger", "verify"])
|
|
|
|
.status
|
|
|
|
.success());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn nominal() {
|
|
|
|
let keypair = Arc::new(Keypair::new());
|
2019-02-22 21:55:46 -08:00
|
|
|
let (genesis_block, _mint_keypair) = GenesisBlock::new_with_leader(100, keypair.pubkey(), 50);
|
|
|
|
let ticks_per_slot = genesis_block.ticks_per_slot;
|
|
|
|
let (ledger_path, tick_height, _last_entry_height, _last_id, _last_entry_id) =
|
|
|
|
create_tmp_sample_blocktree(
|
2019-02-12 13:14:33 -08:00
|
|
|
"test_ledger_tool_nominal",
|
2019-02-22 21:55:46 -08:00
|
|
|
&genesis_block,
|
2019-02-21 18:46:04 -08:00
|
|
|
ticks_per_slot - 2,
|
2019-02-12 13:14:33 -08:00
|
|
|
);
|
2018-12-07 20:44:59 -08:00
|
|
|
|
|
|
|
// Basic validation
|
|
|
|
let output = run_ledger_tool(&["-l", &ledger_path, "verify"]);
|
|
|
|
assert!(output.status.success());
|
|
|
|
|
|
|
|
// Print everything
|
|
|
|
let output = run_ledger_tool(&["-l", &ledger_path, "print"]);
|
|
|
|
assert!(output.status.success());
|
2019-02-14 11:22:39 -08:00
|
|
|
assert_eq!(count_newlines(&output.stdout), tick_height as usize);
|
2018-12-07 20:44:59 -08:00
|
|
|
|
|
|
|
// Only print the first 5 items
|
|
|
|
let output = run_ledger_tool(&["-l", &ledger_path, "-n", "5", "print"]);
|
|
|
|
assert!(output.status.success());
|
|
|
|
assert_eq!(count_newlines(&output.stdout), 5);
|
|
|
|
|
2019-01-28 15:19:10 -08:00
|
|
|
// Skip entries with no hashes
|
2018-12-07 20:44:59 -08:00
|
|
|
let output = run_ledger_tool(&["-l", &ledger_path, "-h", "1", "print"]);
|
|
|
|
assert!(output.status.success());
|
2019-02-14 11:22:39 -08:00
|
|
|
assert_eq!(count_newlines(&output.stdout), tick_height as usize);
|
2018-12-07 20:44:59 -08:00
|
|
|
|
|
|
|
// Skip entries with fewer than 2 hashes (skip everything)
|
|
|
|
let output = run_ledger_tool(&["-l", &ledger_path, "-h", "2", "print"]);
|
|
|
|
assert!(output.status.success());
|
|
|
|
assert_eq!(count_newlines(&output.stdout), 0);
|
|
|
|
}
|