Skip to content

Commit

Permalink
refactor: refactor spec testsuite ... to be prettier :)
Browse files Browse the repository at this point in the history
Signed-off-by: George Cosma <[email protected]>
  • Loading branch information
george-cosma committed Sep 2, 2024
1 parent 8e076e1 commit 752992c
Show file tree
Hide file tree
Showing 4 changed files with 254 additions and 175 deletions.
23 changes: 23 additions & 0 deletions tests/specification/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,33 @@ pub fn spec_dummy() {
pub fn spec_tests() {
let paths = get_wast_files(Path::new("./tests/specification/testsuite/"))
.expect("Failed to find testsuite");

let mut successful_reports = 0;
let mut failed_reports = 0;
let mut compile_error_reports = 0;

for test_path in paths {
let report = run::run_spec_test(test_path.to_str().unwrap());
println!("Report for {}:\n{}", test_path.display(), report);

match report {
reports::WastTestReport::Asserts(assert_report) => {
if assert_report.has_errors() {
failed_reports += 1;
} else {
successful_reports += 1;
}
}
reports::WastTestReport::CompilationError(_) => {
compile_error_reports += 1;
}
}
}

println!(
"Tests: {} Passed, {} Failed, {} Compilation Errors",
successful_reports, failed_reports, compile_error_reports
);
}

// See: https://stackoverflow.com/a/76820878
Expand Down
168 changes: 92 additions & 76 deletions tests/specification/reports.rs
Original file line number Diff line number Diff line change
@@ -1,135 +1,151 @@
use std::error::Error;

pub struct WastSuccess {
filename: String,
line_number: u32,
command: String,
}

impl WastSuccess {
pub fn new(line_number: u32, command: &str) -> Self {
Self {
line_number,
command: command.to_string(),
}
}
}

pub struct WastError {
inner: Box<dyn Error>,
filename: String,
line_number: u32,
line_number: Option<u32>,
command: String,
}

impl WastError {
pub fn new(error: Box<dyn Error>, filename: String, line_number: u32, command: &str) -> Self {
pub fn new(error: Box<dyn Error>, line_number: u32, command: &str) -> Self {
Self {
inner: error,
filename,
line_number,
line_number: Some(line_number),
command: command.to_string(),
}
}

pub fn from_outside(error: Box<dyn Error>, reason: &str) -> Self {
pub fn external(error: Box<dyn Error>, reason: &str) -> Self {
Self {
inner: error,
filename: "".to_string(),
line_number: 0,
line_number: None,
command: reason.to_string(),
}
}
}

pub struct AssertReport {
filename: String,
results: Vec<Result<WastSuccess, WastError>>,
}

impl AssertReport {
pub fn new() -> Self {
pub fn new(filename: &str) -> Self {
Self {
filename: filename.to_string(),
results: Vec::new(),
}
}

pub fn push_success(&mut self, filename: String, line_number: u32, command: String) {
self.results.push(Ok(WastSuccess {
filename,
line_number,
command,
}));
pub fn push_success(&mut self, success: WastSuccess) {
self.results.push(Ok(success));
}

pub fn push_error(
&mut self,
filename: String,
line_number: u32,
command: String,
error: Box<dyn Error>,
) {
self.results.push(Err(WastError {
inner: error,
filename,
line_number,
command,
}));
pub fn push_error(&mut self, error: WastError) {
self.results.push(Err(error));
}
}

pub enum WastTestReport {
Asserts(AssertReport),
CompilationError(WastError),
}

impl From<WastError> for WastTestReport {
fn from(error: WastError) -> Self {
WastTestReport::CompilationError(error)
pub fn compile_report(self) -> WastTestReport {
return WastTestReport::Asserts(self);
}
}

impl From<AssertReport> for WastTestReport {
fn from(assert_report: AssertReport) -> Self {
WastTestReport::Asserts(assert_report)
pub fn has_errors(&self) -> bool {
self.results.iter().any(|r| r.is_err())
}
}

// .------------------------.
// | Display Implementation |
// '------------------------'

impl std::fmt::Display for WastSuccess {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
write!(
f,
"[SUCCESS] {} ({}:{})",
self.command, self.filename, self.line_number
)
}
pub struct CompilationError {
inner: Box<dyn Error>,
filename: String,
context: String,
}

impl std::fmt::Display for WastError {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
writeln!(
f,
"[ERROR] {} ({}:{})",
self.command, self.filename, self.line_number
)?;
write!(f, "\t{}", self.inner)?;
impl CompilationError {
pub fn new(error: Box<dyn Error>, filename: &str, context: &str) -> Self {
Self {
inner: error,
filename: filename.to_string(),
context: context.to_string(),
}
}

Ok(())
pub fn compile_report(self) -> WastTestReport {
return WastTestReport::CompilationError(self);
}
}

impl std::fmt::Display for AssertReport {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
for result in &self.results {
match result {
Ok(success) => writeln!(f, "{}", success)?,
Err(error) => writeln!(f, "{}", error)?,
}
}

Ok(())
}
pub enum WastTestReport {
Asserts(AssertReport),
CompilationError(CompilationError),
}

// .------------------------.
// | Display Implementation |
// '------------------------'

impl std::fmt::Display for WastTestReport {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
match self {
WastTestReport::Asserts(assert_report) => write!(f, "{}", assert_report),
WastTestReport::CompilationError(error) => write!(f, "{}", error),
WastTestReport::CompilationError(error) => {
writeln!(f, "------ {} ------", error.filename)?;
writeln!(f, "⚠ Compilation Failed ⚠")?;
writeln!(f, "Context: {}", error.context)?;
writeln!(f, "Error: {}", error.inner)?;
writeln!(f, "~~~~~~~~~~~~~~~~")?;
writeln!(f, "")?;
}
WastTestReport::Asserts(assert_report) => {
writeln!(f, "------ {} ------", assert_report.filename)?;
for result in &assert_report.results {
match result {
Ok(success) => {
writeln!(
f,
"✅ {}:{} -> {}",
assert_report.filename, success.line_number, success.command
)?;
}
Err(error) => {
writeln!(
f,
"❌ {}:{} -> {}",
assert_report.filename,
error.line_number.unwrap_or(0),
error.command
)?;
writeln!(f, " Error: {}", error.inner)?;
}
}
}
let passed_asserts = assert_report.results.iter().filter(|r| r.is_ok()).count();
let failed_asserts = assert_report.results.iter().filter(|r| r.is_err()).count();
let total_asserts = assert_report.results.len();

writeln!(f, "")?;
writeln!(
f,
"Execution finished. Passed: {}, Failed: {}, Total: {}",
passed_asserts, failed_asserts, total_asserts
)?;
writeln!(f, "~~~~~~~~~~~~~~~~")?;
writeln!(f, "")?;
}
}

Ok(())
}
}
Loading

0 comments on commit 752992c

Please sign in to comment.