2015-05-01 16:43:36 +00:00
|
|
|
// Copyright 2015 The Rust Project Developers. See the COPYRIGHT
|
|
|
|
// file at the top-level directory of this distribution and at
|
|
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
// except according to those terms.
|
|
|
|
|
2015-05-02 14:50:33 +00:00
|
|
|
#![feature(std_misc)]
|
|
|
|
|
2015-05-01 16:43:36 +00:00
|
|
|
extern crate rustfmt;
|
|
|
|
|
|
|
|
use std::collections::HashMap;
|
|
|
|
use std::fs;
|
|
|
|
use std::io::Read;
|
|
|
|
use rustfmt::*;
|
|
|
|
|
|
|
|
// For now, the only supported regression tests are idempotent tests - the input and
|
|
|
|
// output must match exactly.
|
|
|
|
// FIXME(#28) would be good to check for error messages and fail on them, or at least report.
|
|
|
|
#[test]
|
|
|
|
fn idempotent_tests() {
|
|
|
|
println!("Idempotent tests:");
|
|
|
|
|
|
|
|
// Get all files in the tests/idem directory
|
|
|
|
let files = fs::read_dir("tests/idem").unwrap();
|
2015-05-02 14:50:33 +00:00
|
|
|
let files2 = fs::read_dir("tests").unwrap();
|
|
|
|
let files3 = fs::read_dir("src/bin").unwrap();
|
2015-05-01 16:43:36 +00:00
|
|
|
// For each file, run rustfmt and collect the output
|
2015-05-02 14:50:33 +00:00
|
|
|
|
2015-05-01 16:43:36 +00:00
|
|
|
let mut count = 0;
|
2015-05-02 14:50:33 +00:00
|
|
|
let mut fails = 0;
|
|
|
|
for entry in files.chain(files2).chain(files3) {
|
2015-05-01 16:43:36 +00:00
|
|
|
let path = entry.unwrap().path();
|
|
|
|
let file_name = path.to_str().unwrap();
|
2015-05-02 14:50:33 +00:00
|
|
|
if !file_name.ends_with(".rs") {
|
|
|
|
continue;
|
|
|
|
}
|
2015-05-01 16:43:36 +00:00
|
|
|
println!("Testing '{}'...", file_name);
|
2015-05-02 14:50:33 +00:00
|
|
|
match idempotent_check(vec!["rustfmt".to_owned(), file_name.to_owned()]) {
|
|
|
|
Ok(()) => {},
|
|
|
|
Err(m) => {
|
|
|
|
print_mismatches(m);
|
|
|
|
fails += 1;
|
|
|
|
},
|
|
|
|
}
|
2015-05-01 16:43:36 +00:00
|
|
|
count += 1;
|
|
|
|
}
|
2015-05-02 14:50:33 +00:00
|
|
|
// And also dogfood rustfmt!
|
2015-05-01 16:43:36 +00:00
|
|
|
println!("Testing 'src/lib.rs'...");
|
2015-05-02 14:50:33 +00:00
|
|
|
match idempotent_check(vec!["rustfmt".to_owned(), "src/lib.rs".to_owned()]) {
|
|
|
|
Ok(()) => {},
|
|
|
|
Err(m) => {
|
|
|
|
print_mismatches(m);
|
|
|
|
fails += 1;
|
|
|
|
},
|
|
|
|
}
|
2015-05-01 16:43:36 +00:00
|
|
|
count += 1;
|
|
|
|
|
|
|
|
// Display results
|
|
|
|
println!("Ran {} idempotent tests; {} failures.", count, fails);
|
|
|
|
assert!(fails == 0, "{} idempotent tests failed", fails);
|
|
|
|
}
|
|
|
|
|
2015-05-02 14:50:33 +00:00
|
|
|
// Compare output to input.
|
|
|
|
fn print_mismatches(result: HashMap<String, String>) {
|
|
|
|
for (file_name, fmt_text) in result {
|
|
|
|
println!("Mismatch in {}.", file_name);
|
|
|
|
println!("{}", fmt_text);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-01 16:43:36 +00:00
|
|
|
// Ick, just needed to get a &'static to handle_result.
|
|
|
|
static HANDLE_RESULT: &'static Fn(HashMap<String, String>) = &handle_result;
|
|
|
|
|
2015-05-02 14:50:33 +00:00
|
|
|
pub fn idempotent_check(args: Vec<String>) -> Result<(), HashMap<String, String>> {
|
|
|
|
use std::thread;
|
|
|
|
use std::fs;
|
|
|
|
use std::io::Read;
|
|
|
|
thread::spawn(move || {
|
|
|
|
run(args, WriteMode::Return(HANDLE_RESULT));
|
|
|
|
}).join().map_err(|mut any|
|
|
|
|
any.downcast_mut::<HashMap<String, String>>()
|
|
|
|
.unwrap() // i know it is a hashmap
|
|
|
|
.drain() // i only get a reference :(
|
|
|
|
.collect() // so i need to turn it into an iter and then back
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2015-05-01 16:43:36 +00:00
|
|
|
// Compare output to input.
|
|
|
|
fn handle_result(result: HashMap<String, String>) {
|
2015-05-02 14:50:33 +00:00
|
|
|
let mut failures = HashMap::new();
|
2015-05-01 16:43:36 +00:00
|
|
|
|
2015-05-02 14:50:33 +00:00
|
|
|
for (file_name, fmt_text) in result {
|
|
|
|
let mut f = fs::File::open(&file_name).unwrap();
|
2015-05-01 16:43:36 +00:00
|
|
|
let mut text = String::new();
|
2015-05-02 14:50:33 +00:00
|
|
|
// TODO: speedup by running through bytes iterator
|
2015-05-01 16:43:36 +00:00
|
|
|
f.read_to_string(&mut text).unwrap();
|
2015-05-02 14:50:33 +00:00
|
|
|
if fmt_text != text {
|
|
|
|
failures.insert(file_name, fmt_text);
|
2015-05-01 16:43:36 +00:00
|
|
|
}
|
|
|
|
}
|
2015-05-02 14:50:33 +00:00
|
|
|
if !failures.is_empty() {
|
|
|
|
panic!(failures);
|
2015-05-01 16:43:36 +00:00
|
|
|
}
|
|
|
|
}
|