0
0
mirror of https://github.com/bec-project/bec_widgets.git synced 2025-07-13 19:21:50 +02:00

tests(motor_map_widget): tests added

This commit is contained in:
2024-07-06 20:20:31 +02:00
committed by wyzula_j
parent c78cd898f2
commit 734f4c7750
5 changed files with 208 additions and 3 deletions

View File

@ -72,6 +72,13 @@ class FakePositioner(FakeDevice):
return MagicMock(get=MagicMock(return_value=self.read_value))
class Positioner(FakePositioner):
"""just placeholder for testing embeded isinstance check in DeviceCombobox"""
def __init__(self, name="test", limits=None, read_value=1.0):
super().__init__(name, limits, read_value)
class DMMock:
def __init__(self):
self.devices = DeviceContainer()
@ -95,6 +102,7 @@ DEVICES = [
FakeDevice("bpm3a"),
FakeDevice("bpm3i"),
FakeDevice("eiger"),
Positioner("test", limits=[-10, 10], read_value=2.0),
]

View File

@ -63,4 +63,4 @@ def test_device_input_base_get_device_list(device_input_base):
def test_device_input_base_get_filters(device_input_base):
filters = device_input_base.get_available_filters()
assert filters == {"FakePositioner", "FakeDevice"}
assert filters == {"FakePositioner", "FakeDevice", "Positioner"}

View File

@ -67,6 +67,7 @@ def test_device_input_combobox_init(device_input_combobox):
"bpm3a",
"bpm3i",
"eiger",
"test",
]
@ -153,6 +154,7 @@ def test_device_input_line_edit_init(device_input_line_edit):
"bpm3a",
"bpm3i",
"eiger",
"test",
]

View File

