From f509a60f0a627833c2261ed7708ace341526e6ff Mon Sep 17 00:00:00 2001 From: Andras Schmelczer Date: Sun, 6 Apr 2025 11:20:58 +0100 Subject: [PATCH] Split integration tests --- backend/reconcile/tests/test.rs | 84 +++++++++++++++++++-------------- 1 file changed, 49 insertions(+), 35 deletions(-) diff --git a/backend/reconcile/tests/test.rs b/backend/reconcile/tests/test.rs index 4e43d8a6..5a749f1b 100644 --- a/backend/reconcile/tests/test.rs +++ b/backend/reconcile/tests/test.rs @@ -7,12 +7,57 @@ use reconcile::{reconcile, reconcile_with_cursors}; use serde::Deserialize; #[test] -fn test_with_examples() { +fn test_document_one_way_without_cursors() { + get_all_documents().iter().for_each(|doc| { + doc.assert_eq_without_cursors(&reconcile( + &doc.parent(), + &doc.left().text, + &doc.right().text, + )) + }); +} + +#[test] +fn test_document_one_way_with_cursors() { + get_all_documents().iter().for_each(|doc| { + doc.assert_eq(&reconcile_with_cursors( + &doc.parent(), + doc.left(), + doc.right(), + )) + }); +} + +#[test] +fn test_document_inverse_way_without_cursors() { + get_all_documents().iter().for_each(|doc| { + doc.assert_eq_without_cursors(&reconcile( + &doc.parent(), + &doc.right().text, + &doc.left().text, + )); + }); +} + +#[test] +fn test_document_inverse_way_with_cursors() { + get_all_documents().iter().for_each(|doc| { + doc.assert_eq(&reconcile_with_cursors( + &doc.parent(), + doc.right(), + doc.left(), + )) + }); +} + +fn get_all_documents() -> Vec { let examples_dir = Path::new("tests/examples"); let entries = fs::read_dir(examples_dir) .expect("Failed to read examples directory") .collect::>(); + let mut documents = Vec::new(); + for entry in entries { let entry = entry.expect("Failed to read directory entry"); let path = entry.path(); @@ -20,43 +65,12 @@ fn test_with_examples() { if path.is_file() && path.extension().and_then(|ext| ext.to_str()) == Some("yml") { let file = fs::File::open(&path).expect("Failed to open example file"); for document in serde_yaml::Deserializer::from_reader(file) { - println!("Testing with example from {}", path.display()); - let doc = ExampleDocument::deserialize(document).expect("Failed to deserialize document"); - - test_document(doc); - - println!("Test passed for example from {}", path.display()); + documents.push(doc); } } } -} - -fn test_document(doc: ExampleDocument) { - doc.assert_eq_without_cursors(&reconcile( - &doc.parent(), - &doc.left().text, - &doc.right().text, - )); - - doc.assert_eq(&reconcile_with_cursors( - &doc.parent(), - doc.left(), - doc.right(), - )); - - // inverse direction - doc.assert_eq_without_cursors(&reconcile( - &doc.parent(), - &doc.right().text, - &doc.left().text, - )); - - // inverse direction with cursors - doc.assert_eq(&reconcile_with_cursors( - &doc.parent(), - doc.right(), - doc.left(), - )); + + documents }