forked from p15670423/monkey
agent: Refactor BatchingTelemetryMessenger tests to destroy threads
This commit is contained in:
parent
8cf316b64a
commit
d5a26ca6eb
|
@ -1,7 +1,5 @@
|
||||||
import time
|
import time
|
||||||
|
|
||||||
import pytest
|
|
||||||
|
|
||||||
from infection_monkey.telemetry.base_telem import BaseTelem
|
from infection_monkey.telemetry.base_telem import BaseTelem
|
||||||
from infection_monkey.telemetry.batchable_telem_mixin import BatchableTelemMixin
|
from infection_monkey.telemetry.batchable_telem_mixin import BatchableTelemMixin
|
||||||
from infection_monkey.telemetry.i_batchable_telem import IBatchableTelem
|
from infection_monkey.telemetry.i_batchable_telem import IBatchableTelem
|
||||||
|
@ -53,15 +51,21 @@ class BatchableTelemStub(BatchableTelemMixin, BaseTelem, IBatchableTelem):
|
||||||
return {"entries": self._telemetry_entries}
|
return {"entries": self._telemetry_entries}
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
# Note that this function is not a fixture. This is because BatchingTelemetyMessenger
|
||||||
def batching_telemetry_messenger(monkeypatch, telemetry_messenger_spy):
|
# stops its thread when it is destructed. If this were a fixture, it may live
|
||||||
|
# past the end of the test, which would allow the in the BatchingTelemetryMessenger
|
||||||
|
# instance to keep running instead of stopping
|
||||||
|
def build_batching_telemetry_messenger(monkeypatch, telemetry_messenger_spy):
|
||||||
patch_time(monkeypatch, 0)
|
patch_time(monkeypatch, 0)
|
||||||
return BatchingTelemetryMessenger(telemetry_messenger_spy, period=0.001)
|
return BatchingTelemetryMessenger(telemetry_messenger_spy, period=PERIOD)
|
||||||
|
|
||||||
|
|
||||||
def test_send_immediately(batching_telemetry_messenger, telemetry_messenger_spy):
|
def test_send_immediately(monkeypatch, telemetry_messenger_spy):
|
||||||
|
batching_telemetry_messenger = build_batching_telemetry_messenger(
|
||||||
|
monkeypatch, telemetry_messenger_spy
|
||||||
|
)
|
||||||
|
|
||||||
telem = NonBatchableTelemStub()
|
telem = NonBatchableTelemStub()
|
||||||
|
|
||||||
batching_telemetry_messenger.send_telemetry(telem)
|
batching_telemetry_messenger.send_telemetry(telem)
|
||||||
release_GIL()
|
release_GIL()
|
||||||
|
|
||||||
|
@ -69,7 +73,11 @@ def test_send_immediately(batching_telemetry_messenger, telemetry_messenger_spy)
|
||||||
assert telemetry_messenger_spy.telemetries[0] == telem
|
assert telemetry_messenger_spy.telemetries[0] == telem
|
||||||
|
|
||||||
|
|
||||||
def test_send_telem_batch(monkeypatch, batching_telemetry_messenger, telemetry_messenger_spy):
|
def test_send_telem_batch(monkeypatch, telemetry_messenger_spy):
|
||||||
|
batching_telemetry_messenger = build_batching_telemetry_messenger(
|
||||||
|
monkeypatch, telemetry_messenger_spy
|
||||||
|
)
|
||||||
|
|
||||||
expected_data = {"entries": [1, 2]}
|
expected_data = {"entries": [1, 2]}
|
||||||
telem1 = BatchableTelemStub(1)
|
telem1 = BatchableTelemStub(1)
|
||||||
telem2 = BatchableTelemStub(2)
|
telem2 = BatchableTelemStub(2)
|
||||||
|
@ -86,9 +94,11 @@ def test_send_telem_batch(monkeypatch, batching_telemetry_messenger, telemetry_m
|
||||||
assert telemetry_messenger_spy.telemetries[0].get_data() == expected_data
|
assert telemetry_messenger_spy.telemetries[0].get_data() == expected_data
|
||||||
|
|
||||||
|
|
||||||
def test_send_different_telem_types(
|
def test_send_different_telem_types(monkeypatch, telemetry_messenger_spy):
|
||||||
monkeypatch, batching_telemetry_messenger, telemetry_messenger_spy
|
batching_telemetry_messenger = build_batching_telemetry_messenger(
|
||||||
):
|
monkeypatch, telemetry_messenger_spy
|
||||||
|
)
|
||||||
|
|
||||||
telem1 = BatchableTelemStub(1, "cat1")
|
telem1 = BatchableTelemStub(1, "cat1")
|
||||||
telem2 = BatchableTelemStub(2, "cat2")
|
telem2 = BatchableTelemStub(2, "cat2")
|
||||||
|
|
||||||
|
@ -105,7 +115,11 @@ def test_send_different_telem_types(
|
||||||
assert telemetry_messenger_spy.telemetries[1] == telem2
|
assert telemetry_messenger_spy.telemetries[1] == telem2
|
||||||
|
|
||||||
|
|
||||||
def test_send_two_batches(monkeypatch, batching_telemetry_messenger, telemetry_messenger_spy):
|
def test_send_two_batches(monkeypatch, telemetry_messenger_spy):
|
||||||
|
batching_telemetry_messenger = build_batching_telemetry_messenger(
|
||||||
|
monkeypatch, telemetry_messenger_spy
|
||||||
|
)
|
||||||
|
|
||||||
telem1 = BatchableTelemStub(1, "cat1")
|
telem1 = BatchableTelemStub(1, "cat1")
|
||||||
telem2 = BatchableTelemStub(2, "cat1")
|
telem2 = BatchableTelemStub(2, "cat1")
|
||||||
|
|
||||||
|
@ -125,9 +139,8 @@ def test_send_two_batches(monkeypatch, batching_telemetry_messenger, telemetry_m
|
||||||
|
|
||||||
|
|
||||||
def test_send_remaining_telem_after_stop(monkeypatch, telemetry_messenger_spy):
|
def test_send_remaining_telem_after_stop(monkeypatch, telemetry_messenger_spy):
|
||||||
patch_time(monkeypatch, 0)
|
batching_telemetry_messenger = build_batching_telemetry_messenger(
|
||||||
batching_telemetry_messenger = BatchingTelemetryMessenger(
|
monkeypatch, telemetry_messenger_spy
|
||||||
telemetry_messenger_spy, period=PERIOD
|
|
||||||
)
|
)
|
||||||
|
|
||||||
expected_data = {"entries": [1]}
|
expected_data = {"entries": [1]}
|
||||||
|
|
Loading…
Reference in New Issue