rustlings/src/verify.rs

84 lines
2.8 KiB
Rust
Raw Normal View History

use crate::exercise::{Exercise, Mode};
2019-01-09 22:33:43 +03:00
use console::{style, Emoji};
use indicatif::ProgressBar;
pub fn verify<'a>(start_at: impl IntoIterator<Item = &'a Exercise>) -> Result<(), ()> {
for exercise in start_at {
match exercise.mode {
Mode::Test => test(&exercise)?,
Mode::Compile => compile_only(&exercise)?,
}
}
2019-01-09 22:33:43 +03:00
Ok(())
}
fn compile_only(exercise: &Exercise) -> Result<(), ()> {
2019-03-11 17:09:20 +03:00
let progress_bar = ProgressBar::new_spinner();
progress_bar.set_message(format!("Compiling {}...", exercise).as_str());
2019-03-11 17:09:20 +03:00
progress_bar.enable_steady_tick(100);
let compile_output = exercise.compile();
2019-03-11 17:09:20 +03:00
progress_bar.finish_and_clear();
if compile_output.status.success() {
2019-01-09 22:33:43 +03:00
let formatstr = format!(
"{} Successfully compiled {}!",
Emoji("", ""),
exercise
2019-01-09 22:33:43 +03:00
);
println!("{}", style(formatstr).green());
exercise.clean();
2019-01-09 22:33:43 +03:00
Ok(())
} else {
let formatstr = format!(
"{} Compilation of {} failed! Compiler error message:\n",
Emoji("⚠️ ", "!"),
exercise
2019-01-09 22:33:43 +03:00
);
println!("{}", style(formatstr).red());
println!("{}", String::from_utf8_lossy(&compile_output.stderr));
exercise.clean();
2019-01-09 22:33:43 +03:00
Err(())
}
}
pub fn test(exercise: &Exercise) -> Result<(), ()> {
2019-03-11 17:09:20 +03:00
let progress_bar = ProgressBar::new_spinner();
progress_bar.set_message(format!("Testing {}...", exercise).as_str());
2019-03-11 17:09:20 +03:00
progress_bar.enable_steady_tick(100);
let compile_output = exercise.compile();
if compile_output.status.success() {
progress_bar.set_message(format!("Running {}...", exercise).as_str());
let runcmd = exercise.run();
2019-03-11 17:09:20 +03:00
progress_bar.finish_and_clear();
if runcmd.status.success() {
let formatstr = format!("{} Successfully tested {}!", Emoji("", ""), exercise);
println!("{}", style(formatstr).green());
exercise.clean();
Ok(())
} else {
let formatstr = format!(
"{} Testing of {} failed! Please try again. Here's the output:",
Emoji("⚠️ ", "!"),
exercise
);
println!("{}", style(formatstr).red());
println!("{}", String::from_utf8_lossy(&runcmd.stdout));
exercise.clean();
Err(())
}
2019-01-09 22:33:43 +03:00
} else {
2019-03-11 17:09:20 +03:00
progress_bar.finish_and_clear();
2019-01-09 22:33:43 +03:00
let formatstr = format!(
"{} Compiling of {} failed! Please try again. Here's the output:",
2019-01-09 22:33:43 +03:00
Emoji("⚠️ ", "!"),
exercise
2019-01-09 22:33:43 +03:00
);
println!("{}", style(formatstr).red());
println!("{}", String::from_utf8_lossy(&compile_output.stderr));
exercise.clean();
2019-01-09 22:33:43 +03:00
Err(())
}
}