This renames `cton_frontend` to `cretonne_frontend` and so on. This fixes the first part of #287.
91 lines
2.6 KiB
Rust
91 lines
2.6 KiB
Rust
//! File tests.
|
|
//!
|
|
//! This crate contains the main test driver as well as implementations of the
|
|
//! available filetest commands.
|
|
|
|
#![cfg_attr(feature="cargo-clippy", allow(
|
|
type_complexity,
|
|
// Rustfmt 0.9.0 is at odds with this lint:
|
|
block_in_if_condition_stmt))]
|
|
|
|
#[macro_use(dbg)]
|
|
extern crate cretonne;
|
|
extern crate cretonne_reader;
|
|
extern crate filecheck;
|
|
extern crate num_cpus;
|
|
|
|
use cretonne_reader::TestCommand;
|
|
use runner::TestRunner;
|
|
use std::path::Path;
|
|
use std::time;
|
|
|
|
mod concurrent;
|
|
mod match_directive;
|
|
mod runner;
|
|
mod runone;
|
|
mod subtest;
|
|
|
|
mod test_binemit;
|
|
mod test_cat;
|
|
mod test_compile;
|
|
mod test_dce;
|
|
mod test_domtree;
|
|
mod test_legalizer;
|
|
mod test_licm;
|
|
mod test_postopt;
|
|
mod test_preopt;
|
|
mod test_print_cfg;
|
|
mod test_regalloc;
|
|
mod test_simple_gvn;
|
|
mod test_verifier;
|
|
|
|
/// The result of running the test in a file.
|
|
type TestResult = Result<time::Duration, String>;
|
|
|
|
/// Main entry point for `cton-util test`.
|
|
///
|
|
/// Take a list of filenames which can be either `.cton` files or directories.
|
|
///
|
|
/// Files are interpreted as test cases and executed immediately.
|
|
///
|
|
/// Directories are scanned recursively for test cases ending in `.cton`. These test cases are
|
|
/// executed on background threads.
|
|
///
|
|
pub fn run(verbose: bool, files: &[String]) -> TestResult {
|
|
let mut runner = TestRunner::new(verbose);
|
|
|
|
for path in files.iter().map(Path::new) {
|
|
if path.is_file() {
|
|
runner.push_test(path);
|
|
} else {
|
|
runner.push_dir(path);
|
|
}
|
|
}
|
|
|
|
runner.start_threads();
|
|
runner.run()
|
|
}
|
|
|
|
/// Create a new subcommand trait object to match `parsed.command`.
|
|
///
|
|
/// This function knows how to create all of the possible `test <foo>` commands that can appear in
|
|
/// a `.cton` test file.
|
|
fn new_subtest(parsed: &TestCommand) -> subtest::Result<Box<subtest::SubTest>> {
|
|
match parsed.command {
|
|
"binemit" => test_binemit::subtest(parsed),
|
|
"cat" => test_cat::subtest(parsed),
|
|
"compile" => test_compile::subtest(parsed),
|
|
"dce" => test_dce::subtest(parsed),
|
|
"domtree" => test_domtree::subtest(parsed),
|
|
"legalizer" => test_legalizer::subtest(parsed),
|
|
"licm" => test_licm::subtest(parsed),
|
|
"postopt" => test_postopt::subtest(parsed),
|
|
"preopt" => test_preopt::subtest(parsed),
|
|
"print-cfg" => test_print_cfg::subtest(parsed),
|
|
"regalloc" => test_regalloc::subtest(parsed),
|
|
"simple-gvn" => test_simple_gvn::subtest(parsed),
|
|
"verifier" => test_verifier::subtest(parsed),
|
|
_ => Err(format!("unknown test command '{}'", parsed.command)),
|
|
}
|
|
}
|