Table of Contents
Test Report
View CI Run 1242 | Commit 074bf9e ✅ Pytest completed successfully
All tests were collected and executed properly. See the details below.
📋 Short test summary info
=========================== short test summary info ============================
FAILED tests/test_utils_debug.py::test_short_repr[aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa-10-'aaaaaaaaaa...] - assert "'aaaaaaaaa..." == "'aaaaaaaaaa..."
- 'aaaaaaaaaa...
? -
+ 'aaaaaaaaa...
FAILED tests/test_utils_debug.py::test_short_repr[value5-20-Obj(xxxxxxxxxxxxxxxxx...] - AssertionError: assert 'Obj(xxxxxxxxxxxxxxxx...' == 'Obj(xxxxxxxxxxxxxxxxx...'
- Obj(xxxxxxxxxxxxxxxxx...
? -
+ Obj(xxxxxxxxxxxxxxxx...
FAILED tests/test_utils_dictext.py::test_attrdict_getattr[data3-outer.inner-None] - AttributeError: 'MyDict' object has no attribute 'outer.inner'
FAILED tests/test_utils_dictext.py::test_attrdict_getattr[data4-outer.inner-42] - AttributeError: 'MyDict' object has no attribute 'outer.inner'
FAILED tests/test_utils_dictext.py::test_attrdict_getattr_and_missing[data1-missing-None-'AttrDict' object has no attribute 'missing'] - assert "'MyDict' obj...ute 'missing'" == "'AttrDict' o...ute 'missing'"
- 'AttrDict' object has no attribute 'missing'
? ^^^^
+ 'MyDict' object has no attribute 'missing'
? ^^
=================== 5 failed, 90 passed, 4 warnings in 5.82s ===================
🪵 Full raw pytest log
============================= test session starts ==============================
platform linux -- Python 3.8.20, pytest-8.3.4, pluggy-1.5.0
rootdir: /workspace/tligui_y/slic
plugins: allure-pytest-2.13.5, html-4.1.1, metadata-3.1.1, cov-5.0.0, json-report-1.5.0
]0;⊚slic[W 250725 10:48:51 pvpreload:38] PV preload file not loaded due to: FileNotFoundError: [Errno 2] No such file or directory: '/root/.slic/pvpreload'
collected 95 items
tests/test_utils_ask_yes_no.py .............
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
..
.
.
.
.
.
.
tests/test_utils_channels.py .
tests/test_utils_cpint.py ........................
tests/test_utils_debug.py ......F...F
tests/test_utils_dictext.py ...FF.......F......
=================================== FAILURES ===================================
_ test_short_repr[aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa-10-'aaaaaaaaaa...] _
value = 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
cutoff = 10, expected = "'aaaaaaaaaa..."
@pytest.mark.parametrize(
"value, cutoff, expected",
[
("abc", 10, "'abc'"),
("a" * 100, 10, "'aaaaaaaaaa..."),
(12345, 10, "12345"),
([0]*100, 15, str(repr([0]*100))[:15] + "..."),
(None, 10, "None"),
(type("Obj", (), {"__repr__": lambda self: "Obj(" + "x"*50 + ")"})(), 20, "Obj(xxxxxxxxxxxxxxxxx..."),
]
)
def test_short_repr(value, cutoff, expected):
> assert short_repr(value, cutoff) == expected
E assert "'aaaaaaaaa..." == "'aaaaaaaaaa..."
E
E - 'aaaaaaaaaa...
E ? -
E + 'aaaaaaaaa...
tests/test_utils_debug.py:66: AssertionError
_____________ test_short_repr[value5-20-Obj(xxxxxxxxxxxxxxxxx...] ______________
value = Obj(xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx), cutoff = 20
expected = 'Obj(xxxxxxxxxxxxxxxxx...'
@pytest.mark.parametrize(
"value, cutoff, expected",
[
("abc", 10, "'abc'"),
("a" * 100, 10, "'aaaaaaaaaa..."),
(12345, 10, "12345"),
([0]*100, 15, str(repr([0]*100))[:15] + "..."),
(None, 10, "None"),
(type("Obj", (), {"__repr__": lambda self: "Obj(" + "x"*50 + ")"})(), 20, "Obj(xxxxxxxxxxxxxxxxx..."),
]
)
def test_short_repr(value, cutoff, expected):
> assert short_repr(value, cutoff) == expected
E AssertionError: assert 'Obj(xxxxxxxxxxxxxxxx...' == 'Obj(xxxxxxxxxxxxxxxxx...'
E
E - Obj(xxxxxxxxxxxxxxxxx...
E ? -
E + Obj(xxxxxxxxxxxxxxxx...
tests/test_utils_debug.py:66: AssertionError
________________ test_attrdict_getattr[data3-outer.inner-None] _________________
data = {'outer': {'inner': 42}}, attr = 'outer.inner', expected = None
@pytest.mark.parametrize(
"data, attr, expected",
[
({"x": 1, "y": 2}, "x", 1),
({"world": "ok"}, "world", "ok"),
({"outer": {"inner": 42}}, "outer", {"inner": 42}),
({"outer": {"inner": 42}}, "outer.inner", None), # pas converti, pas accessible par point
({"outer": AttrDict({"inner": 42})}, "outer.inner", 42),
]
)
def test_attrdict_getattr(data, attr, expected):
d = MyDict(**data)
> assert getattr(d, attr) == expected
tests/test_utils_dictext.py:27:
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
slic/utils/dictext.py:18: in __getattr__
self._raise_missing_attribute(name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
self = {'outer': {'inner': 42}}, name = 'outer.inner'
def _raise_missing_attribute(self, name):
tn = typename(self)
> raise AttributeError(f"{repr(tn)} object has no attribute {repr(name)}")
E AttributeError: 'MyDict' object has no attribute 'outer.inner'
slic/utils/dictext.py:31: AttributeError
_________________ test_attrdict_getattr[data4-outer.inner-42] __________________
data = {'outer': {'inner': 42}}, attr = 'outer.inner', expected = 42
@pytest.mark.parametrize(
"data, attr, expected",
[
({"x": 1, "y": 2}, "x", 1),
({"world": "ok"}, "world", "ok"),
({"outer": {"inner": 42}}, "outer", {"inner": 42}),
({"outer": {"inner": 42}}, "outer.inner", None), # pas converti, pas accessible par point
({"outer": AttrDict({"inner": 42})}, "outer.inner", 42),
]
)
def test_attrdict_getattr(data, attr, expected):
d = MyDict(**data)
> assert getattr(d, attr) == expected
tests/test_utils_dictext.py:27:
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
slic/utils/dictext.py:18: in __getattr__
self._raise_missing_attribute(name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
self = {'outer': {'inner': 42}}, name = 'outer.inner'
def _raise_missing_attribute(self, name):
tn = typename(self)
> raise AttributeError(f"{repr(tn)} object has no attribute {repr(name)}")
E AttributeError: 'MyDict' object has no attribute 'outer.inner'
slic/utils/dictext.py:31: AttributeError
_ test_attrdict_getattr_and_missing[data1-missing-None-'AttrDict' object has no attribute 'missing'] _
data = {'number': 42}, attr = 'missing', expect_value = None
expect_error = "'AttrDict' object has no attribute 'missing'"
@pytest.mark.parametrize(
"data, attr, expect_value, expect_error",
[
({"x": 1, "y": 2}, "x", 1, None),
({"number": 42}, "missing", None, "'AttrDict' object has no attribute 'missing'"),
]
)
def test_attrdict_getattr_and_missing(data, attr, expect_value, expect_error):
d = MyDict(**data)
if expect_error is None:
assert getattr(d, attr) == expect_value
else:
with pytest.raises(AttributeError) as excinfo:
_ = getattr(d, attr)
> assert str(excinfo.value) == expect_error
E assert "'MyDict' obj...ute 'missing'" == "'AttrDict' o...ute 'missing'"
E
E - 'AttrDict' object has no attribute 'missing'
E ? ^^^^
E + 'MyDict' object has no attribute 'missing'
E ? ^^
tests/test_utils_dictext.py:87: AssertionError
=============================== warnings summary ===============================
.pixi/envs/default/lib/python3.8/site-packages/bsread/h5.py:207
/workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/bsread/h5.py:207: DeprecationWarning: invalid escape sequence \-
if not re.match('^tcp://[a-zA-Z.\-0-9]+:[0-9]+$', address):
.pixi/envs/default/lib/python3.8/site-packages/pyepics-3.4.3-py3.9.egg/epics/ca.py:28
/workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pyepics-3.4.3-py3.9.egg/epics/ca.py:28: DeprecationWarning: pkg_resources is deprecated as an API. See https://setuptools.pypa.io/en/latest/pkg_resources.html
.pixi/envs/default/lib/python3.8/site-packages/pkg_resources/__init__.py:3154
/workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pkg_resources/__init__.py:3154: DeprecationWarning: Deprecated call to `pkg_resources.declare_namespace('mpl_toolkits')`.
Implementing implicit namespace packages (as specified in PEP 420) is preferred to `pkg_resources.declare_namespace`. See https://setuptools.pypa.io/en/latest/references/keywords.html#keyword-namespace-packages
declare_namespace(pkg)
.pixi/envs/default/lib/python3.8/site-packages/scipy/fft/__init__.py:97
/workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/scipy/fft/__init__.py:97: DeprecationWarning: The module numpy.dual is deprecated. Instead of using dual, use the functions directly from numpy or scipy.
from numpy.dual import register_func
-- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html
🧪 Test Report
Generated on 2025-07-25 12:48:54 CEST
🧾 General Info
- duration: 5.819619417190552
- root: /workspace/tligui_y/slic
- environment: {}
📋 Summary
- Passed: 90
- Failed: 5
- Total: 95
- Collected: 95
🔎 Tests
✅ Passed (90)
-
📄 test_utils_ask_yes_no.py
↳ Function: test_ask_yes_no
-
✅ Test 1
📌 Setup phase
duration:
0.0007951022125780582outcome:
passed📌 Call phase
duration:
0.0008352159056812525outcome:
passed📌 Teardown phase
duration:
0.000313265947625041outcome:
passed -
✅ Test 2
📌 Setup phase
duration:
0.000339386984705925outcome:
passed📌 Call phase
duration:
0.0005627158097922802outcome:
passed📌 Teardown phase
duration:
0.00018613087013363838outcome:
passed -
✅ Test 3
📌 Setup phase
duration:
0.0003387080505490303outcome:
passed📌 Call phase
duration:
0.0006826601456850767outcome:
passed📌 Teardown phase
duration:
0.00019274302758276463outcome:
passed -
✅ Test 4
📌 Setup phase
duration:
0.00033179717138409615outcome:
passed📌 Call phase
duration:
0.0005073279608041048outcome:
passed📌 Teardown phase
duration:
0.00019026105292141438outcome:
passed -
✅ Test 5
📌 Setup phase
duration:
0.0003260320518165827outcome:
passed📌 Call phase
duration:
0.000520594883710146outcome:
passed📌 Teardown phase
duration:
0.00018853601068258286outcome:
passed -
✅ Test 6
📌 Setup phase
duration:
0.00032265298068523407outcome:
passed📌 Call phase
duration:
0.0006519211456179619outcome:
passed📌 Teardown phase
duration:
0.00019183708354830742outcome:
passed -
✅ Test 7
📌 Setup phase
duration:
0.00032456801272928715outcome:
passed📌 Call phase
duration:
0.000542165944352746outcome:
passed📌 Teardown phase
duration:
0.0001799080055207014outcome:
passed -
✅ Test 8
📌 Setup phase
duration:
0.00032345415093004704outcome:
passed📌 Call phase
duration:
0.0004926510155200958outcome:
passed📌 Teardown phase
duration:
0.0001911649014800787outcome:
passed -
✅ Test 9
📌 Setup phase
duration:
0.00031755887903273106outcome:
passed📌 Call phase
duration:
0.0005085710436105728outcome:
passed📌 Teardown phase
duration:
0.00017842301167547703outcome:
passed -
✅ Test 10
📌 Setup phase
duration:
0.00031738588586449623outcome:
passed📌 Call phase
duration:
0.000621334882453084outcome:
passed📌 Teardown phase
duration:
0.00017830682918429375outcome:
passed -
✅ Test 11
📌 Setup phase
duration:
0.0003294600173830986outcome:
passed📌 Call phase
duration:
0.0004892109427601099outcome:
passed📌 Teardown phase
duration:
0.00017789914272725582outcome:
passed -
✅ Test 12
📌 Setup phase
duration:
0.0003180350176990032outcome:
passed📌 Call phase
duration:
0.0005069889593869448outcome:
passed📌 Teardown phase
duration:
0.00018682191148400307outcome:
passed -
✅ Test 13
📌 Setup phase
duration:
0.0003210650756955147outcome:
passed📌 Call phase
duration:
0.0005014459602534771outcome:
passed📌 Teardown phase
duration:
0.00020805210806429386outcome:
passed
↳ Function: test_ask_yes_no_ctrl_c
-
✅ Test 14
📌 Setup phase
duration:
0.0003825260791927576outcome:
passed📌 Call phase
duration:
0.000684673897922039outcome:
passed📌 Teardown phase
duration:
0.0002141878940165043outcome:
passed -
✅ Test 15
📌 Setup phase
duration:
0.00035631307400763035outcome:
passed📌 Call phase
duration:
0.0005036140792071819outcome:
passed📌 Teardown phase
duration:
0.00018760794773697853outcome:
passed -
✅ Test 16
📌 Setup phase
duration:
0.00031746295280754566outcome:
passed📌 Call phase
duration:
0.0004900579806417227outcome:
passed📌 Teardown phase
duration:
0.00020121620036661625outcome:
passed -
✅ Test 17
📌 Setup phase
duration:
0.0003209519200026989outcome:
passed📌 Call phase
duration:
0.0005128539633005857outcome:
passed📌 Teardown phase
duration:
0.00019696983508765697outcome:
passed -
✅ Test 18
📌 Setup phase
duration:
0.0003221950028091669outcome:
passed📌 Call phase
duration:
0.000631924020126462outcome:
passed📌 Teardown phase
duration:
0.0001919118221849203outcome:
passed -
✅ Test 19
📌 Setup phase
duration:
0.0003293741028755903outcome:
passed📌 Call phase
duration:
0.0005318347830325365outcome:
passed📌 Teardown phase
duration:
0.00018137809820473194outcome:
passed -
✅ Test 20
📌 Setup phase
duration:
0.00032272282987833023outcome:
passed📌 Call phase
duration:
0.0005343940574675798outcome:
passed📌 Teardown phase
duration:
0.00017896713688969612outcome:
passed -
✅ Test 21
📌 Setup phase
duration:
0.00032119592651724815outcome:
passed📌 Call phase
duration:
0.0006689261645078659outcome:
passed📌 Teardown phase
duration:
0.0001923141535371542outcome:
passed -
✅ Test 22
📌 Setup phase
duration:
0.00031479494646191597outcome:
passed📌 Call phase
duration:
0.000544223003089428outcome:
passed📌 Teardown phase
duration:
0.00018937909044325352outcome:
passed -
✅ Test 23
📌 Setup phase
duration:
0.00032818294130265713outcome:
passed📌 Call phase
duration:
0.000536409905180335outcome:
passed📌 Teardown phase
duration:
0.00018559210002422333outcome:
passed
↳ Function: test_ask_yes_no_ctrl_d
-
✅ Test 24
📌 Setup phase
duration:
0.0003175539895892143outcome:
passed📌 Call phase
duration:
0.0005078129470348358outcome:
passed📌 Teardown phase
duration:
0.00017935712821781635outcome:
passed -
✅ Test 25
📌 Setup phase
duration:
0.00031863898038864136outcome:
passed📌 Call phase
duration:
0.001019081100821495outcome:
passed📌 Teardown phase
duration:
0.00020515103824436665outcome:
passed -
✅ Test 26
📌 Setup phase
duration:
0.00031809601932764053outcome:
passed📌 Call phase
duration:
0.0005270871333777905outcome:
passed📌 Teardown phase
duration:
0.00019880500622093678outcome:
passed -
✅ Test 27
📌 Setup phase
duration:
0.00031906203366816044outcome:
passed📌 Call phase
duration:
0.0005115459207445383outcome:
passed📌 Teardown phase
duration:
0.00018442398868501186outcome:
passed -
✅ Test 28
📌 Setup phase
duration:
0.00032626697793602943outcome:
passed📌 Call phase
duration:
0.0006122931372374296outcome:
passed📌 Teardown phase
duration:
0.00018219882622361183outcome:
passed -
✅ Test 29
📌 Setup phase
duration:
0.00031939009204506874outcome:
passed📌 Call phase
duration:
0.0005074830260127783outcome:
passed📌 Teardown phase
duration:
0.00017608702182769775outcome:
passed -
✅ Test 30
📌 Setup phase
duration:
0.0003391159698367119outcome:
passed📌 Call phase
duration:
0.0005299968179315329outcome:
passed📌 Teardown phase
duration:
0.00017788400873541832outcome:
passed -
✅ Test 31
📌 Setup phase
duration:
0.0003304739948362112outcome:
passed📌 Call phase
duration:
0.000507633900269866outcome:
passed📌 Teardown phase
duration:
0.00018666288815438747outcome:
passed -
✅ Test 32
📌 Setup phase
duration:
0.0003322330303490162outcome:
passed📌 Call phase
duration:
0.0006018779240548611outcome:
passed📌 Teardown phase
duration:
0.0001911770086735487outcome:
passed -
✅ Test 33
📌 Setup phase
duration:
0.00031553301960229874outcome:
passed📌 Call phase
duration:
0.000563301844522357outcome:
passed📌 Teardown phase
duration:
0.00019478192552924156outcome:
passed -
✅ Test 34
📌 Setup phase
duration:
0.00033247401006519794outcome:
passed📌 Call phase
duration:
0.0005172840319573879outcome:
passed📌 Teardown phase
duration:
0.00018184306100010872outcome:
passed -
✅ Test 35
📌 Setup phase
duration:
0.00033040507696568966outcome:
passed📌 Call phase
duration:
0.0005550801288336515outcome:
passed📌 Teardown phase
duration:
0.0003153439611196518outcome:
passed -
✅ Test 36
📌 Setup phase
duration:
0.0003556490410119295outcome:
passed📌 Call phase
duration:
0.0005624738987535238outcome:
passed📌 Teardown phase
duration:
0.00019487994723021984outcome:
passed -
✅ Test 37
📌 Setup phase
duration:
0.0003664819523692131outcome:
passed📌 Call phase
duration:
0.0005297141615301371outcome:
passed📌 Teardown phase
duration:
0.00020621786825358868outcome:
passed
↳ Function: test_ask_yes_no_mixed_sequences
-
✅ Test 38
📌 Setup phase
duration:
0.0003782401327043772outcome:
passed📌 Call phase
duration:
0.0005910200998187065outcome:
passed📌 Teardown phase
duration:
0.00022145290859043598outcome:
passed -
✅ Test 39
📌 Setup phase
duration:
0.0003598388284444809outcome:
passed📌 Call phase
duration:
0.0006589710246771574outcome:
passed📌 Teardown phase
duration:
0.00022995099425315857outcome:
passed -
✅ Test 40
📌 Setup phase
duration:
0.00035703089088201523outcome:
passed📌 Call phase
duration:
0.0005808589048683643outcome:
passed📌 Teardown phase
duration:
0.000230015954002738outcome:
passed
-
-
📄 test_utils_channels.py
↳ Function: test_load_channels_and_channels_class_with_professional_names
-
✅ Test 41
📌 Setup phase
duration:
0.00013704807497560978outcome:
passed📌 Call phase
duration:
0.0011749181430786848outcome:
passed📌 Teardown phase
duration:
0.00012749899178743362outcome:
passed
-
-
📄 test_utils_cpint.py
↳ Function: test_load_color_variants_all_keys_and_types
-
✅ Test 42
📌 Setup phase
duration:
0.0001982199028134346outcome:
passed📌 Call phase
duration:
0.00024277507327497005outcome:
passed📌 Teardown phase
duration:
0.00012795603834092617outcome:
passed -
✅ Test 43
📌 Setup phase
duration:
0.0002386870328336954outcome:
passed📌 Call phase
duration:
0.00016034184955060482outcome:
passed📌 Teardown phase
duration:
0.00012461491860449314outcome:
passed -
✅ Test 44
📌 Setup phase
duration:
0.0002131389919668436outcome:
passed📌 Call phase
duration:
0.00015149894170463085outcome:
passed📌 Teardown phase
duration:
0.0002045340370386839outcome:
passed -
✅ Test 45
📌 Setup phase
duration:
0.0001890980638563633outcome:
passed📌 Call phase
duration:
0.00015518791042268276outcome:
passed📌 Teardown phase
duration:
0.0001409640535712242outcome:
passed -
✅ Test 46
📌 Setup phase
duration:
0.00018377299420535564outcome:
passed📌 Call phase
duration:
0.0001545199193060398outcome:
passed📌 Teardown phase
duration:
0.00014789286069571972outcome:
passed -
✅ Test 47
📌 Setup phase
duration:
0.00017744884826242924outcome:
passed📌 Call phase
duration:
0.00016640289686620235outcome:
passed📌 Teardown phase
duration:
0.00012406008318066597outcome:
passed -
✅ Test 48
📌 Setup phase
duration:
0.00017781415954232216outcome:
passed📌 Call phase
duration:
0.0001922990195453167outcome:
passed📌 Teardown phase
duration:
0.00014226697385311127outcome:
passed -
✅ Test 49
📌 Setup phase
duration:
0.00018110591918230057outcome:
passed📌 Call phase
duration:
0.00015331199392676353outcome:
passed📌 Teardown phase
duration:
0.0001235739327967167outcome:
passed
↳ Function: test_cprint_all_cases_fancy
-
✅ Test 50
📌 Setup phase
duration:
0.0008385730907320976outcome:
passed📌 Call phase
duration:
0.0002985149621963501outcome:
passed📌 Teardown phase
duration:
0.0002606830094009638outcome:
passed -
✅ Test 51
📌 Setup phase
duration:
0.0004706829786300659outcome:
passed📌 Call phase
duration:
0.0002314241137355566outcome:
passed📌 Teardown phase
duration:
0.0002787569537758827outcome:
passed -
✅ Test 52
📌 Setup phase
duration:
0.0004627569578588009outcome:
passed📌 Call phase
duration:
0.00021910411305725574outcome:
passed📌 Teardown phase
duration:
0.0002456789370626211outcome:
passed -
✅ Test 53
📌 Setup phase
duration:
0.00045093195512890816outcome:
passed📌 Call phase
duration:
0.0002132959198206663outcome:
passed📌 Teardown phase
duration:
0.0002473860513418913outcome:
passed -
✅ Test 54
📌 Setup phase
duration:
0.0004714981187134981outcome:
passed📌 Call phase
duration:
0.00021432898938655853outcome:
passed📌 Teardown phase
duration:
0.00024544214829802513outcome:
passed -
✅ Test 55
📌 Setup phase
duration:
0.0004550190642476082outcome:
passed📌 Call phase
duration:
0.0002359040081501007outcome:
passed📌 Teardown phase
duration:
0.0002586080227047205outcome:
passed -
✅ Test 56
📌 Setup phase
duration:
0.00046176998876035213outcome:
passed📌 Call phase
duration:
0.0002186899073421955outcome:
passed📌 Teardown phase
duration:
0.00026231189258396626outcome:
passed -
✅ Test 57
📌 Setup phase
duration:
0.0004501459188759327outcome:
passed📌 Call phase
duration:
0.00021568313241004944outcome:
passed📌 Teardown phase
duration:
0.0002356390468776226outcome:
passed -
✅ Test 58
📌 Setup phase
duration:
0.00046037090942263603outcome:
passed📌 Call phase
duration:
0.00021959096193313599outcome:
passed📌 Teardown phase
duration:
0.0002503800205886364outcome:
passed -
✅ Test 59
📌 Setup phase
duration:
0.00044572283513844013outcome:
passed📌 Call phase
duration:
0.00020952709019184113outcome:
passed📌 Teardown phase
duration:
0.00023596896789968014outcome:
passed -
✅ Test 60
📌 Setup phase
duration:
0.0004514788743108511outcome:
passed📌 Call phase
duration:
0.00021293200552463531outcome:
passed📌 Teardown phase
duration:
0.00023744790814816952outcome:
passed -
✅ Test 61
📌 Setup phase
duration:
0.000428980914875865outcome:
passed📌 Call phase
duration:
0.00021885591559112072outcome:
passed📌 Teardown phase
duration:
0.00024436693638563156outcome:
passed -
✅ Test 62
📌 Setup phase
duration:
0.00044381897896528244outcome:
passed📌 Call phase
duration:
0.0005471790209412575outcome:
passed📌 Teardown phase
duration:
0.0002470070030540228outcome:
passed -
✅ Test 63
📌 Setup phase
duration:
0.00046226195991039276outcome:
passed📌 Call phase
duration:
0.00023415498435497284outcome:
passed📌 Teardown phase
duration:
0.00024037598632276058outcome:
passed -
✅ Test 64
📌 Setup phase
duration:
0.0004506469704210758outcome:
passed📌 Call phase
duration:
0.00023170304484665394outcome:
passed📌 Teardown phase
duration:
0.0002386749256402254outcome:
passed -
✅ Test 65
📌 Setup phase
duration:
0.0004810879472643137outcome:
passed📌 Call phase
duration:
0.0002275428269058466outcome:
passed📌 Teardown phase
duration:
0.00024415296502411366outcome:
passed
-
-
📄 test_utils_debug.py
↳ Function: test_traceable
-
✅ Test 66
📌 Setup phase
duration:
0.000300960848107934outcome:
passed📌 Call phase
duration:
0.0011131421197205782outcome:
passed📌 Teardown phase
duration:
0.00017967401072382927outcome:
passed -
✅ Test 67
📌 Setup phase
duration:
0.0002997650299221277outcome:
passed📌 Call phase
duration:
0.0008800958748906851outcome:
passed📌 Teardown phase
duration:
0.00017532892525196075outcome:
passed -
✅ Test 68
📌 Setup phase
duration:
0.0002830850426107645outcome:
passed📌 Call phase
duration:
0.0009092190302908421outcome:
passed📌 Teardown phase
duration:
0.00018514902330935001outcome:
passed -
✅ Test 69
📌 Setup phase
duration:
0.00028435816057026386outcome:
passed📌 Call phase
duration:
0.0007955720648169518outcome:
passed📌 Teardown phase
duration:
0.00016896706074476242outcome:
passed -
✅ Test 70
📌 Setup phase
duration:
0.00028357189148664474outcome:
passed📌 Call phase
duration:
0.0008820600342005491outcome:
passed📌 Teardown phase
duration:
0.00017620809376239777outcome:
passed
↳ Function: test_short_repr
-
✅ Test 71
📌 Setup phase
duration:
0.00028303288854658604outcome:
passed📌 Call phase
duration:
0.00014106091111898422outcome:
passed📌 Teardown phase
duration:
0.00016441917978227139outcome:
passed -
✅ Test 73
📌 Setup phase
duration:
0.00036796298809349537outcome:
passed📌 Call phase
duration:
0.0001737878192216158outcome:
passed📌 Teardown phase
duration:
0.0001607229933142662outcome:
passed -
✅ Test 74
📌 Setup phase
duration:
0.0002954760566353798outcome:
passed📌 Call phase
duration:
0.00015037809498608112outcome:
passed📌 Teardown phase
duration:
0.00016050692647695541outcome:
passed -
✅ Test 75
📌 Setup phase
duration:
0.00025932304561138153outcome:
passed📌 Call phase
duration:
0.00014710193499922752outcome:
passed📌 Teardown phase
duration:
0.00018084794282913208outcome:
passed
-
-
📄 test_utils_dictext.py
↳ Function: test_attrdict_getattr
-
✅ Test 77
📌 Setup phase
duration:
0.0003262499812990427outcome:
passed📌 Call phase
duration:
0.0001605211291462183outcome:
passed📌 Teardown phase
duration:
0.00017080805264413357outcome:
passed -
✅ Test 78
📌 Setup phase
duration:
0.00027403305284678936outcome:
passed📌 Call phase
duration:
0.00015461002476513386outcome:
passed📌 Teardown phase
duration:
0.00018334202468395233outcome:
passed -
✅ Test 79
📌 Setup phase
duration:
0.0002750351559370756outcome:
passed📌 Call phase
duration:
0.00014401692897081375outcome:
passed📌 Teardown phase
duration:
0.0001602561678737402outcome:
passed
↳ Function: test_attrdict_setattr
-
✅ Test 82
📌 Setup phase
duration:
0.00031034299172461033outcome:
passed📌 Call phase
duration:
0.00016191205941140652outcome:
passed📌 Teardown phase
duration:
0.0001750278752297163outcome:
passed -
✅ Test 83
📌 Setup phase
duration:
0.00028741895221173763outcome:
passed📌 Call phase
duration:
0.0001490139402449131outcome:
passed📌 Teardown phase
duration:
0.00015781098045408726outcome:
passed
↳ Function: test_attrdict_delattr
-
✅ Test 84
📌 Setup phase
duration:
0.00025843316689133644outcome:
passed📌 Call phase
duration:
0.0001902331132441759outcome:
passed📌 Teardown phase
duration:
0.00016262102872133255outcome:
passed -
✅ Test 85
📌 Setup phase
duration:
0.0002718649338930845outcome:
passed📌 Call phase
duration:
0.00017114798538386822outcome:
passed📌 Teardown phase
duration:
0.00015602493658661842outcome:
passed
↳ Function: test_attrdict_dir
-
✅ Test 86
📌 Setup phase
duration:
0.00023358012549579144outcome:
passed📌 Call phase
duration:
0.00016679195687174797outcome:
passed📌 Teardown phase
duration:
0.0001390769612044096outcome:
passed -
✅ Test 87
📌 Setup phase
duration:
0.00021865591406822205outcome:
passed📌 Call phase
duration:
0.00018155807629227638outcome:
passed📌 Teardown phase
duration:
0.00016865413635969162outcome:
passed
↳ Function: test_attrdict_getattr_and_missing
-
✅ Test 88
📌 Setup phase
duration:
0.00031567993573844433outcome:
passed📌 Call phase
duration:
0.00014258106239140034outcome:
passed📌 Teardown phase
duration:
0.00018699979409575462outcome:
passed
↳ Function: test_dictupdatemixin_init_and_update
-
✅ Test 90
📌 Setup phase
duration:
0.00033441116102039814outcome:
passed📌 Call phase
duration:
0.00016329390928149223outcome:
passed📌 Teardown phase
duration:
0.00018748384900391102outcome:
passed -
✅ Test 91
📌 Setup phase
duration:
0.0003205828834325075outcome:
passed📌 Call phase
duration:
0.00016431603580713272outcome:
passed📌 Teardown phase
duration:
0.00018264004029333591outcome:
passed -
✅ Test 92
📌 Setup phase
duration:
0.00034764688462018967outcome:
passed📌 Call phase
duration:
0.0001539471559226513outcome:
passed📌 Teardown phase
duration:
0.00016864994540810585outcome:
passed -
✅ Test 93
📌 Setup phase
duration:
0.0003297349903732538outcome:
passed📌 Call phase
duration:
0.00015659513883292675outcome:
passed📌 Teardown phase
duration:
0.0001706150360405445outcome:
passed -
✅ Test 94
📌 Setup phase
duration:
0.00031962315551936626outcome:
passed📌 Call phase
duration:
0.00014622695744037628outcome:
passed📌 Teardown phase
duration:
0.00016249995678663254outcome:
passed -
✅ Test 95
📌 Setup phase
duration:
0.0003398528788238764outcome:
passed📌 Call phase
duration:
0.0002920120023190975outcome:
passed📌 Teardown phase
duration:
0.00019453605636954308outcome:
passed
-
❌ Failed (5)
-
📄 test_utils_debug.py
↳ Function: test_short_repr
-
❌ Test 72
📌 Setup phase
duration:
0.00027056504040956497outcome:
passed📌 Call phase
duration:
0.000960255041718483outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_debug.py lineno: 66 message: assert "'aaaaaaaaa..." == "'aaaaaaaaaa..." - 'aaaaaaaaaa... ? - + 'aaaaaaaaa...traceback:
- path: tests/test_utils_debug.py lineno: 66 message: AssertionErrorlongrepr:
value = 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa' cutoff = 10, expected = "'aaaaaaaaaa..." @pytest.mark.parametrize( "value, cutoff, expected", [ ("abc", 10, "'abc'"), ("a" * 100, 10, "'aaaaaaaaaa..."), (12345, 10, "12345"), ([0]*100, 15, str(repr([0]*100))[:15] + "..."), (None, 10, "None"), (type("Obj", (), {"__repr__": lambda self: "Obj(" + "x"*50 + ")"})(), 20, "Obj(xxxxxxxxxxxxxxxxx..."), ] ) def test_short_repr(value, cutoff, expected): > assert short_repr(value, cutoff) == expected E assert "'aaaaaaaaa..." == "'aaaaaaaaaa..." E E - 'aaaaaaaaaa... E ? - E + 'aaaaaaaaa... tests/test_utils_debug.py:66: AssertionError📌 Teardown phase
duration:
0.0003439199645072222outcome:
passed -
❌ Test 76
📌 Setup phase
duration:
0.00027322396636009216outcome:
passed📌 Call phase
duration:
0.0006646339315921068outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_debug.py lineno: 66 message: AssertionError: assert 'Obj(xxxxxxxxxxxxxxxx...' == 'Obj(xxxxxxxxxxxxxxxxx...' - Obj(xxxxxxxxxxxxxxxxx... ? - + Obj(xxxxxxxxxxxxxxxx...traceback:
- path: tests/test_utils_debug.py lineno: 66 message: AssertionErrorlongrepr:
value = Obj(xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx), cutoff = 20 expected = 'Obj(xxxxxxxxxxxxxxxxx...' @pytest.mark.parametrize( "value, cutoff, expected", [ ("abc", 10, "'abc'"), ("a" * 100, 10, "'aaaaaaaaaa..."), (12345, 10, "12345"), ([0]*100, 15, str(repr([0]*100))[:15] + "..."), (None, 10, "None"), (type("Obj", (), {"__repr__": lambda self: "Obj(" + "x"*50 + ")"})(), 20, "Obj(xxxxxxxxxxxxxxxxx..."), ] ) def test_short_repr(value, cutoff, expected): > assert short_repr(value, cutoff) == expected E AssertionError: assert 'Obj(xxxxxxxxxxxxxxxx...' == 'Obj(xxxxxxxxxxxxxxxxx...' E E - Obj(xxxxxxxxxxxxxxxxx... E ? - E + Obj(xxxxxxxxxxxxxxxx... tests/test_utils_debug.py:66: AssertionError📌 Teardown phase
duration:
0.000217461958527565outcome:
passed
-
-
📄 test_utils_dictext.py
↳ Function: test_attrdict_getattr
-
❌ Test 80
📌 Setup phase
duration:
0.0002623060718178749outcome:
passed📌 Call phase
duration:
0.00019576307386159897outcome:
failedcrash:
path: /workspace/tligui_y/slic/slic/utils/dictext.py lineno: 31 message: AttributeError: 'MyDict' object has no attribute 'outer.inner'traceback:
- path: tests/test_utils_dictext.py lineno: 27 message: None - path: slic/utils/dictext.py lineno: 18 message: in __getattr__ - path: slic/utils/dictext.py lineno: 31 message: AttributeErrorlongrepr:
data = {'outer': {'inner': 42}}, attr = 'outer.inner', expected = None @pytest.mark.parametrize( "data, attr, expected", [ ({"x": 1, "y": 2}, "x", 1), ({"world": "ok"}, "world", "ok"), ({"outer": {"inner": 42}}, "outer", {"inner": 42}), ({"outer": {"inner": 42}}, "outer.inner", None), # pas converti, pas accessible par point ({"outer": AttrDict({"inner": 42})}, "outer.inner", 42), ] ) def test_attrdict_getattr(data, attr, expected): d = MyDict(**data) > assert getattr(d, attr) == expected tests/test_utils_dictext.py:27: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ slic/utils/dictext.py:18: in __getattr__ self._raise_missing_attribute(name) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = {'outer': {'inner': 42}}, name = 'outer.inner' def _raise_missing_attribute(self, name): tn = typename(self) > raise AttributeError(f"{repr(tn)} object has no attribute {repr(name)}") E AttributeError: 'MyDict' object has no attribute 'outer.inner' slic/utils/dictext.py:31: AttributeError📌 Teardown phase
duration:
0.0002007409930229187outcome:
passed -
❌ Test 81
📌 Setup phase
duration:
0.00028946693055331707outcome:
passed📌 Call phase
duration:
0.0001713661476969719outcome:
failedcrash:
path: /workspace/tligui_y/slic/slic/utils/dictext.py lineno: 31 message: AttributeError: 'MyDict' object has no attribute 'outer.inner'traceback:
- path: tests/test_utils_dictext.py lineno: 27 message: None - path: slic/utils/dictext.py lineno: 18 message: in __getattr__ - path: slic/utils/dictext.py lineno: 31 message: AttributeErrorlongrepr:
data = {'outer': {'inner': 42}}, attr = 'outer.inner', expected = 42 @pytest.mark.parametrize( "data, attr, expected", [ ({"x": 1, "y": 2}, "x", 1), ({"world": "ok"}, "world", "ok"), ({"outer": {"inner": 42}}, "outer", {"inner": 42}), ({"outer": {"inner": 42}}, "outer.inner", None), # pas converti, pas accessible par point ({"outer": AttrDict({"inner": 42})}, "outer.inner", 42), ] ) def test_attrdict_getattr(data, attr, expected): d = MyDict(**data) > assert getattr(d, attr) == expected tests/test_utils_dictext.py:27: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ slic/utils/dictext.py:18: in __getattr__ self._raise_missing_attribute(name) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = {'outer': {'inner': 42}}, name = 'outer.inner' def _raise_missing_attribute(self, name): tn = typename(self) > raise AttributeError(f"{repr(tn)} object has no attribute {repr(name)}") E AttributeError: 'MyDict' object has no attribute 'outer.inner' slic/utils/dictext.py:31: AttributeError📌 Teardown phase
duration:
0.0002035719808191061outcome:
passed
↳ Function: test_attrdict_getattr_and_missing
-
❌ Test 89
📌 Setup phase
duration:
0.00032425811514258385outcome:
passed📌 Call phase
duration:
0.0007367150392383337outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_dictext.py lineno: 87 message: assert "'MyDict' obj...ute 'missing'" == "'AttrDict' o...ute 'missing'" - 'AttrDict' object has no attribute 'missing' ? ^^^^ + 'MyDict' object has no attribute 'missing' ? ^^traceback:
- path: tests/test_utils_dictext.py lineno: 87 message: AssertionErrorlongrepr:
data = {'number': 42}, attr = 'missing', expect_value = None expect_error = "'AttrDict' object has no attribute 'missing'" @pytest.mark.parametrize( "data, attr, expect_value, expect_error", [ ({"x": 1, "y": 2}, "x", 1, None), ({"number": 42}, "missing", None, "'AttrDict' object has no attribute 'missing'"), ] ) def test_attrdict_getattr_and_missing(data, attr, expect_value, expect_error): d = MyDict(**data) if expect_error is None: assert getattr(d, attr) == expect_value else: with pytest.raises(AttributeError) as excinfo: _ = getattr(d, attr) > assert str(excinfo.value) == expect_error E assert "'MyDict' obj...ute 'missing'" == "'AttrDict' o...ute 'missing'" E E - 'AttrDict' object has no attribute 'missing' E ? ^^^^ E + 'MyDict' object has no attribute 'missing' E ? ^^ tests/test_utils_dictext.py:87: AssertionError📌 Teardown phase
duration:
0.00022234697826206684outcome:
passed
-
📚 Collected files
✅ (1 tests)
-
✅
- Outcome:
passed - result:
- nodeid: . type: Dir - Outcome:
✅ ci-reports (13 tests)
-
✅ ci-reports
- Outcome:
passed - result:
- nodeid: ci-reports/allure type: Dir - nodeid: ci-reports/junit type: Dir - nodeid: ci-reports/markdown type: Dir-
✅ ci-reports/allure
- Outcome:
passed - result:
- nodeid: ci-reports/allure/data type: Dir - nodeid: ci-reports/allure/export type: Dir - nodeid: ci-reports/allure/history type: Dir - nodeid: ci-reports/allure/plugin type: Dir - nodeid: ci-reports/allure/widgets type: Dir - Outcome:
-
✅ ci-reports/allure/data
- Outcome:
passed - result:
- nodeid: ci-reports/allure/data/test-cases type: Dir - Outcome:
-
✅ ci-reports/allure/data/test-cases
- Outcome:
passed - result:
[] - Outcome:
-
✅ ci-reports/allure/export
- Outcome:
passed - result:
[] - Outcome:
-
✅ ci-reports/allure/history
- Outcome:
passed - result:
[] - Outcome:
-
✅ ci-reports/allure/plugin
- Outcome:
passed - result:
- nodeid: ci-reports/allure/plugin/behaviors type: Dir - nodeid: ci-reports/allure/plugin/packages type: Dir - nodeid: ci-reports/allure/plugin/screen-diff type: Dir - Outcome:
-
✅ ci-reports/allure/plugin/behaviors
- Outcome:
passed - result:
[] - Outcome:
-
✅ ci-reports/allure/plugin/packages
- Outcome:
passed - result:
[] - Outcome:
-
✅ ci-reports/allure/plugin/screen-diff
- Outcome:
passed - result:
[] - Outcome:
-
✅ ci-reports/allure/widgets
- Outcome:
passed - result:
[] - Outcome:
-
✅ ci-reports/junit
- Outcome:
passed - result:
[] - Outcome:
-
✅ ci-reports/markdown
- Outcome:
passed - result:
[] - Outcome:
- Outcome:
✅ outputs (1 tests)
-
✅ outputs
- Outcome:
passed - result:
[] - Outcome:
✅ slic (30 tests)
-
✅ slic
- Outcome:
passed - result:
- nodeid: slic/core type: Package - nodeid: slic/devices type: Package - nodeid: slic/gui type: Package - nodeid: slic/utils type: Package-
✅ slic/core
- Outcome:
passed - result:
- nodeid: slic/core/acquisition type: Package - nodeid: slic/core/adjustable type: Package - nodeid: slic/core/condition type: Package - nodeid: slic/core/device type: Package - nodeid: slic/core/scanner type: Package - nodeid: slic/core/sensor type: Package - nodeid: slic/core/task type: Package - Outcome:
-
✅ slic/core/acquisition
- Outcome:
passed - result:
- nodeid: slic/core/acquisition/broker type: Package - Outcome:
-
✅ slic/core/acquisition/broker
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/core/adjustable
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/core/condition
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/core/device
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/core/scanner
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/core/sensor
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/core/task
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/devices
- Outcome:
passed - result:
- nodeid: slic/devices/cameras type: Package - nodeid: slic/devices/endstations type: Package - nodeid: slic/devices/general type: Package - nodeid: slic/devices/loptics type: Package - nodeid: slic/devices/timing type: Package - nodeid: slic/devices/xdiagnostics type: Package - nodeid: slic/devices/xoptics type: Package - Outcome:
-
✅ slic/devices/cameras
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/devices/endstations
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/devices/general
- Outcome:
passed - result:
- nodeid: slic/devices/general/detectors type: Package - nodeid: slic/devices/general/unused type: Dir - Outcome:
-
✅ slic/devices/general/detectors
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/devices/general/unused
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/devices/loptics
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/devices/timing
- Outcome:
passed - result:
- nodeid: slic/devices/timing/events type: Package - Outcome:
-
✅ slic/devices/timing/events
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/devices/xdiagnostics
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/devices/xoptics
- Outcome:
passed - result:
- nodeid: slic/devices/xoptics/slits type: Package - nodeid: slic/devices/xoptics/unused type: Dir - Outcome:
-
✅ slic/devices/xoptics/slits
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/devices/xoptics/unused
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/gui
- Outcome:
passed - result:
- nodeid: slic/gui/daqpanels type: Package - nodeid: slic/gui/widgets type: Package - Outcome:
-
✅ slic/gui/daqpanels
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/gui/widgets
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/utils
- Outcome:
passed - result:
- nodeid: slic/utils/ioc type: Package - nodeid: slic/utils/unused type: Dir - Outcome:
-
✅ slic/utils/ioc
- Outcome:
passed - result:
[] - Outcome:
-
✅ slic/utils/unused
- Outcome:
passed - result:
- nodeid: slic/utils/unused/xsim type: Package - Outcome:
-
✅ slic/utils/unused/xsim
- Outcome:
passed - result:
[] - Outcome:
- Outcome:
✅ temp-ci (1 tests)
-
✅ temp-ci
- Outcome:
passed - result:
[] - Outcome:
✅ tests (6 tests)
-
✅ tests
- Outcome:
passed - result:
- nodeid: tests/test_utils_ask_yes_no.py type: Module - nodeid: tests/test_utils_channels.py type: Module - nodeid: tests/test_utils_cpint.py type: Module - nodeid: tests/test_utils_debug.py type: Module - nodeid: tests/test_utils_dictext.py type: Module-
✅ tests/test_utils_ask_yes_no.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no[None-y-True-Question? [y/n] ] type: Function lineno: 8 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no[None-yes-True-Question? [y/n] ] type: Function lineno: 8 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no[None-n-False-Question? [y/n] ] type: Function lineno: 8 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no[None-no-False-Question? [y/n] ] type: Function lineno: 8 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no[None-user_input4-True-Question? [y/n] ] type: Function lineno: 8 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no[None-user_input5-False-Question? [y/n] ] type: Function lineno: 8 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no[None-user_input6-True-Question? [y/n] ] type: Function lineno: 8 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no[y-y-True-Question? [Y/n] ] type: Function lineno: 8 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no[y-n-False-Question? [Y/n] ] type: Function lineno: 8 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no[y--True-Question? [Y/n] ] type: Function lineno: 8 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no[n-y-True-Question? [y/N] ] type: Function lineno: 8 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no[n-n-False-Question? [y/N] ] type: Function lineno: 8 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no[n--False-Question? [y/N] ] type: Function lineno: 8 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_c[None-KeyboardInterrupt-False-n] type: Function lineno: 46 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_c[None-KeyboardInterrupt-True-y] type: Function lineno: 46 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_c[y-KeyboardInterrupt-False-n] type: Function lineno: 46 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_c[y-KeyboardInterrupt-True-y] type: Function lineno: 46 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_c[n-KeyboardInterrupt-False-n] type: Function lineno: 46 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_c[None-user_input5-False-n] type: Function lineno: 46 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_c[None-user_input6-True-y] type: Function lineno: 46 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_c[None-user_input7-False-None] type: Function lineno: 46 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_c[n-user_input8-False-None] type: Function lineno: 46 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_c[n-user_input9-False-Invalid] type: Function lineno: 46 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[None-EOFError-False-n] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[None-EOFError-True-y] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[y-EOFError-True-y] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[n-EOFError-True-y] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[n-EOFError-False-n] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[None-user_input5-True-y] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[None-user_input6-False-n] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[y-EOFError-True-None] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[n-EOFError-False-None] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[None-user_input9-True-None] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[n-user_input10-False-None] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[None-user_input11-True-None] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[None-user_input12-False-n] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_ctrl_d[None-user_input13-True-y] type: Function lineno: 79 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_mixed_sequences[None-invalid-None-user_input0-False] type: Function lineno: 117 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_mixed_sequences[None-None-notananswer-user_input1-True] type: Function lineno: 117 - nodeid: tests/test_utils_ask_yes_no.py::test_ask_yes_no_mixed_sequences[None-n-nop-user_input2-False] type: Function lineno: 117 - Outcome:
-
✅ tests/test_utils_channels.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_channels.py::test_load_channels_and_channels_class_with_professional_names type: Function lineno: 42 - Outcome:
-
✅ tests/test_utils_cpint.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_cpint.py::test_load_color_variants_all_keys_and_types[red] type: Function lineno: 9 - nodeid: tests/test_utils_cpint.py::test_load_color_variants_all_keys_and_types[blue] type: Function lineno: 9 - nodeid: tests/test_utils_cpint.py::test_load_color_variants_all_keys_and_types[yellow] type: Function lineno: 9 - nodeid: tests/test_utils_cpint.py::test_load_color_variants_all_keys_and_types[green] type: Function lineno: 9 - nodeid: tests/test_utils_cpint.py::test_load_color_variants_all_keys_and_types[cyan] type: Function lineno: 9 - nodeid: tests/test_utils_cpint.py::test_load_color_variants_all_keys_and_types[magenta] type: Function lineno: 9 - nodeid: tests/test_utils_cpint.py::test_load_color_variants_all_keys_and_types[white] type: Function lineno: 9 - nodeid: tests/test_utils_cpint.py::test_load_color_variants_all_keys_and_types[black] type: Function lineno: 9 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects0-color_spec0- | -['Fancy', 'list'] | {'a': 7} | None-None] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects1-color_spec1- - -{'k': [1, 2]} - 99 - ['X', ['Y']]-None] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects2-color_spec2- / -[] / {} / End-None] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects3-color_spec3-;-['', [3, 4]];done;0-None] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects4-color_spec4-::-['alpha', None]::['beta', {}]::stop-None] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects5-color_spec5- ... -['deep', ['deeper', ['deepest']]] ... X-None] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects6-color_spec6- // -{'dict': {'nested': [4, 5]}} // [True, False] // 6.28-None] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects7-color_spec7-==-['A', ['B']]==string==C-None] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects8-color_spec8- ++ -['Test', None, []] ++ {'v': 0}-None] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects9-None-;-['no', 'color'];plain-None] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects10-None- | -['simple'] | | 12-None] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects11-None- : -[['very', 'deep']] : {'ok': True}-None] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects12-color_spec12-|-['fail', 'color']|123-ValueError] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects13-color_spec13- * -['error'] * {}-ValueError] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects14-color_spec14-//-['nope']//['bad']-ValueError] type: Function lineno: 24 - nodeid: tests/test_utils_cpint.py::test_cprint_all_cases_fancy[objects15-color_spec15----wrong--base-ValueError] type: Function lineno: 24 - Outcome:
-
✅ tests/test_utils_debug.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_debug.py::test_traceable[A-entry0-creating: A(10, 20)] type: Function lineno: 21 - nodeid: tests/test_utils_debug.py::test_traceable[A-entry1-creating: A(10, 20, e=100)] type: Function lineno: 21 - nodeid: tests/test_utils_debug.py::test_traceable[A-entry2-creating: A('foo', [1, 2, 3], flag=True, data={'x': 9})] type: Function lineno: 21 - nodeid: tests/test_utils_debug.py::test_traceable[A-entry3-creating: A(CustomObj(big), [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], name='test', meta='yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy...)] type: Function lineno: 21 - nodeid: tests/test_utils_debug.py::test_traceable[A-entry4-creating: A('AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA..., [0, 0, 0, 0, 0])] type: Function lineno: 21 - nodeid: tests/test_utils_debug.py::test_short_repr[abc-10-'abc'] type: Function lineno: 52 - nodeid: tests/test_utils_debug.py::test_short_repr[aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa-10-'aaaaaaaaaa...] type: Function lineno: 52 - nodeid: tests/test_utils_debug.py::test_short_repr[12345-10-12345] type: Function lineno: 52 - nodeid: tests/test_utils_debug.py::test_short_repr[value3-15-[0, 0, 0, 0, 0,...] type: Function lineno: 52 - nodeid: tests/test_utils_debug.py::test_short_repr[None-10-None] type: Function lineno: 52 - nodeid: tests/test_utils_debug.py::test_short_repr[value5-20-Obj(xxxxxxxxxxxxxxxxx...] type: Function lineno: 52 - Outcome:
-
✅ tests/test_utils_dictext.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_dictext.py::test_attrdict_getattr[data0-x-1] type: Function lineno: 12 - nodeid: tests/test_utils_dictext.py::test_attrdict_getattr[data1-world-ok] type: Function lineno: 12 - nodeid: tests/test_utils_dictext.py::test_attrdict_getattr[data2-outer-expected2] type: Function lineno: 12 - nodeid: tests/test_utils_dictext.py::test_attrdict_getattr[data3-outer.inner-None] type: Function lineno: 12 - nodeid: tests/test_utils_dictext.py::test_attrdict_getattr[data4-outer.inner-42] type: Function lineno: 12 - nodeid: tests/test_utils_dictext.py::test_attrdict_setattr[initial0-nouveau-123] type: Function lineno: 29 - nodeid: tests/test_utils_dictext.py::test_attrdict_setattr[initial1-b-valeur] type: Function lineno: 29 - nodeid: tests/test_utils_dictext.py::test_attrdict_delattr[initial0-a-expected_keys0] type: Function lineno: 43 - nodeid: tests/test_utils_dictext.py::test_attrdict_delattr[initial1-k-expected_keys1] type: Function lineno: 43 - nodeid: tests/test_utils_dictext.py::test_attrdict_dir[data0-expected_keys0] type: Function lineno: 58 - nodeid: tests/test_utils_dictext.py::test_attrdict_dir[data1-expected_keys1] type: Function lineno: 58 - nodeid: tests/test_utils_dictext.py::test_attrdict_getattr_and_missing[data0-x-1-None] type: Function lineno: 72 - nodeid: tests/test_utils_dictext.py::test_attrdict_getattr_and_missing[data1-missing-None-'AttrDict' object has no attribute 'missing'] type: Function lineno: 72 - nodeid: tests/test_utils_dictext.py::test_dictupdatemixin_init_and_update[init_kwargs0-None-kwargs0-expected0] type: Function lineno: 93 - nodeid: tests/test_utils_dictext.py::test_dictupdatemixin_init_and_update[init_kwargs1-other1-kwargs1-expected1] type: Function lineno: 93 - nodeid: tests/test_utils_dictext.py::test_dictupdatemixin_init_and_update[init_kwargs2-other2-kwargs2-expected2] type: Function lineno: 93 - nodeid: tests/test_utils_dictext.py::test_dictupdatemixin_init_and_update[init_kwargs3-None-kwargs3-expected3] type: Function lineno: 93 - nodeid: tests/test_utils_dictext.py::test_dictupdatemixin_init_and_update[init_kwargs4-other4-kwargs4-expected4] type: Function lineno: 93 - nodeid: tests/test_utils_dictext.py::test_dictupdatemixin_init_and_update[init_kwargs5-other5-kwargs5-expected5] type: Function lineno: 93 - Outcome:
- Outcome:
✅ . (1 tests)
-
✅ .
- Outcome:
passed - result:
- nodeid: ci-reports type: Dir - nodeid: outputs type: Dir - nodeid: slic type: Package - nodeid: temp-ci type: Dir - nodeid: tests type: Dir - Outcome:
⚠️ Warnings
Warnings #1
message: invalid escape sequence \-
category: DeprecationWarning
when: collect
filename: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/bsread/h5.py
lineno: 207
Warnings #2
message: pkg_resources is deprecated as an API. See https://setuptools.pypa.io/en/latest/pkg_resources.html
category: DeprecationWarning
when: collect
filename: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pyepics-3.4.3-py3.9.egg/epics/ca.py
lineno: 28
Warnings #3
message: Deprecated call to `pkg_resources.declare_namespace('mpl_toolkits')`.
Implementing implicit namespace packages (as specified in PEP 420) is preferred to `pkg_resources.declare_namespace`. See https://setuptools.pypa.io/en/latest/references/keywords.html#keyword-namespace-packages
category: DeprecationWarning
when: collect
filename: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pkg_resources/__init__.py
lineno: 3154
Warnings #4
message: The module numpy.dual is deprecated. Instead of using dual, use the functions directly from numpy or scipy.
category: DeprecationWarning
when: collect
filename: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/scipy/fft/__init__.py
lineno: 97