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/SimulationMetrics.java | 47 ++++++++++++++++++++++++++++ 1 file changed, 47 insertions(+) create mode 100644 src/main/java/testing/SimulationMetrics.java (limited to 'src/main/java/testing/SimulationMetrics.java') diff --git a/src/main/java/testing/SimulationMetrics.java b/src/main/java/testing/SimulationMetrics.java new file mode 100644 index 0000000..2b80631 --- /dev/null +++ b/src/main/java/testing/SimulationMetrics.java @@ -0,0 +1,47 @@ +package testing; + +import java.util.Collections; +import java.util.Map; + +/** + * Metrics collected during simulation execution. + */ +public class SimulationMetrics { + private final int numProcesses; + private final int totalLogCount; + private final Map processMessageCounts; + + public SimulationMetrics(int numProcesses, + int totalLogCount, + Map processMessageCounts) { + this.numProcesses = numProcesses; + this.totalLogCount = totalLogCount; + this.processMessageCounts = Collections.unmodifiableMap(processMessageCounts); + } + + public int getNumProcesses() { + return numProcesses; + } + + public int getTotalLogCount() { + return totalLogCount; + } + + public Map getProcessMessageCounts() { + return processMessageCounts; + } + + public int getMessageCountForProcess(int processNum) { + return processMessageCounts.getOrDefault(processNum, 0); + } + + public double getAverageMessagesPerProcess() { + if (numProcesses == 0) return 0; + + int totalProcessMessages = processMessageCounts.values().stream() + .mapToInt(Integer::intValue) + .sum(); + + return (double) totalProcessMessages / numProcesses; + } +} \ No newline at end of file -- cgit v1.2.3