@ -0,0 +1,196 @@
from unittest.mock import MagicMock, patch
import pytest
from bec_widgets.widgets.motor_map.motor_map_dialog.motor_map_settings import MotorMapSettings
from bec_widgets.widgets.motor_map.motor_map_widget import BECMotorMapWidget
from .client_mocks import mocked_client
@pytest.fixture
def motor_map_widget(qtbot, mocked_client):
widget = BECMotorMapWidget(client=mocked_client())
widget.toolbar.widgets["motor_x"].device_combobox.set_device_filter("FakePositioner")
widget.toolbar.widgets["motor_y"].device_combobox.set_device_filter("FakePositioner")
qtbot.addWidget(widget)
qtbot.waitExposed(widget)
yield widget
widget.close()
@pytest.fixture
def mock_motor_map(motor_map_widget):
motor_map_mock = MagicMock()
motor_map_widget.map = motor_map_mock
return motor_map_mock
def test_motor_map_widget_init(motor_map_widget):
assert motor_map_widget is not None
assert motor_map_widget.client is not None
assert isinstance(motor_map_widget, BECMotorMapWidget)
assert motor_map_widget.config.widget_class == "BECMotorMapWidget"
# check initial state of toolbar actions
assert motor_map_widget.toolbar.widgets["connect"].action.isEnabled() == True
assert motor_map_widget.toolbar.widgets["config"].action.isEnabled() == False
assert motor_map_widget.toolbar.widgets["history"].action.isEnabled() == False
assert (
motor_map_widget.toolbar.widgets["motor_x"].device_combobox.config.device_filter
== "FakePositioner"
)
assert (
motor_map_widget.toolbar.widgets["motor_y"].device_combobox.config.device_filter
== "FakePositioner"
)
assert motor_map_widget.map.motor_x is None
assert motor_map_widget.map.motor_y is None
###################################
# Toolbar Actions
###################################
def test_motor_map_widget_change_motors_enable_toolbar(motor_map_widget):
motor_map_widget.change_motors("samx", "samy")
assert motor_map_widget.map.motor_x == "samx"
assert motor_map_widget.map.motor_y == "samy"
assert motor_map_widget.toolbar.widgets["motor_x"].device_combobox.currentText() == "samx"
assert motor_map_widget.toolbar.widgets["motor_y"].device_combobox.currentText() == "samy"
assert motor_map_widget.toolbar.widgets["config"].action.isEnabled() == True
assert motor_map_widget.toolbar.widgets["history"].action.isEnabled() == True
###################################
# Wrapper methods for MotorMap
###################################
def test_change_motors(motor_map_widget, mock_motor_map):
motor_map_widget.change_motors("motor_x", "motor_y", "motor_x_entry", "motor_y_entry", True)
mock_motor_map.change_motors.assert_called_once_with(
"motor_x", "motor_y", "motor_x_entry", "motor_y_entry", True
)
def test_get_data(motor_map_widget, mock_motor_map):
motor_map_widget.get_data()
mock_motor_map.get_data.assert_called_once()
def test_reset_history(motor_map_widget, mock_motor_map):
motor_map_widget.reset_history()
mock_motor_map.reset_history.assert_called_once()
def test_set_color(motor_map_widget, mock_motor_map):
motor_map_widget.set_color("blue")
mock_motor_map.set_color.assert_called_once_with("blue")
def test_set_max_points(motor_map_widget, mock_motor_map):
motor_map_widget.set_max_points(100)
mock_motor_map.set_max_points.assert_called_once_with(100)
def test_set_precision(motor_map_widget, mock_motor_map):
motor_map_widget.set_precision(2)
mock_motor_map.set_precision.assert_called_once_with(2)
def test_set_num_dim_points(motor_map_widget, mock_motor_map):
motor_map_widget.set_num_dim_points(50)
mock_motor_map.set_num_dim_points.assert_called_once_with(50)
def test_set_background_value(motor_map_widget, mock_motor_map):
motor_map_widget.set_background_value(128)
mock_motor_map.set_background_value.assert_called_once_with(128)
def test_set_scatter_size(motor_map_widget, mock_motor_map):
motor_map_widget.set_scatter_size(10)
mock_motor_map.set_scatter_size.assert_called_once_with(10)
###################################
# MotorMap Dialog
###################################
def test_motor_map_widget_clicked(motor_map_widget, qtbot):
motor_map_widget.toolbar.widgets["motor_x"].device_combobox.setCurrentText("samx")
motor_map_widget.toolbar.widgets["motor_y"].device_combobox.setCurrentText("samy")
motor_map_widget.toolbar.widgets["connect"].action.trigger()
qtbot.wait(200)
assert motor_map_widget.map.motor_x == "samx"
assert motor_map_widget.map.motor_y == "samy"
assert motor_map_widget.toolbar.widgets["config"].action.isEnabled() == True
assert motor_map_widget.toolbar.widgets["history"].action.isEnabled() == True
@pytest.fixture
def motor_map_settings(qtbot):
widget = MotorMapSettings()
qtbot.addWidget(widget)
qtbot.waitExposed(widget)
yield widget
widget.close()
def test_display_current_settings(motor_map_settings):
config = {
"max_points": 100,
"num_dim_points": 50,
"precision": 2,
"scatter_size": 10,
"background_value": 128,
"color": (255, 0, 0, 255),
}
with patch("bec_widgets.utils.widget_io.WidgetIO.set_value") as mock_set_value:
with patch.object(motor_map_settings.ui.color, "setColor") as mock_set_color:
motor_map_settings.display_current_settings(config)
mock_set_value.assert_any_call(motor_map_settings.ui.max_points, config["max_points"])
mock_set_value.assert_any_call(
motor_map_settings.ui.trace_dim, config["num_dim_points"]
)
mock_set_value.assert_any_call(motor_map_settings.ui.precision, config["precision"])
mock_set_value.assert_any_call(
motor_map_settings.ui.scatter_size, config["scatter_size"]
)
mock_set_value.assert_any_call(
motor_map_settings.ui.background_value, 50
) # 128/255*100 = 50
mock_set_color.assert_called_once_with(config["color"])
def test_accept_changes(motor_map_settings):
with patch(
"bec_widgets.utils.widget_io.WidgetIO.get_value", side_effect=[100, 50, 2, 10, 50]
) as mock_get_value:
with patch.object(
motor_map_settings.ui.color, "get_color", return_value=(255, 0, 0, 255)
) as mock_get_color:
mock_target_widget = MagicMock()
motor_map_settings.set_target_widget(mock_target_widget)
motor_map_settings.accept_changes()
mock_get_value.assert_any_call(motor_map_settings.ui.max_points)
mock_get_value.assert_any_call(motor_map_settings.ui.trace_dim)
mock_get_value.assert_any_call(motor_map_settings.ui.precision)
mock_get_value.assert_any_call(motor_map_settings.ui.scatter_size)
mock_get_value.assert_any_call(motor_map_settings.ui.background_value)
mock_get_color.assert_called_once()
mock_target_widget.set_max_points.assert_called_once_with(100)
mock_target_widget.set_num_dim_points.assert_called_once_with(50)
mock_target_widget.set_precision.assert_called_once_with(2)
mock_target_widget.set_scatter_size.assert_called_once_with(10)
mock_target_widget.set_background_value.assert_called_once_with(127)
mock_target_widget.set_color.assert_called_once_with((255, 0, 0, 255))

View File

@ -3,8 +3,7 @@ from unittest.mock import MagicMock, patch
import pytest
from qtpy.QtWidgets import QWidget
from bec_widgets.qt_utils.settings_dialog import SettingWidget, SettingsDialog
from bec_widgets.qt_utils.settings_dialog import SettingsDialog, SettingWidget
###################################
# SettingWidget base class tests