2019-03-07 23:50:12 +00:00
|
|
|
use clap::{App, Arg, SubCommand};
|
2019-02-28 12:13:00 +00:00
|
|
|
use env_logger::{Builder, Env};
|
2019-03-07 23:50:12 +00:00
|
|
|
use run_test::run_test;
|
2019-02-28 12:13:00 +00:00
|
|
|
|
|
|
|
mod beacon_chain_harness;
|
2019-03-07 23:50:12 +00:00
|
|
|
mod run_test;
|
2019-03-03 04:12:19 +00:00
|
|
|
mod test_case;
|
2019-02-28 12:13:00 +00:00
|
|
|
mod validator_harness;
|
|
|
|
|
2019-03-02 07:59:47 +00:00
|
|
|
use validator_harness::ValidatorHarness;
|
|
|
|
|
2019-02-28 12:13:00 +00:00
|
|
|
fn main() {
|
|
|
|
let matches = App::new("Lighthouse Test Harness Runner")
|
|
|
|
.version("0.0.1")
|
|
|
|
.author("Sigma Prime <contact@sigmaprime.io>")
|
2019-03-03 04:12:19 +00:00
|
|
|
.about("Runs `test_harness` using a YAML test_case.")
|
2019-03-03 05:15:00 +00:00
|
|
|
.arg(
|
|
|
|
Arg::with_name("log")
|
|
|
|
.long("log-level")
|
|
|
|
.value_name("LOG_LEVEL")
|
|
|
|
.help("Logging level.")
|
|
|
|
.possible_values(&["error", "warn", "info", "debug", "trace"])
|
|
|
|
.default_value("debug")
|
|
|
|
.required(true),
|
|
|
|
)
|
2019-03-07 23:50:12 +00:00
|
|
|
.subcommand(
|
|
|
|
SubCommand::with_name("run_test")
|
|
|
|
.about("Executes a YAML test specification")
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("yaml")
|
|
|
|
.long("yaml")
|
|
|
|
.value_name("FILE")
|
|
|
|
.help("YAML file test_case.")
|
|
|
|
.required(true),
|
|
|
|
),
|
|
|
|
)
|
2019-02-28 12:13:00 +00:00
|
|
|
.get_matches();
|
|
|
|
|
2019-03-03 05:15:00 +00:00
|
|
|
if let Some(log_level) = matches.value_of("log") {
|
|
|
|
Builder::from_env(Env::default().default_filter_or(log_level)).init();
|
|
|
|
}
|
2019-02-28 12:13:00 +00:00
|
|
|
|
2019-03-07 23:50:12 +00:00
|
|
|
if let Some(matches) = matches.subcommand_matches("run_test") {
|
|
|
|
run_test(matches);
|
2019-02-28 12:13:00 +00:00
|
|
|
}
|
|
|
|
}
|