From 1d066c8e6da23d4d8c092fb7a2a2d5d26816abf6 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Mon, 28 Jun 2021 12:05:57 -0400 Subject: [PATCH] agent: Add explicit start to BatchingTelemetryMessenger My original plan was to start a thread in __init__() and stop the thread when __del__() was called. Since the running thread (object) contains a reference to the BatchingTelemetryMessenger object that launched it, the destructor will not be called until the thread is stopped. Therefore, a stop() was added to allow the BatchingTelemetryMessenger to be stopped. Since it has an explicit stop, it should also have an explicit start, rather than starting the thread in the constructor. --- monkey/infection_monkey/monkey.py | 1 + .../telemetry/messengers/batching_telemetry_messenger.py | 8 +++++--- .../messengers/test_batching_telemetry_messenger.py | 1 + 3 files changed, 7 insertions(+), 3 deletions(-) diff --git a/monkey/infection_monkey/monkey.py b/monkey/infection_monkey/monkey.py index 28e59c616..bd9062eeb 100644 --- a/monkey/infection_monkey/monkey.py +++ b/monkey/infection_monkey/monkey.py @@ -474,6 +474,7 @@ class InfectionMonkey(object): def run_ransomware(): telemetry_messenger = LegacyTelemetryMessengerAdapter() batching_telemetry_messenger = BatchingTelemetryMessenger(telemetry_messenger) + batching_telemetry_messenger.start() try: RansomewarePayload( WormConfiguration.ransomware, batching_telemetry_messenger diff --git a/monkey/infection_monkey/telemetry/messengers/batching_telemetry_messenger.py b/monkey/infection_monkey/telemetry/messengers/batching_telemetry_messenger.py index 6596e89e7..f5f21a760 100644 --- a/monkey/infection_monkey/telemetry/messengers/batching_telemetry_messenger.py +++ b/monkey/infection_monkey/telemetry/messengers/batching_telemetry_messenger.py @@ -28,14 +28,16 @@ class BatchingTelemetryMessenger(ITelemetryMessenger): self._last_sent_time = time.time() self._telemetry_batches: Dict[str, IBatchableTelem] = {} + def __del__(self): + self.stop() + + def start(self): + self._should_run_batch_thread = True self._manage_telemetry_batches_thread = threading.Thread( target=self._manage_telemetry_batches ) self._manage_telemetry_batches_thread.start() - def __del__(self): - self.stop() - def stop(self): self._should_run_batch_thread = False self._manage_telemetry_batches_thread.join() diff --git a/monkey/tests/unit_tests/infection_monkey/telemetry/messengers/test_batching_telemetry_messenger.py b/monkey/tests/unit_tests/infection_monkey/telemetry/messengers/test_batching_telemetry_messenger.py index 58ee96d89..65eebc582 100644 --- a/monkey/tests/unit_tests/infection_monkey/telemetry/messengers/test_batching_telemetry_messenger.py +++ b/monkey/tests/unit_tests/infection_monkey/telemetry/messengers/test_batching_telemetry_messenger.py @@ -57,6 +57,7 @@ class BatchableTelemStub(BatchableTelemMixin, BaseTelem, IBatchableTelem): def batching_telemetry_messenger(monkeypatch, telemetry_messenger_spy): patch_time(monkeypatch, 0) btm = BatchingTelemetryMessenger(telemetry_messenger_spy, period=0.001) + btm.start() yield btm btm.stop()