From d3b697218773eaa5a3dd368705184726dbc0fa38 Mon Sep 17 00:00:00 2001 From: Paul Buetow Date: Sat, 21 Jun 2025 15:54:07 +0300 Subject: Implement headless testing framework for DS-Sim protocol simulations MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - Created HeadlessSimulationRunner that loads and runs simulations without GUI - Implemented LogCapture to intercept and store all simulation logs - Added ProtocolVerifier for flexible pattern-based log verification - Created test runners: standard, with logs, and clean (filters GUI errors) - Implemented tests for all non-Raft protocols - Added DummySimulatorFrame to satisfy GUI dependencies during loading - Created CleanHeadlessRunner that filters GUI-related errors from output - Updated run-tests.sh script with quiet mode option - Documented the framework architecture and usage The framework successfully runs protocol tests and verifies behavior through log analysis. GUI errors occur internally due to tight coupling in DS-Sim but are filtered in quiet mode for clean output. šŸ¤– Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude --- src/main/java/testing/examples/QuickTest.java | 40 +++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 src/main/java/testing/examples/QuickTest.java (limited to 'src/main/java/testing/examples/QuickTest.java') diff --git a/src/main/java/testing/examples/QuickTest.java b/src/main/java/testing/examples/QuickTest.java new file mode 100644 index 0000000..f6f3e86 --- /dev/null +++ b/src/main/java/testing/examples/QuickTest.java @@ -0,0 +1,40 @@ +package testing.examples; + +import testing.*; + +public class QuickTest { + public static void main(String[] args) throws Exception { + // Use command line arg or default + String simulationFile = args.length > 0 ? args[0] : "saved-simulations/ping-pong.dat"; + long duration = args.length > 1 ? Long.parseLong(args[1]) : 1000; + + if (args.length == 0) { + System.out.println("=== Quick Headless Test ===\n"); + } + + HeadlessSimulationRunner runner = new HeadlessSimulationRunner(); + + try { + SimulationResult result = runner.runSimulation( + simulationFile, + duration + ); + + System.out.println("Captured " + result.getAllLogs().size() + " logs"); + System.out.println("\nFirst 5 logs:"); + result.getAllLogs().stream() + .limit(5) + .forEach(log -> System.out.println(" " + log)); + + // Simple verification + boolean hasActivation = result.countLogs("activated") > 0; + boolean hasMessages = result.countLogs("Message") > 0; + + System.out.println("\nāœ“ Protocol activated: " + hasActivation); + System.out.println("āœ“ Messages exchanged: " + hasMessages); + + } finally { + runner.shutdown(); + } + } +} \ No newline at end of file -- cgit v1.2.3