diff options
| author | Paul Buetow <paul@buetow.org> | 2025-06-21 20:10:38 +0300 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2025-06-21 20:10:38 +0300 |
| commit | 695adc1f6bfb0a0eeef4dd6c035475ea2826871f (patch) | |
| tree | 945fc0552d4f7f1ef1f468f6030e9925970fa72b /src/main/java/core | |
| parent | d3b697218773eaa5a3dd368705184726dbc0fa38 (diff) | |
Complete GUI decoupling implementation for headless testing
- Implement MessageHandler pattern to decouple message sending from visualization
- Add HeadlessLoader to load simulations without GUI components
- Create HeadlessProtocolRunner for clean protocol test execution
- Update VSInternalProcess to use MessageHandler for message routing
- Add null checks in VSSimulator for headless mode compatibility
- Update VSSimulatorVisualization paint() to check for headless mode
- Remove obsolete test scripts and documentation
- Update test-protocols.sh to remove GUI error suppression options
- Consolidate testing documentation in docs/testing-guide.md
All protocol tests now run cleanly in headless mode without GUI errors,
enabling proper CI/CD integration and automated testing.
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
Diffstat (limited to 'src/main/java/core')
| -rw-r--r-- | src/main/java/core/VSInternalProcess.java | 20 |
1 files changed, 19 insertions, 1 deletions
diff --git a/src/main/java/core/VSInternalProcess.java b/src/main/java/core/VSInternalProcess.java index ddf378e..5d49ec1 100644 --- a/src/main/java/core/VSInternalProcess.java +++ b/src/main/java/core/VSInternalProcess.java @@ -38,6 +38,9 @@ public class VSInternalProcess extends VSAbstractProcess { /** The vector clock monitor for timestamp-triggered events */ private VSVectorClockMonitor vectorClockMonitor; + /** Optional message handler for decoupled message sending */ + private simulator.messaging.MessageHandler messageHandler; + /** * Instantiates a new process. * @@ -408,7 +411,22 @@ public class VSInternalProcess extends VSAbstractProcess { buffer.append("; "); buffer.append(message.toStringFull()); log(buffer.toString()); - simulatorVisualization.sendMessage(message); + + // Use message handler if available (for decoupled operation) + if (messageHandler != null) { + messageHandler.handleMessage(message); + } else { + // Fallback to direct visualization call for backward compatibility + simulatorVisualization.sendMessage(message); + } + } + + /** + * Sets the message handler for decoupled message sending. + * @param handler the message handler to use + */ + public void setMessageHandler(simulator.messaging.MessageHandler handler) { + this.messageHandler = handler; } /** |
