mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2025-04-20 02:40:03 +02:00
490 lines
16 KiB
Python
Executable File
490 lines
16 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
# -*- coding: utf-8 -*-
|
|
"""
|
|
Testing parameters and methods of the Detector class using mocks
|
|
"""
|
|
from unittest.mock import Mock
|
|
import pytest
|
|
from pytest_mock import mocker
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
def d():
|
|
from sls_detector import Eiger
|
|
return Eiger()
|
|
|
|
|
|
def test_acq_call(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.acq')
|
|
d.acq()
|
|
m.assert_called_once_with()
|
|
|
|
def test_busy_call(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getAcquiringFlag')
|
|
m.return_value = False
|
|
assert d.busy == False
|
|
|
|
|
|
def test_assign_to_detector_type(d):
|
|
with pytest.raises(AttributeError):
|
|
d.detector_type = 'Eiger'
|
|
|
|
def test_det_type(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getDetectorType')
|
|
m.return_value = 'Eiger'
|
|
assert d.detector_type == 'Eiger'
|
|
|
|
def test_set_dynamic_range_4(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setDynamicRange')
|
|
d.dynamic_range = 4
|
|
m.assert_called_with(4)
|
|
|
|
def test_set_dynamic_range_8(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setDynamicRange')
|
|
d.dynamic_range = 8
|
|
m.assert_called_with(8)
|
|
|
|
|
|
def test_set_dynamic_range_16(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setDynamicRange')
|
|
d.dynamic_range = 16
|
|
m.assert_called_with(16)
|
|
|
|
def test_set_dynamic_range_32(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setDynamicRange')
|
|
d.dynamic_range = 32
|
|
m.assert_called_with(32)
|
|
|
|
def test_set_dynamic_range_raises_exception(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.setDynamicRange')
|
|
with pytest.raises(ValueError):
|
|
d.dynamic_range = 17
|
|
|
|
def test_get_dynamic_range_32(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getDynamicRange')
|
|
m.return_value = 32
|
|
dr = d.dynamic_range
|
|
assert dr == 32
|
|
|
|
def test_eiger_matrix_reset(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getCounterBit')
|
|
m.return_value = True
|
|
assert d.eiger_matrix_reset == True
|
|
|
|
def test_set_eiger_matrix_reset(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setCounterBit')
|
|
d.eiger_matrix_reset = True
|
|
m.assert_called_once_with(True)
|
|
|
|
|
|
def test_get_exposure_time(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getExposureTime')
|
|
m.return_value = 100000000
|
|
assert d.exposure_time == 0.1
|
|
|
|
def test_set_exposure_time(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setExposureTime')
|
|
d.exposure_time = 1.5
|
|
m.assert_called_once_with(1500000000)
|
|
|
|
def test_set_exposure_time_less_than_zero(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.setExposureTime')
|
|
with pytest.raises(ValueError):
|
|
d.exposure_time = -7
|
|
|
|
|
|
def test_get_file_index(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getFileIndex')
|
|
m.return_value = 8
|
|
assert d.file_index == 8
|
|
|
|
def test_set_file_index(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setFileIndex')
|
|
d.file_index = 9
|
|
m.assert_called_with(9)
|
|
|
|
|
|
def test_set_file_index_raises_on_neg(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.setFileIndex')
|
|
with pytest.raises(ValueError):
|
|
d.file_index = -9
|
|
|
|
|
|
def test_get_file_name(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getFileName')
|
|
d.file_name
|
|
m.assert_called_once_with()
|
|
|
|
def test_set_file_name(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setFileName')
|
|
d.file_name = 'hej'
|
|
m.assert_called_once_with('hej')
|
|
|
|
def test_get_file_path(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getFilePath')
|
|
d.file_path
|
|
m.assert_called_once_with()
|
|
|
|
def test_set_file_path_when_path_exists(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setFilePath')
|
|
#To avoid raising an exception because path is not there
|
|
mock_os = mocker.patch('os.path.exists')
|
|
mock_os.return_value = True
|
|
d.file_path = '/path/to/something/'
|
|
m.assert_called_once_with('/path/to/something/')
|
|
|
|
def test_set_file_path_raises_when_not_exists(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.setFilePath')
|
|
mock_os = mocker.patch('os.path.exists')
|
|
mock_os.return_value = False
|
|
with pytest.raises(FileNotFoundError):
|
|
d.file_path = '/path/to/something/'
|
|
|
|
def test_get_file_write(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getFileWrite')
|
|
m.return_value = False
|
|
assert d.file_write == False
|
|
|
|
def test_set_file_write(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setFileWrite')
|
|
d.file_write = True
|
|
m.assert_called_once_with(True)
|
|
|
|
|
|
def test_get_firmware_version(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getFirmwareVersion')
|
|
m.return_value = 20
|
|
assert d.firmware_version == 20
|
|
|
|
def test_cannot_set_fw_version(d):
|
|
with pytest.raises(AttributeError):
|
|
d.firmware_version = 20
|
|
|
|
def test_get_high_voltage_call_signature(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getDac')
|
|
d.high_voltage
|
|
m.assert_called_once_with('highvoltage', -1)
|
|
|
|
def test_get_high_voltage(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getDac')
|
|
m.return_value = 80
|
|
assert d.high_voltage == 80
|
|
|
|
#self._api.setDac('highvoltage', -1, voltage)
|
|
def test_set_high_voltage(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setDac')
|
|
d.high_voltage = 80
|
|
m.assert_called_once_with('highvoltage', -1, 80)
|
|
|
|
def test_decode_hostname_two_names(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getHostname')
|
|
m.return_value = 'beb059+beb048+'
|
|
assert d.hostname == ['beb059', 'beb048']
|
|
|
|
def test_decode_hostname_four_names(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getHostname')
|
|
m.return_value = 'beb059+beb048+beb120+beb153+'
|
|
assert d.hostname == ['beb059', 'beb048', 'beb120', 'beb153']
|
|
|
|
def test_decode_hostname_blank(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getHostname')
|
|
m.return_value = ''
|
|
assert d.hostname == []
|
|
|
|
def test_get_image_size_gives_correct_size(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getImageSize')
|
|
m.return_value = (512,1024)
|
|
im_size = d.image_size
|
|
assert im_size.rows == 512
|
|
assert im_size.cols == 1024
|
|
|
|
|
|
|
|
def test_load_config(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.readConfigurationFile')
|
|
#To avoid raising an exception because path is not there
|
|
mock_os = mocker.patch('os.path.isfile')
|
|
mock_os.return_value = True
|
|
d.load_config('/path/to/my/file.config')
|
|
m.assert_called_once_with('/path/to/my/file.config')
|
|
|
|
def test_load_config_raises_when_file_is_not_found(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.readConfigurationFile')
|
|
mock_os = mocker.patch('os.path.isfile')
|
|
mock_os.return_value = False
|
|
with pytest.raises(FileNotFoundError):
|
|
d.load_config('/path/to/my/file.config')
|
|
|
|
def test_load_parameters(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.readParametersFile')
|
|
#To avoid raising an exception because path is not there
|
|
mock_os = mocker.patch('os.path.isfile')
|
|
mock_os.return_value = True
|
|
d.load_parameters('/path/to/my/file.par')
|
|
m.assert_called_once_with('/path/to/my/file.par')
|
|
|
|
def test_load_parameters_raises_when_file_is_not_found(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.readParametersFile')
|
|
mock_os = mocker.patch('os.path.isfile')
|
|
mock_os.return_value = False
|
|
with pytest.raises(FileNotFoundError):
|
|
d.load_parameters('/path/to/my/file.par')
|
|
|
|
#getDetectorGeometry
|
|
def test_get_module_geometry_gives_correct_size(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getDetectorGeometry')
|
|
m.return_value = (13,7)
|
|
g = d.module_geometry
|
|
assert g.vertical == 7
|
|
assert g.horizontal == 13
|
|
|
|
def test_get_module_geometry_access(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getDetectorGeometry')
|
|
m.return_value = (12,3)
|
|
assert d.module_geometry[0] == 12
|
|
assert d.module_geometry[1] == 3
|
|
assert d.module_geometry.vertical == 3
|
|
assert d.module_geometry.horizontal == 12
|
|
|
|
def test_get_n_frames(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getNumberOfFrames')
|
|
m.return_value = 3
|
|
assert d.n_frames == 3
|
|
|
|
def test_set_n_frames(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setNumberOfFrames')
|
|
d.n_frames = 9
|
|
m.assert_called_once_with(9)
|
|
|
|
def test_set_n_frames_raises_on_neg(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.setNumberOfFrames')
|
|
with pytest.raises(ValueError):
|
|
d.n_frames = -1
|
|
|
|
def test_set_n_frames_raises_on_zero(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.setNumberOfFrames')
|
|
with pytest.raises(ValueError):
|
|
d.n_frames = 0
|
|
|
|
def test_get_n_modules(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getNumberOfDetectors')
|
|
m.return_value = 12
|
|
assert d.n_modules == 12
|
|
|
|
def test_get_period_time(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getPeriod')
|
|
m.return_value = 130000000
|
|
assert d.period == 0.13
|
|
|
|
def test_set_period_time(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setPeriod')
|
|
d.period = 1.953
|
|
m.assert_called_once_with(1953000000)
|
|
|
|
def test_set_period_time_less_than_zero(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.setPeriod')
|
|
with pytest.raises(ValueError):
|
|
d.period = -7
|
|
|
|
def test_pulse_chip_call(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.pulseChip')
|
|
d.pulse_chip(15)
|
|
m.assert_called_once_with(15)
|
|
|
|
def test_pulse_chip_call_minus_one(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.pulseChip')
|
|
d.pulse_chip(-1)
|
|
m.assert_called_once_with(-1)
|
|
|
|
def test_pulse_chip_asserts_on_smaller_than_minus_one(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.pulseChip')
|
|
with pytest.raises(ValueError):
|
|
d.pulse_chip(-3)
|
|
#--------------------------------------------------------------------subexptime
|
|
def test_get_sub_exposure_time(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getSubExposureTime')
|
|
m.return_value = 2370000
|
|
assert d.sub_exposure_time == 0.00237
|
|
|
|
|
|
def test_set_sub_exposure_time(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setSubExposureTime')
|
|
d.sub_exposure_time = 0.002
|
|
m.assert_called_once_with(2000000)
|
|
|
|
def test_set_sub_exposure_time_raises_on_zero(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.setSubExposureTime')
|
|
with pytest.raises(ValueError):
|
|
d.sub_exposure_time = 0
|
|
|
|
#-------------------------------------------------------------Rate correction
|
|
def test_get_rate_correction(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getRateCorrection')
|
|
m.return_value = [132,129]
|
|
assert d.rate_correction == [132,129]
|
|
|
|
def test_set_rate_correction(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setRateCorrection')
|
|
mock_n = mocker.patch('_slsdet.DetectorApi.getNumberOfDetectors')
|
|
mock_n.return_value = 3
|
|
d.rate_correction = [123,90,50]
|
|
m.assert_called_once_with([123,90,50])
|
|
|
|
def test_set_rate_correction_raises_on_wrong_number_of_values(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.setRateCorrection')
|
|
mock_n = mocker.patch('_slsdet.DetectorApi.getNumberOfDetectors')
|
|
mock_n.return_value = 4
|
|
with pytest.raises(ValueError):
|
|
d.rate_correction = [123,90,50]
|
|
|
|
#----------------------------------------------------------------Readout clock
|
|
def test_get_readout_clock_0(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getReadoutClockSpeed')
|
|
m.return_value = 0
|
|
assert d.readout_clock == 'Full Speed'
|
|
|
|
def test_get_readout_clock_1(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getReadoutClockSpeed')
|
|
m.return_value = 1
|
|
assert d.readout_clock == 'Half Speed'
|
|
|
|
def test_get_readout_clock_2(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getReadoutClockSpeed')
|
|
m.return_value = 2
|
|
assert d.readout_clock == 'Quarter Speed'
|
|
|
|
def test_get_readout_clock_3(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getReadoutClockSpeed')
|
|
m.return_value = 3
|
|
assert d.readout_clock == 'Super Slow Speed'
|
|
|
|
def test_set_readout_clock_0(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setReadoutClockSpeed')
|
|
d.readout_clock = 'Full Speed'
|
|
m.assert_called_once_with(0)
|
|
|
|
def test_set_readout_clock_1(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setReadoutClockSpeed')
|
|
d.readout_clock = 'Half Speed'
|
|
m.assert_called_once_with(1)
|
|
|
|
def test_set_readout_clock_2(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setReadoutClockSpeed')
|
|
d.readout_clock = 'Quarter Speed'
|
|
m.assert_called_once_with(2)
|
|
|
|
def test_set_readout_clock_3(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setReadoutClockSpeed')
|
|
d.readout_clock = 'Super Slow Speed'
|
|
m.assert_called_once_with(3)
|
|
|
|
#----------------------------------------------------------------rx_zmqstream
|
|
def test_get_rx_zmqstream(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getRxDataStreamStatus')
|
|
m.return_value = False
|
|
assert d.rx_zmqstream == False
|
|
|
|
def test_set_rx_zmqstream(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setRxDataStreamStatus')
|
|
d.rx_zmqstream = True
|
|
m.assert_called_once_with(True)
|
|
|
|
def test_get_rx_zmqip(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getNetworkParameter')
|
|
d.rx_zmqip
|
|
m.assert_called_once_with('rx_zmqip')
|
|
|
|
def test_get_rx_zmqport_call(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getNetworkParameter')
|
|
d.rx_zmqport
|
|
m.assert_called_once_with('rx_zmqport')
|
|
|
|
def test_get_rx_zmqport_decode(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getNetworkParameter')
|
|
m.return_value = '30001+30003+'
|
|
assert d.rx_zmqport == [30001, 30002, 30003, 30004]
|
|
|
|
def test_get_rx_zmqport_empty(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getNetworkParameter')
|
|
m.return_value = ''
|
|
assert d.rx_zmqport == []
|
|
|
|
|
|
#--------------------------------------------------------------------status
|
|
def test_status_call(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getRunStatus')
|
|
d.status
|
|
m.assert_called_once_with()
|
|
|
|
def test_start_acq_call(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.startAcquisition')
|
|
d.start_acq()
|
|
m.assert_called_once_with()
|
|
|
|
def test_stop_acq_call(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.stopAcquisition')
|
|
d.stop_acq()
|
|
m.assert_called_once_with()
|
|
|
|
#--------------------------------------------------------------------subexptime
|
|
def test_get_sub_exposure_time(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getSubExposureTime')
|
|
m.return_value = 2370000
|
|
assert d.sub_exposure_time == 0.00237
|
|
|
|
|
|
def test_set_sub_exposure_time(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setSubExposureTime')
|
|
d.sub_exposure_time = 0.002
|
|
m.assert_called_once_with(2000000)
|
|
|
|
def test_set_sub_exposure_time_raises_on_zero(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.setSubExposureTime')
|
|
with pytest.raises(ValueError):
|
|
d.sub_exposure_time = 0
|
|
|
|
#------------------------------------------------------------------timing mode
|
|
def test_get_timing_mode(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getTimingMode')
|
|
d.timing_mode
|
|
m.assert_called_once_with()
|
|
|
|
def test_set_timing_mode(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setTimingMode')
|
|
d.timing_mode = 'auto'
|
|
m.assert_called_once_with('auto')
|
|
|
|
#----------------------------------------------------------------vthreshold
|
|
def test_get_vthreshold(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getDac')
|
|
d.vthreshold
|
|
m.assert_called_once_with('vthreshold', -1)
|
|
|
|
def test_set_vthreshold(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setDac')
|
|
d.vthreshold = 1675
|
|
m.assert_called_once_with('vthreshold', -1, 1675)
|
|
|
|
#----------------------------------------------------------------trimbits
|
|
def test_get_trimbits(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.getAllTrimbits')
|
|
d.trimbits
|
|
m.assert_called_once_with()
|
|
|
|
def test_set_trimbits(d, mocker):
|
|
m = mocker.patch('_slsdet.DetectorApi.setAllTrimbits')
|
|
d.trimbits = 15
|
|
m.assert_called_once_with(15)
|
|
|
|
def test_set_trimbits_raises_outside_range(d, mocker):
|
|
mocker.patch('_slsdet.DetectorApi.setAllTrimbits')
|
|
|
|
with pytest.raises(ValueError):
|
|
d.trimbits = 69
|
|
|
|
with pytest.raises(ValueError):
|
|
d.trimbits = -5
|
|
|
|
|