0
0
mirror of https://github.com/bec-project/bec_widgets.git synced 2025-07-14 11:41:49 +02:00

test: bugfix to prohibit leackage of mock

This commit is contained in:
2024-06-24 13:17:52 +02:00
parent 5c11fde0a9
commit 4348ed1bb2
2 changed files with 127 additions and 154 deletions

View File

@ -11,7 +11,7 @@ import qdarktheme
from bec_lib.utils.import_utils import lazy_import_from
from pydantic import BaseModel, Field, field_validator
from qtpy.QtCore import QObject, QTimer, Signal, Slot
from qtpy.QtWidgets import QTreeWidget, QTreeWidgetItem, QVBoxLayout, QWidget
from qtpy.QtWidgets import QTreeWidget, QTreeWidgetItem
from bec_widgets.utils.bec_connector import BECConnector, ConnectionConfig
from bec_widgets.widgets.bec_status_box.status_item import StatusItem
@ -108,6 +108,7 @@ class BECStatusBox(BECConnector, QTreeWidget):
service_name: str = "BEC Server",
client: BECClient = None,
config: BECStatusBoxConfig | dict = None,
bec_service_status_mixin: BECServiceStatusMixin = None,
gui_id: str = None,
):
if config is None:
@ -124,7 +125,10 @@ class BECStatusBox(BECConnector, QTreeWidget):
self.bec_service_info_container = {}
self.tree_items = {}
self.tree_top_item = None
self.bec_service_status = BECServiceStatusMixin(client=self.client)
if not bec_service_status_mixin:
bec_service_status_mixin = BECServiceStatusMixin(client=self.client)
self.bec_service_status = bec_service_status_mixin
self.init_ui()
self.bec_service_status.services_update.connect(self.update_service_status)

View File

