Table of Contents
Test Report
View CI Run 1250 | Commit 0a8f456 ✅ 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_lazypv.py::test_getattr - AssertionError: PV is not connected
assert False
+ where False = <PV 'ca://TEST:FLOAT': not connected>.connected
+ where <PV 'ca://TEST:FLOAT': not connected> = <slic.utils.lazypv.PV object at 0x7feb11b894f0>._pv
================== 3 failed, 109 passed, 4 warnings in 5.20s ===================
🪵 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: cov-5.0.0, metadata-3.1.1, allure-pytest-2.13.5, html-4.1.1, json-report-1.5.0
]0;⊚slic[W 250725 15:41:26 pvpreload:38] PV preload file not loaded due to: FileNotFoundError: [Errno 2] No such file or directory: '/root/.slic/pvpreload'
collected 112 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 .................
tests/test_utils_dotdir.py ...
tests/test_utils_jsonext.py ........
tests/test_utils_lazypv.py F
tests/test_utils_picklio.py .......
=================================== 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_getattr _________________________________
def test_getattr():
# Only valid kwargs accepted by epics.PV
pv = PV(
"ca://TEST:FLOAT",
form='time',
auto_monitor=True,
verbose=True,
connection_timeout=3.0
)
# Pv not yet instantiated
assert pv._pv is None
# Trigger instantiation by accessing a real attribute
pvname = pv.__getattr__('pvname')
assert isinstance(pvname, str)
assert pvname == "ca://TEST:FLOAT"
assert pv._pv is not None
> assert pv._pv.connected, "PV is not connected"
E AssertionError: PV is not connected
E assert False
E + where False = <PV 'ca://TEST:FLOAT': not connected>.connected
E + where <PV 'ca://TEST:FLOAT': not connected> = <slic.utils.lazypv.PV object at 0x7feb11b894f0>._pv
tests/test_utils_lazypv.py:34: 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 17:41:29 CEST
🧾 General Info
- duration: 5.200657844543457
- root: /workspace/tligui_y/slic
- environment: {}
📋 Summary
- Passed: 109
- Failed: 3
- Total: 112
- Collected: 112
🔎 Tests
✅ Passed (109)
-
📄 test_utils_ask_yes_no.py
↳ Function: test_ask_yes_no
-
✅ Test 1
📌 Setup phase
duration:
0.000668233959004283outcome:
passed📌 Call phase
duration:
0.0007070610299706459outcome:
passed📌 Teardown phase
duration:
0.0002904590219259262outcome:
passed -
✅ Test 2
📌 Setup phase
duration:
0.00035739410668611526outcome:
passed📌 Call phase
duration:
0.0006786580197513103outcome:
passed📌 Teardown phase
duration:
0.00019070389680564404outcome:
passed -
✅ Test 3
📌 Setup phase
duration:
0.0003311941400170326outcome:
passed📌 Call phase
duration:
0.0004967448767274618outcome:
passed📌 Teardown phase
duration:
0.00018752296455204487outcome:
passed -
✅ Test 4
📌 Setup phase
duration:
0.0003180759958922863outcome:
passed📌 Call phase
duration:
0.0004876831080764532outcome:
passed📌 Teardown phase
duration:
0.00018604984506964684outcome:
passed -
✅ Test 5
📌 Setup phase
duration:
0.0003165749367326498outcome:
passed📌 Call phase
duration:
0.0005236971192061901outcome:
passed📌 Teardown phase
duration:
0.00018720398657023907outcome:
passed -
✅ Test 6
📌 Setup phase
duration:
0.00033189705573022366outcome:
passed📌 Call phase
duration:
0.0006134589202702045outcome:
passed📌 Teardown phase
duration:
0.00018244702368974686outcome:
passed -
✅ Test 7
📌 Setup phase
duration:
0.0003240949008613825outcome:
passed📌 Call phase
duration:
0.0005338189657777548outcome:
passed📌 Teardown phase
duration:
0.00019690091721713543outcome:
passed -
✅ Test 8
📌 Setup phase
duration:
0.0003151758573949337outcome:
passed📌 Call phase
duration:
0.0005015369970351458outcome:
passed📌 Teardown phase
duration:
0.00018224609084427357outcome:
passed -
✅ Test 9
📌 Setup phase
duration:
0.0003152580466121435outcome:
passed📌 Call phase
duration:
0.000510459067299962outcome:
passed📌 Teardown phase
duration:
0.00017988611944019794outcome:
passed -
✅ Test 10
📌 Setup phase
duration:
0.0003265291452407837outcome:
passed📌 Call phase
duration:
0.0005839930381625891outcome:
passed📌 Teardown phase
duration:
0.00018186098895967007outcome:
passed -
✅ Test 11
📌 Setup phase
duration:
0.0003251719754189253outcome:
passed📌 Call phase
duration:
0.0004967991262674332outcome:
passed📌 Teardown phase
duration:
0.00018035201355814934outcome:
passed -
✅ Test 12
📌 Setup phase
duration:
0.00031991791911423206outcome:
passed📌 Call phase
duration:
0.0004948507994413376outcome:
passed📌 Teardown phase
duration:
0.00018146098591387272outcome:
passed -
✅ Test 13
📌 Setup phase
duration:
0.0003236830234527588outcome:
passed📌 Call phase
duration:
0.0004910242278128862outcome:
passed📌 Teardown phase
duration:
0.00019442499615252018outcome:
passed
↳ Function: test_ask_yes_no_ctrl_c
-
✅ Test 14
📌 Setup phase
duration:
0.00042176502756774426outcome:
passed📌 Call phase
duration:
0.000509417150169611outcome:
passed📌 Teardown phase
duration:
0.00018131802789866924outcome:
passed -
✅ Test 15
📌 Setup phase
duration:
0.00030930014327168465outcome:
passed📌 Call phase
duration:
0.0005074460059404373outcome:
passed📌 Teardown phase
duration:
0.00018418999388813972outcome:
passed -
✅ Test 16
📌 Setup phase
duration:
0.00032449886202812195outcome:
passed📌 Call phase
duration:
0.000501084141433239outcome:
passed📌 Teardown phase
duration:
0.00018551410175859928outcome:
passed -
✅ Test 17
📌 Setup phase
duration:
0.00031241285614669323outcome:
passed📌 Call phase
duration:
0.0005985300522297621outcome:
passed📌 Teardown phase
duration:
0.00017785606905817986outcome:
passed -
✅ Test 18
📌 Setup phase
duration:
0.00032548094168305397outcome:
passed📌 Call phase
duration:
0.0005093638319522142outcome:
passed📌 Teardown phase
duration:
0.0001770670060068369outcome:
passed -
✅ Test 19
📌 Setup phase
duration:
0.0003268439322710037outcome:
passed📌 Call phase
duration:
0.0005231271497905254outcome:
passed📌 Teardown phase
duration:
0.00017852894961833954outcome:
passed -
✅ Test 20
📌 Setup phase
duration:
0.00031479005701839924outcome:
passed📌 Call phase
duration:
0.0005271369591355324outcome:
passed📌 Teardown phase
duration:
0.00019999686628580093outcome:
passed -
✅ Test 21
📌 Setup phase
duration:
0.0003131220582872629outcome:
passed📌 Call phase
duration:
0.0006692439783364534outcome:
passed📌 Teardown phase
duration:
0.00018554506823420525outcome:
passed -
✅ Test 22
📌 Setup phase
duration:
0.00031499098986387253outcome:
passed📌 Call phase
duration:
0.0005435880739241838outcome:
passed📌 Teardown phase
duration:
0.0001873169094324112outcome:
passed -
✅ Test 23
📌 Setup phase
duration:
0.0003278120420873165outcome:
passed📌 Call phase
duration:
0.0005256650038063526outcome:
passed📌 Teardown phase
duration:
0.00020991801284253597outcome:
passed
↳ Function: test_ask_yes_no_ctrl_d
-
✅ Test 24
📌 Setup phase
duration:
0.0003212839365005493outcome:
passed📌 Call phase
duration:
0.0005862240213900805outcome:
passed📌 Teardown phase
duration:
0.00019118189811706543outcome:
passed -
✅ Test 25
📌 Setup phase
duration:
0.00030920817516744137outcome:
passed📌 Call phase
duration:
0.000507161021232605outcome:
passed📌 Teardown phase
duration:
0.00018037296831607819outcome:
passed -
✅ Test 26
📌 Setup phase
duration:
0.000312939053401351outcome:
passed📌 Call phase
duration:
0.000499810790643096outcome:
passed📌 Teardown phase
duration:
0.00018082302995026112outcome:
passed -
✅ Test 27
📌 Setup phase
duration:
0.00032139290124177933outcome:
passed📌 Call phase
duration:
0.0005017770454287529outcome:
passed📌 Teardown phase
duration:
0.0001891010906547308outcome:
passed -
✅ Test 28
📌 Setup phase
duration:
0.00030650594271719456outcome:
passed📌 Call phase
duration:
0.0005959589034318924outcome:
passed📌 Teardown phase
duration:
0.00017825490795075893outcome:
passed -
✅ Test 29
📌 Setup phase
duration:
0.0003195670433342457outcome:
passed📌 Call phase
duration:
0.0005107410252094269outcome:
passed📌 Teardown phase
duration:
0.0001784428022801876outcome:
passed -
✅ Test 30
📌 Setup phase
duration:
0.0003244939725846052outcome:
passed📌 Call phase
duration:
0.0005125429015606642outcome:
passed📌 Teardown phase
duration:
0.00019980105571448803outcome:
passed -
✅ Test 31
📌 Setup phase
duration:
0.00032055890187621117outcome:
passed📌 Call phase
duration:
0.0005064199212938547outcome:
passed📌 Teardown phase
duration:
0.0001819299068301916outcome:
passed -
✅ Test 32
📌 Setup phase
duration:
0.0003189330454915762outcome:
passed📌 Call phase
duration:
0.0005976499523967505outcome:
passed📌 Teardown phase
duration:
0.00019334792159497738outcome:
passed -
✅ Test 33
📌 Setup phase
duration:
0.00032058008946478367outcome:
passed📌 Call phase
duration:
0.000538473017513752outcome:
passed📌 Teardown phase
duration:
0.000184760894626379outcome:
passed -
✅ Test 34
📌 Setup phase
duration:
0.000315310200676322outcome:
passed📌 Call phase
duration:
0.0004999309312552214outcome:
passed📌 Teardown phase
duration:
0.00018509593792259693outcome:
passed -
✅ Test 35
📌 Setup phase
duration:
0.0003131488338112831outcome:
passed📌 Call phase
duration:
0.0006393210496753454outcome:
passed📌 Teardown phase
duration:
0.00019416306167840958outcome:
passed -
✅ Test 36
📌 Setup phase
duration:
0.00032236380502581596outcome:
passed📌 Call phase
duration:
0.0005424048285931349outcome:
passed📌 Teardown phase
duration:
0.00018395786173641682outcome:
passed -
✅ Test 37
📌 Setup phase
duration:
0.00032868701964616776outcome:
passed📌 Call phase
duration:
0.00052595604211092outcome:
passed📌 Teardown phase
duration:
0.00018727406859397888outcome:
passed
↳ Function: test_ask_yes_no_mixed_sequences
-
✅ Test 38
📌 Setup phase
duration:
0.00035651098005473614outcome:
passed📌 Call phase
duration:
0.0005738399922847748outcome:
passed📌 Teardown phase
duration:
0.00022020889446139336outcome:
passed -
✅ Test 39
📌 Setup phase
duration:
0.00046401401050388813outcome:
passed📌 Call phase
duration:
0.000553719000890851outcome:
passed📌 Teardown phase
duration:
0.00020552612841129303outcome:
passed -
✅ Test 40
📌 Setup phase
duration:
0.00035757781006395817outcome:
passed📌 Call phase
duration:
0.0005660690367221832outcome:
passed📌 Teardown phase
duration:
0.0002002750989049673outcome:
passed
-
-
📄 test_utils_channels.py
↳ Function: test_load_channels_and_channels_class_with_professional_names
-
✅ Test 41
📌 Setup phase
duration:
0.0001253050286322832outcome:
passed📌 Call phase
duration:
0.0009752491023391485outcome:
passed📌 Teardown phase
duration:
0.00012237299233675003outcome:
passed
-
-
📄 test_utils_cpint.py
↳ Function: test_load_color_variants_all_keys_and_types
-
✅ Test 42
📌 Setup phase
duration:
0.00020503206178545952outcome:
passed📌 Call phase
duration:
0.0001683069858700037outcome:
passed📌 Teardown phase
duration:
0.00018020998686552048outcome:
passed -
✅ Test 43
📌 Setup phase
duration:
0.00018327892757952213outcome:
passed📌 Call phase
duration:
0.00015273992903530598outcome:
passed📌 Teardown phase
duration:
0.00012339209206402302outcome:
passed -
✅ Test 44
📌 Setup phase
duration:
0.00017335312440991402outcome:
passed📌 Call phase
duration:
0.00015103700570762157outcome:
passed📌 Teardown phase
duration:
0.0001266289036720991outcome:
passed -
✅ Test 45
📌 Setup phase
duration:
0.00018176203593611717outcome:
passed📌 Call phase
duration:
0.00014745700173079967outcome:
passed📌 Teardown phase
duration:
0.00011881696991622448outcome:
passed -
✅ Test 46
📌 Setup phase
duration:
0.00017502694390714169outcome:
passed📌 Call phase
duration:
0.00015329592861235142outcome:
passed📌 Teardown phase
duration:
0.0001241371501237154outcome:
passed -
✅ Test 47
📌 Setup phase
duration:
0.00016650301404297352outcome:
passed📌 Call phase
duration:
0.0001419109757989645outcome:
passed📌 Teardown phase
duration:
0.00011838087812066078outcome:
passed -
✅ Test 48
📌 Setup phase
duration:
0.00017462903633713722outcome:
passed📌 Call phase
duration:
0.00015181000344455242outcome:
passed📌 Teardown phase
duration:
0.00012020394206047058outcome:
passed -
✅ Test 49
📌 Setup phase
duration:
0.0001741698943078518outcome:
passed📌 Call phase
duration:
0.00014768308028578758outcome:
passed📌 Teardown phase
duration:
0.00011741905473172665outcome:
passed
↳ Function: test_cprint_all_cases_fancy
-
✅ Test 50
📌 Setup phase
duration:
0.0010838399175554514outcome:
passed📌 Call phase
duration:
0.00027134292759001255outcome:
passed📌 Teardown phase
duration:
0.00026504206471145153outcome:
passed -
✅ Test 51
📌 Setup phase
duration:
0.0004784420598298311outcome:
passed📌 Call phase
duration:
0.00021952809765934944outcome:
passed📌 Teardown phase
duration:
0.00026947888545691967outcome:
passed -
✅ Test 52
📌 Setup phase
duration:
0.00044986698776483536outcome:
passed📌 Call phase
duration:
0.00021194806322455406outcome:
passed📌 Teardown phase
duration:
0.00023811915889382362outcome:
passed -
✅ Test 53
📌 Setup phase
duration:
0.0004642040003091097outcome:
passed📌 Call phase
duration:
0.0002123950980603695outcome:
passed📌 Teardown phase
duration:
0.00023433496244251728outcome:
passed -
✅ Test 54
📌 Setup phase
duration:
0.00044729001820087433outcome:
passed📌 Call phase
duration:
0.00021530594676733017outcome:
passed📌 Teardown phase
duration:
0.000234497943893075outcome:
passed -
✅ Test 55
📌 Setup phase
duration:
0.0004541270900517702outcome:
passed📌 Call phase
duration:
0.00021361606195569038outcome:
passed📌 Teardown phase
duration:
0.00024333689361810684outcome:
passed -
✅ Test 56
📌 Setup phase
duration:
0.00044380687177181244outcome:
passed📌 Call phase
duration:
0.00022330321371555328outcome:
passed📌 Teardown phase
duration:
0.00023846793919801712outcome:
passed -
✅ Test 57
📌 Setup phase
duration:
0.00045568193309009075outcome:
passed📌 Call phase
duration:
0.0002147480845451355outcome:
passed📌 Teardown phase
duration:
0.00023419316858053207outcome:
passed -
✅ Test 58
📌 Setup phase
duration:
0.0004420490004122257outcome:
passed📌 Call phase
duration:
0.00021255481988191605outcome:
passed📌 Teardown phase
duration:
0.00023830309510231018outcome:
passed -
✅ Test 59
📌 Setup phase
duration:
0.00045621907338500023outcome:
passed📌 Call phase
duration:
0.00021163886412978172outcome:
passed📌 Teardown phase
duration:
0.0002349289134144783outcome:
passed -
✅ Test 60
📌 Setup phase
duration:
0.0004592910408973694outcome:
passed📌 Call phase
duration:
0.00021034409292042255outcome:
passed📌 Teardown phase
duration:
0.0002370639704167843outcome:
passed -
✅ Test 61
📌 Setup phase
duration:
0.0004491009749472141outcome:
passed📌 Call phase
duration:
0.00021236296743154526outcome:
passed📌 Teardown phase
duration:
0.00024126702919602394outcome:
passed -
✅ Test 62
📌 Setup phase
duration:
0.0004564509727060795outcome:
passed📌 Call phase
duration:
0.00045131403021514416outcome:
passed📌 Teardown phase
duration:
0.0002551369834691286outcome:
passed -
✅ Test 63
📌 Setup phase
duration:
0.00046691903844475746outcome:
passed📌 Call phase
duration:
0.00023811310529708862outcome:
passed📌 Teardown phase
duration:
0.00024196505546569824outcome:
passed -
✅ Test 64
📌 Setup phase
duration:
0.0004544870462268591outcome:
passed📌 Call phase
duration:
0.00023437384516000748outcome:
passed📌 Teardown phase
duration:
0.0002408251166343689outcome:
passed -
✅ Test 65
📌 Setup phase
duration:
0.0004539010114967823outcome:
passed📌 Call phase
duration:
0.00022668996825814247outcome:
passed📌 Teardown phase
duration:
0.0002505581360310316outcome:
passed
-
-
📄 test_utils_debug.py
↳ Function: test_traceable
-
✅ Test 66
📌 Setup phase
duration:
0.0002833399921655655outcome:
passed📌 Call phase
duration:
0.0009066700004041195outcome:
passed📌 Teardown phase
duration:
0.00017125718295574188outcome:
passed -
✅ Test 67
📌 Setup phase
duration:
0.00027810013853013515outcome:
passed📌 Call phase
duration:
0.0007850457914173603outcome:
passed📌 Teardown phase
duration:
0.00018702400848269463outcome:
passed -
✅ Test 68
📌 Setup phase
duration:
0.00028418400324881077outcome:
passed📌 Call phase
duration:
0.0008478970266878605outcome:
passed📌 Teardown phase
duration:
0.00019077910110354424outcome:
passed -
✅ Test 69
📌 Setup phase
duration:
0.0002809918951243162outcome:
passed📌 Call phase
duration:
0.0007776811253279448outcome:
passed📌 Teardown phase
duration:
0.0001859671901911497outcome:
passed -
✅ Test 70
📌 Setup phase
duration:
0.0002771960571408272outcome:
passed📌 Call phase
duration:
0.0008531820494681597outcome:
passed📌 Teardown phase
duration:
0.0001878710463643074outcome:
passed
↳ Function: test_short_repr
-
✅ Test 71
📌 Setup phase
duration:
0.0002763571683317423outcome:
passed📌 Call phase
duration:
0.00014559505507349968outcome:
passed📌 Teardown phase
duration:
0.00015420583076775074outcome:
passed -
✅ Test 73
📌 Setup phase
duration:
0.000367429805919528outcome:
passed📌 Call phase
duration:
0.0001905329991132021outcome:
passed📌 Teardown phase
duration:
0.00017045298591256142outcome:
passed -
✅ Test 74
📌 Setup phase
duration:
0.00032184505835175514outcome:
passed📌 Call phase
duration:
0.00015816790983080864outcome:
passed📌 Teardown phase
duration:
0.00016108504496514797outcome:
passed -
✅ Test 75
📌 Setup phase
duration:
0.0002679519820958376outcome:
passed📌 Call phase
duration:
0.00014437688514590263outcome:
passed📌 Teardown phase
duration:
0.0001639740075916052outcome:
passed
-
-
📄 test_utils_dictext.py
↳ Function: test_attrdict_getattr
-
✅ Test 77
📌 Setup phase
duration:
0.00030823308043181896outcome:
passed📌 Call phase
duration:
0.00016961293295025826outcome:
passed📌 Teardown phase
duration:
0.00015856209211051464outcome:
passed -
✅ Test 78
📌 Setup phase
duration:
0.00025970302522182465outcome:
passed📌 Call phase
duration:
0.00015554600395262241outcome:
passed📌 Teardown phase
duration:
0.00015412992797791958outcome:
passed -
✅ Test 79
📌 Setup phase
duration:
0.00028817402198910713outcome:
passed📌 Call phase
duration:
0.00015405705198645592outcome:
passed📌 Teardown phase
duration:
0.00016171811148524284outcome:
passed
↳ Function: test_attrdict_setattr
-
✅ Test 80
📌 Setup phase
duration:
0.00027312804013490677outcome:
passed📌 Call phase
duration:
0.00014341715723276138outcome:
passed📌 Teardown phase
duration:
0.00015685311518609524outcome:
passed -
✅ Test 81
📌 Setup phase
duration:
0.00026280106976628304outcome:
passed📌 Call phase
duration:
0.00014079688116908073outcome:
passed📌 Teardown phase
duration:
0.00016569090075790882outcome:
passed
↳ Function: test_attrdict_delattr
-
✅ Test 82
📌 Setup phase
duration:
0.000256973784416914outcome:
passed📌 Call phase
duration:
0.0001912890002131462outcome:
passed📌 Teardown phase
duration:
0.00016160006634891033outcome:
passed -
✅ Test 83
📌 Setup phase
duration:
0.00027435412630438805outcome:
passed📌 Call phase
duration:
0.00018655601888895035outcome:
passed📌 Teardown phase
duration:
0.00016170903109014034outcome:
passed
↳ Function: test_attrdict_dir
-
✅ Test 84
📌 Setup phase
duration:
0.00024794507771730423outcome:
passed📌 Call phase
duration:
0.00014671310782432556outcome:
passed📌 Teardown phase
duration:
0.00019367807544767857outcome:
passed -
✅ Test 85
📌 Setup phase
duration:
0.0002374979667365551outcome:
passed📌 Call phase
duration:
0.00017331703566014767outcome:
passed📌 Teardown phase
duration:
0.00016051391139626503outcome:
passed
↳ Function: test_attrdict_getattr_and_missing
-
✅ Test 86
📌 Setup phase
duration:
0.00030820700339972973outcome:
passed📌 Call phase
duration:
0.00014719204045832157outcome:
passed📌 Teardown phase
duration:
0.00017365510575473309outcome:
passed -
✅ Test 87
📌 Setup phase
duration:
0.00031019188463687897outcome:
passed📌 Call phase
duration:
0.00017256708815693855outcome:
passed📌 Teardown phase
duration:
0.00018484308384358883outcome:
passed
↳ Function: test_dictupdatemixin_init_and_update
-
✅ Test 88
📌 Setup phase
duration:
0.00038177287206053734outcome:
passed📌 Call phase
duration:
0.00016051298007369041outcome:
passed📌 Teardown phase
duration:
0.00018333597108721733outcome:
passed -
✅ Test 89
📌 Setup phase
duration:
0.00030959490686655045outcome:
passed📌 Call phase
duration:
0.0001613639760762453outcome:
passed📌 Teardown phase
duration:
0.00017720717005431652outcome:
passed -
✅ Test 90
📌 Setup phase
duration:
0.0003094819840043783outcome:
passed📌 Call phase
duration:
0.00016301614232361317outcome:
passed📌 Teardown phase
duration:
0.0001630720216780901outcome:
passed -
✅ Test 91
📌 Setup phase
duration:
0.00033225398510694504outcome:
passed📌 Call phase
duration:
0.00014654314145445824outcome:
passed📌 Teardown phase
duration:
0.0001634671352803707outcome:
passed -
✅ Test 92
📌 Setup phase
duration:
0.0003204180393368006outcome:
passed📌 Call phase
duration:
0.0001417549792677164outcome:
passed📌 Teardown phase
duration:
0.00020077591761946678outcome:
passed -
✅ Test 93
📌 Setup phase
duration:
0.0003171509597450495outcome:
passed📌 Call phase
duration:
0.0003147569950670004outcome:
passed📌 Teardown phase
duration:
0.00017396314069628716outcome:
passed
-
-
📄 test_utils_dotdir.py
↳ Function: test_dotdir_creation_and_base_exists
-
✅ Test 94
📌 Setup phase
duration:
0.0016402180772274733outcome:
passed📌 Call phase
duration:
0.0002967182081192732outcome:
passed📌 Teardown phase
duration:
0.00022468087263405323outcome:
passed
↳ Function: test_dotdir_repr_returns_path_str
-
✅ Test 95
📌 Setup phase
duration:
0.0006546699441969395outcome:
passed📌 Call phase
duration:
0.00023371796123683453outcome:
passed📌 Teardown phase
duration:
0.00022169086150825024outcome:
passed
↳ Function: test_dotdir_call
-
✅ Test 96
📌 Setup phase
duration:
0.0006798130925744772outcome:
passed📌 Call phase
duration:
0.0002459711395204067outcome:
passed📌 Teardown phase
duration:
0.00021676486358046532outcome:
passed
-
-
📄 test_utils_jsonext.py
↳ Function: test_json_validate_save_load
-
✅ Test 97
📌 Setup phase
duration:
0.0005712860729545355outcome:
passed📌 Call phase
duration:
0.0004740990698337555outcome:
passed📌 Teardown phase
duration:
0.00018551014363765717outcome:
passed -
✅ Test 98
📌 Setup phase
duration:
0.000792220002040267outcome:
passed📌 Call phase
duration:
0.0003934549167752266outcome:
passed📌 Teardown phase
duration:
0.00018650991842150688outcome:
passed -
✅ Test 99
📌 Setup phase
duration:
0.0006065780762583017outcome:
passed📌 Call phase
duration:
0.00041075306944549084outcome:
passed📌 Teardown phase
duration:
0.00018068100325763226outcome:
passed -
✅ Test 100
📌 Setup phase
duration:
0.0006267360877245665outcome:
passed📌 Call phase
duration:
0.00037282099947333336outcome:
passed📌 Teardown phase
duration:
0.0002321100328117609outcome:
passed -
✅ Test 101
📌 Setup phase
duration:
0.0005907008890062571outcome:
passed📌 Call phase
duration:
0.0003786887973546982outcome:
passed📌 Teardown phase
duration:
0.00018645194359123707outcome:
passed -
✅ Test 102
📌 Setup phase
duration:
0.000589155126363039outcome:
passed📌 Call phase
duration:
0.00040048593655228615outcome:
passed📌 Teardown phase
duration:
0.0002319288905709982outcome:
passed -
✅ Test 103
📌 Setup phase
duration:
0.0006172580178827047outcome:
passed📌 Call phase
duration:
0.00041084899567067623outcome:
passed📌 Teardown phase
duration:
0.00038992613554000854outcome:
passed -
✅ Test 104
📌 Setup phase
duration:
0.0006867139600217342outcome:
passed📌 Call phase
duration:
0.000564774964004755outcome:
passed📌 Teardown phase
duration:
0.00019432604312896729outcome:
passed
-
-
📄 test_utils_picklio.py
↳ Function: test_pickle_and_unpickle
-
✅ Test 106
📌 Setup phase
duration:
0.0013258669059723616outcome:
passed📌 Call phase
duration:
0.0005138160195201635outcome:
passed📌 Teardown phase
duration:
0.00021265004761517048outcome:
passed -
✅ Test 107
📌 Setup phase
duration:
0.0006740621756762266outcome:
passed📌 Call phase
duration:
0.00032420805655419827outcome:
passed📌 Teardown phase
duration:
0.00016218004748225212outcome:
passed -
✅ Test 108
📌 Setup phase
duration:
0.0005647039506584406outcome:
passed📌 Call phase
duration:
0.0003078209701925516outcome:
passed📌 Teardown phase
duration:
0.0001589211169630289outcome:
passed -
✅ Test 109
📌 Setup phase
duration:
0.0006150889676064253outcome:
passed📌 Call phase
duration:
0.0002877952065318823outcome:
passed📌 Teardown phase
duration:
0.00019155791960656643outcome:
passed -
✅ Test 110
📌 Setup phase
duration:
0.0006410209462046623outcome:
passed📌 Call phase
duration:
0.000284567940980196outcome:
passed📌 Teardown phase
duration:
0.0001638699322938919outcome:
passed -
✅ Test 111
📌 Setup phase
duration:
0.0005368650890886784outcome:
passed📌 Call phase
duration:
0.00032970798201859outcome:
passed📌 Teardown phase
duration:
0.00015620095655322075outcome:
passed -
✅ Test 112
📌 Setup phase
duration:
0.0005703628994524479outcome:
passed📌 Call phase
duration:
0.0002919160760939121outcome:
passed📌 Teardown phase
duration:
0.0007244409061968327outcome:
passed
-
❌ Failed (3)
-
📄 test_utils_debug.py
↳ Function: test_short_repr
-
❌ Test 72
📌 Setup phase
duration:
0.0002685920335352421outcome:
passed📌 Call phase
duration:
0.0008549760095775127outcome:
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.0003390300553292036outcome:
passed -
❌ Test 76
📌 Setup phase
duration:
0.00026412494480609894outcome:
passed📌 Call phase
duration:
0.0006271260790526867outcome:
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.0002103589940816164outcome:
passed
-
-
📄 test_utils_lazypv.py
↳ Function: test_getattr
-
❌ Test 105
📌 Setup phase
duration:
0.00013883202336728573outcome:
passed📌 Call phase
duration:
0.09748281398788095outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_lazypv.py lineno: 34 message: AssertionError: PV is not connected assert False + where False = <PV 'ca://TEST:FLOAT': not connected>.connected + where <PV 'ca://TEST:FLOAT': not connected> = <slic.utils.lazypv.PV object at 0x7feb11b894f0>._pvtraceback:
- path: tests/test_utils_lazypv.py lineno: 34 message: AssertionErrorlongrepr:
def test_getattr(): # Only valid kwargs accepted by epics.PV pv = PV( "ca://TEST:FLOAT", form='time', auto_monitor=True, verbose=True, connection_timeout=3.0 ) # Pv not yet instantiated assert pv._pv is None # Trigger instantiation by accessing a real attribute pvname = pv.__getattr__('pvname') assert isinstance(pvname, str) assert pvname == "ca://TEST:FLOAT" assert pv._pv is not None > assert pv._pv.connected, "PV is not connected" E AssertionError: PV is not connected E assert False E + where False = <PV 'ca://TEST:FLOAT': not connected>.connected E + where <PV 'ca://TEST:FLOAT': not connected> = <slic.utils.lazypv.PV object at 0x7feb11b894f0>._pv tests/test_utils_lazypv.py:34: AssertionError📌 Teardown phase
duration:
0.000504491850733757outcome:
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 (10 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 - nodeid: tests/test_utils_dotdir.py type: Module - nodeid: tests/test_utils_jsonext.py type: Module - nodeid: tests/test_utils_lazypv.py type: Module - nodeid: tests/test_utils_picklio.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_setattr[initial0-nouveau-123] type: Function lineno: 26 - nodeid: tests/test_utils_dictext.py::test_attrdict_setattr[initial1-b-valeur] type: Function lineno: 26 - nodeid: tests/test_utils_dictext.py::test_attrdict_delattr[initial0-a-expected_keys0] type: Function lineno: 40 - nodeid: tests/test_utils_dictext.py::test_attrdict_delattr[initial1-k-expected_keys1] type: Function lineno: 40 - nodeid: tests/test_utils_dictext.py::test_attrdict_dir[data0-expected_keys0] type: Function lineno: 55 - nodeid: tests/test_utils_dictext.py::test_attrdict_dir[data1-expected_keys1] type: Function lineno: 55 - nodeid: tests/test_utils_dictext.py::test_attrdict_getattr_and_missing[data0-x-1-None] type: Function lineno: 69 - nodeid: tests/test_utils_dictext.py::test_attrdict_getattr_and_missing[data1-missing-None-'MyDict' object has no attribute 'missing'] type: Function lineno: 69 - nodeid: tests/test_utils_dictext.py::test_dictupdatemixin_init_and_update[init_kwargs0-None-kwargs0-expected0] type: Function lineno: 90 - nodeid: tests/test_utils_dictext.py::test_dictupdatemixin_init_and_update[init_kwargs1-other1-kwargs1-expected1] type: Function lineno: 90 - nodeid: tests/test_utils_dictext.py::test_dictupdatemixin_init_and_update[init_kwargs2-other2-kwargs2-expected2] type: Function lineno: 90 - nodeid: tests/test_utils_dictext.py::test_dictupdatemixin_init_and_update[init_kwargs3-None-kwargs3-expected3] type: Function lineno: 90 - nodeid: tests/test_utils_dictext.py::test_dictupdatemixin_init_and_update[init_kwargs4-other4-kwargs4-expected4] type: Function lineno: 90 - nodeid: tests/test_utils_dictext.py::test_dictupdatemixin_init_and_update[init_kwargs5-other5-kwargs5-expected5] type: Function lineno: 90 - Outcome:
-
✅ tests/test_utils_dotdir.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_dotdir.py::test_dotdir_creation_and_base_exists type: Function lineno: 14 - nodeid: tests/test_utils_dotdir.py::test_dotdir_repr_returns_path_str type: Function lineno: 28 - nodeid: tests/test_utils_dotdir.py::test_dotdir_call type: Function lineno: 35 - Outcome:
-
✅ tests/test_utils_jsonext.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_jsonext.py::test_json_validate_save_load[input_obj0-expected0] type: Function lineno: 7 - nodeid: tests/test_utils_jsonext.py::test_json_validate_save_load[input_obj1-42] type: Function lineno: 7 - nodeid: tests/test_utils_jsonext.py::test_json_validate_save_load[(1-1j)-expected2] type: Function lineno: 7 - nodeid: tests/test_utils_jsonext.py::test_json_validate_save_load[input_obj3-/tmp/file.txt] type: Function lineno: 7 - nodeid: tests/test_utils_jsonext.py::test_json_validate_save_load[input_obj4-expected4] type: Function lineno: 7 - nodeid: tests/test_utils_jsonext.py::test_json_validate_save_load[input_obj5-expected5] type: Function lineno: 7 - nodeid: tests/test_utils_jsonext.py::test_json_validate_save_load[input_obj6-expected6] type: Function lineno: 7 - nodeid: tests/test_utils_jsonext.py::test_json_validate_save_load[input_obj7-expected7] type: Function lineno: 7 - Outcome:
-
✅ tests/test_utils_lazypv.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_lazypv.py::test_getattr type: Function lineno: 14 - Outcome:
-
✅ tests/test_utils_picklio.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_picklio.py::test_pickle_and_unpickle[test_obj0] type: Function lineno: 6 - nodeid: tests/test_utils_picklio.py::test_pickle_and_unpickle[test_obj1] type: Function lineno: 6 - nodeid: tests/test_utils_picklio.py::test_pickle_and_unpickle[simple string] type: Function lineno: 6 - nodeid: tests/test_utils_picklio.py::test_pickle_and_unpickle[42] type: Function lineno: 6 - nodeid: tests/test_utils_picklio.py::test_pickle_and_unpickle[3.14159] type: Function lineno: 6 - nodeid: tests/test_utils_picklio.py::test_pickle_and_unpickle[test_obj5] type: Function lineno: 6 - nodeid: tests/test_utils_picklio.py::test_pickle_and_unpickle[test_obj6] type: Function lineno: 6 - 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