@ -1,152 +1,121 @@
# import re
# from unittest import mock
#
# import pytest
# from bec_lib.messages import BECStatus, ServiceMetricMessage, StatusMessage
# from qtpy.QtCore import QMetaMethod
#
# from bec_widgets.widgets.bec_status_box.bec_status_box import BECServiceInfoContainer, BECStatusBox
#
# from .client_mocks import mocked_client
#
#
# @pytest.fixture
# def status_box(qtbot, mocked_client):
# with mock.patch(
# "bec_widgets.widgets.bec_status_box.bec_status_box.BECServiceStatusMixin"
# ) as mock_service_status_mixin:
# widget = BECStatusBox(client=mocked_client)
# qtbot.addWidget(widget)
# qtbot.waitExposed(widget)
# yield widget
#
#
# def test_status_box_init(qtbot, mocked_client):
# with mock.patch(
# "bec_widgets.widgets.bec_status_box.bec_status_box.BECServiceStatusMixin"
# ) as mock_service_status_mixin:
# name = "my test"
# widget = BECStatusBox(parent=None, service_name=name, client=mocked_client)
# qtbot.addWidget(widget)
# qtbot.waitExposed(widget)
# assert widget.headerItem().DontShowIndicator.value == 1
# assert widget.children()[0].children()[0].config.service_name == name
#
#
# def test_update_top_item(qtbot, mocked_client):
# with (
# mock.patch(
# "bec_widgets.widgets.bec_status_box.bec_status_box.BECServiceStatusMixin"
# ) as mock_service_status_mixin,
# mock.patch(
# "bec_widgets.widgets.bec_status_box.status_item.StatusItem.update_config"
# ) as mock_update,
# ):
# name = "my test"
# widget = BECStatusBox(parent=None, service_name=name, client=mocked_client)
# qtbot.addWidget(widget)
# qtbot.waitExposed(widget)
# widget.update_top_item_status(status="RUNNING")
# assert widget.bec_service_info_container[name].status == "RUNNING"
# assert mock_update.call_args == mock.call(widget.bec_service_info_container[name].dict())
#
#
# def test_create_status_widget(status_box):
# name = "test_service"
# status = BECStatus.IDLE
# info = {"test": "test"}
# metrics = {"metric": "test_metric"}
# item = status_box._create_status_widget(name, status, info, metrics)
# assert item.config.service_name == name
# assert item.config.status == status.name
# assert item.config.info == info
# assert item.config.metrics == metrics
#
#
# def test_bec_service_container(status_box):
# name = "test_service"
# status = BECStatus.IDLE
# info = {"test": "test"}
# metrics = {"metric": "test_metric"}
# expected_return = BECServiceInfoContainer(
# service_name=name, status=status, info=info, metrics=metrics
# )
# assert status_box.service_name in status_box.bec_service_info_container
# assert len(status_box.bec_service_info_container) == 1
# status_box._update_bec_service_container(name, status, info, metrics)
# assert len(status_box.bec_service_info_container) == 2
# assert status_box.bec_service_info_container[name] == expected_return
#
#
# def test_add_tree_item(status_box):
# name = "test_service"
# status = BECStatus.IDLE
# info = {"test": "test"}
# metrics = {"metric": "test_metric"}
# assert len(status_box.children()[0].children()) == 1
# status_box.add_tree_item(name, status, info, metrics)
# assert len(status_box.children()[0].children()) == 2
# assert name in status_box.tree_items
#
#
# def test_update_service_status(status_box):
# """Also checks check redundant tree items"""
# name = "test_service"
# status = BECStatus.IDLE
# info = {"test": "test"}
# metrics = {"metric": "test_metric"}
# status_box.add_tree_item(name, status, info, {})
# not_connected_name = "invalid_service"
# status_box.add_tree_item(not_connected_name, status, info, metrics)
#
# services_status = {name: StatusMessage(name=name, status=status, info=info)}
# services_metrics = {name: ServiceMetricMessage(name=name, metrics=metrics)}
#
# with mock.patch.object(status_box, "update_core_services", return_value=services_status):
# assert not_connected_name in status_box.tree_items
# status_box.update_service_status(services_status, services_metrics)
# assert status_box.tree_items[name][1].config.metrics == metrics
# assert not_connected_name not in status_box.tree_items
#
#
# def test_update_core_services(qtbot, mocked_client):
# with (
# mock.patch(
# "bec_widgets.widgets.bec_status_box.bec_status_box.BECServiceStatusMixin"
# ) as mock_service_status_mixin,
# mock.patch(
# "bec_widgets.widgets.bec_status_box.bec_status_box.BECStatusBox.update_top_item_status"
# ) as mock_update,
# ):
# name = "my test"
# status_box = BECStatusBox(parent=None, service_name=name, client=mocked_client)
# qtbot.addWidget(status_box)
# qtbot.waitExposed(status_box)
# status_box.CORE_SERVICES = ["test_service"]
# name = "test_service"
# status = BECStatus.RUNNING
# info = {"test": "test"}
# metrics = {"metric": "test_metric"}
# services_status = {name: StatusMessage(name=name, status=status, info=info)}
# services_metrics = {name: ServiceMetricMessage(name=name, metrics=metrics)}
#
# status_box.update_core_services(services_status, services_metrics)
# assert mock_update.call_args == mock.call(status.name)
#
# status = BECStatus.IDLE
# services_status = {name: StatusMessage(name=name, status=status, info=info)}
# services_metrics = {name: ServiceMetricMessage(name=name, metrics=metrics)}
# status_box.update_core_services(services_status, services_metrics)
# assert mock_update.call_args == mock.call("ERROR")
#
#
# def test_double_click_item(status_box):
# name = "test_service"
# status = BECStatus.IDLE
# info = {"test": "test"}
# metrics = {"MyData": "This should be shown nicely"}
# status_box.add_tree_item(name, status, info, metrics)
# item, status_item = status_box.tree_items[name]
# with mock.patch.object(status_item, "show_popup") as mock_show_popup:
# status_box.itemDoubleClicked.emit(item, 0)
# assert mock_show_popup.call_count == 1
from unittest import mock
import pytest
from bec_lib.messages import BECStatus, ServiceMetricMessage, StatusMessage
from bec_widgets.widgets.bec_status_box.bec_status_box import BECServiceInfoContainer, BECStatusBox
from .client_mocks import mocked_client
@pytest.fixture
def service_status_fixture():
yield mock.MagicMock()
@pytest.fixture
def status_box(qtbot, mocked_client, service_status_fixture):
widget = BECStatusBox(
client=mocked_client, service_name="test", bec_service_status_mixin=service_status_fixture
)
qtbot.addWidget(widget)
qtbot.waitExposed(widget)
yield widget
def test_update_top_item(status_box):
assert status_box.children()[0].children()[0].config.status == "IDLE"
status_box.update_top_item_status(status="RUNNING")
assert status_box.bec_service_info_container["test"].status == "RUNNING"
assert status_box.children()[0].children()[0].config.status == "RUNNING"
def test_create_status_widget(status_box):
name = "test_service"
status = BECStatus.IDLE
info = {"test": "test"}
metrics = {"metric": "test_metric"}
item = status_box._create_status_widget(name, status, info, metrics)
assert item.config.service_name == name
assert item.config.status == status.name
assert item.config.info == info
assert item.config.metrics == metrics
def test_bec_service_container(status_box):
name = "test_service"
status = BECStatus.IDLE
info = {"test": "test"}
metrics = {"metric": "test_metric"}
expected_return = BECServiceInfoContainer(
service_name=name, status=status, info=info, metrics=metrics
)
assert status_box.service_name in status_box.bec_service_info_container
assert len(status_box.bec_service_info_container) == 1
status_box._update_bec_service_container(name, status, info, metrics)
assert len(status_box.bec_service_info_container) == 2
assert status_box.bec_service_info_container[name] == expected_return
def test_add_tree_item(status_box):
name = "test_service"
status = BECStatus.IDLE
info = {"test": "test"}
metrics = {"metric": "test_metric"}
assert len(status_box.children()[0].children()) == 1
status_box.add_tree_item(name, status, info, metrics)
assert len(status_box.children()[0].children()) == 2
assert name in status_box.tree_items
def test_update_service_status(status_box):
"""Also checks check redundant tree items"""
name = "test_service"
status = BECStatus.IDLE
info = {"test": "test"}
metrics = {"metric": "test_metric"}
status_box.add_tree_item(name, status, info, {})
not_connected_name = "invalid_service"
status_box.add_tree_item(not_connected_name, status, info, metrics)
services_status = {name: StatusMessage(name=name, status=status, info=info)}
services_metrics = {name: ServiceMetricMessage(name=name, metrics=metrics)}
with mock.patch.object(status_box, "update_core_services", return_value=services_status):
assert not_connected_name in status_box.tree_items
status_box.update_service_status(services_status, services_metrics)
assert status_box.tree_items[name][1].config.metrics == metrics
assert not_connected_name not in status_box.tree_items
def test_update_core_services(status_box):
status_box.CORE_SERVICES = ["test_service"]
name = "test_service"
status = BECStatus.RUNNING
info = {"test": "test"}
metrics = {"metric": "test_metric"}
services_status = {name: StatusMessage(name=name, status=status, info=info)}
services_metrics = {name: ServiceMetricMessage(name=name, metrics=metrics)}
status_box.update_core_services(services_status, services_metrics)
assert status_box.children()[0].children()[0].config.status == "RUNNING"
assert status_box.tree_items[name][1].config.metrics == metrics
status = BECStatus.IDLE
services_status = {name: StatusMessage(name=name, status=status, info=info)}
services_metrics = {name: ServiceMetricMessage(name=name, metrics=metrics)}
status_box.update_core_services(services_status, services_metrics)
assert status_box.children()[0].children()[0].config.status == "ERROR"
assert status_box.tree_items[name][1].config.metrics == metrics
def test_double_click_item(status_box):
name = "test_service"
status = BECStatus.IDLE
info = {"test": "test"}
metrics = {"MyData": "This should be shown nicely"}
status_box.add_tree_item(name, status, info, metrics)
item, status_item = status_box.tree_items[name]
with mock.patch.object(status_item, "show_popup") as mock_show_popup:
status_box.itemDoubleClicked.emit(item, 0)
assert mock_show_popup.call_count == 1