Table of Contents
Test Report
View CI Run 1249 | Commit 0df8fed ✅ 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 0x7f7cf81c3790>._pv
================== 3 failed, 109 passed, 4 warnings in 5.56s ===================
🪵 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, metadata-3.1.1, html-4.1.1, cov-5.0.0, json-report-1.5.0
]0;⊚slic[W 250725 15:37:02 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 0x7f7cf81c3790>._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:37:05 CEST
🧾 General Info
- duration: 5.558727264404297
- 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.0008804372046142817outcome:
passed📌 Call phase
duration:
0.0009047039784491062outcome:
passed📌 Teardown phase
duration:
0.0003550171386450529outcome:
passed -
✅ Test 2
📌 Setup phase
duration:
0.00034646596759557724outcome:
passed📌 Call phase
duration:
0.000754278851673007outcome:
passed📌 Teardown phase
duration:
0.00020674383267760277outcome:
passed -
✅ Test 3
📌 Setup phase
duration:
0.00032227509655058384outcome:
passed📌 Call phase
duration:
0.0005268091335892677outcome:
passed📌 Teardown phase
duration:
0.00018590502440929413outcome:
passed -
✅ Test 4
📌 Setup phase
duration:
0.0003294560592621565outcome:
passed📌 Call phase
duration:
0.0005270079709589481outcome:
passed📌 Teardown phase
duration:
0.00018233503215014935outcome:
passed -
✅ Test 5
📌 Setup phase
duration:
0.00034834607504308224outcome:
passed📌 Call phase
duration:
0.0005207529757171869outcome:
passed📌 Teardown phase
duration:
0.0001920941285789013outcome:
passed -
✅ Test 6
📌 Setup phase
duration:
0.00032084505073726177outcome:
passed📌 Call phase
duration:
0.000624452019110322outcome:
passed📌 Teardown phase
duration:
0.00020078709349036217outcome:
passed -
✅ Test 7
📌 Setup phase
duration:
0.0003176419995725155outcome:
passed📌 Call phase
duration:
0.000552845885977149outcome:
passed📌 Teardown phase
duration:
0.00018440699204802513outcome:
passed -
✅ Test 8
📌 Setup phase
duration:
0.00032302411273121834outcome:
passed📌 Call phase
duration:
0.0005031530745327473outcome:
passed📌 Teardown phase
duration:
0.00018746312707662582outcome:
passed -
✅ Test 9
📌 Setup phase
duration:
0.000330963172018528outcome:
passed📌 Call phase
duration:
0.0004965020343661308outcome:
passed📌 Teardown phase
duration:
0.00018822099082171917outcome:
passed -
✅ Test 10
📌 Setup phase
duration:
0.00031761801801621914outcome:
passed📌 Call phase
duration:
0.0006016900297254324outcome:
passed📌 Teardown phase
duration:
0.00018848897889256477outcome:
passed -
✅ Test 11
📌 Setup phase
duration:
0.0003230918664485216outcome:
passed📌 Call phase
duration:
0.0005102090071886778outcome:
passed📌 Teardown phase
duration:
0.00018004118464887142outcome:
passed -
✅ Test 12
📌 Setup phase
duration:
0.00033399718813598156outcome:
passed📌 Call phase
duration:
0.0004901979118585587outcome:
passed📌 Teardown phase
duration:
0.00018766592256724834outcome:
passed -
✅ Test 13
📌 Setup phase
duration:
0.0003103571943938732outcome:
passed📌 Call phase
duration:
0.0004905378445982933outcome:
passed📌 Teardown phase
duration:
0.00017875502817332745outcome:
passed
↳ Function: test_ask_yes_no_ctrl_c
-
✅ Test 14
📌 Setup phase
duration:
0.00042655901052057743outcome:
passed📌 Call phase
duration:
0.0005177960265427828outcome:
passed📌 Teardown phase
duration:
0.00018186005763709545outcome:
passed -
✅ Test 15
📌 Setup phase
duration:
0.0003297051880508661outcome:
passed📌 Call phase
duration:
0.0005104679148644209outcome:
passed📌 Teardown phase
duration:
0.00018807104788720608outcome:
passed -
✅ Test 16
📌 Setup phase
duration:
0.0003307389561086893outcome:
passed📌 Call phase
duration:
0.0004966729320585728outcome:
passed📌 Teardown phase
duration:
0.0002007521688938141outcome:
passed -
✅ Test 17
📌 Setup phase
duration:
0.0003168650437146425outcome:
passed📌 Call phase
duration:
0.0006134239956736565outcome:
passed📌 Teardown phase
duration:
0.0001832619309425354outcome:
passed -
✅ Test 18
📌 Setup phase
duration:
0.0003146061208099127outcome:
passed📌 Call phase
duration:
0.0005021290853619576outcome:
passed📌 Teardown phase
duration:
0.00018745195120573044outcome:
passed -
✅ Test 19
📌 Setup phase
duration:
0.00033124093897640705outcome:
passed📌 Call phase
duration:
0.0005312000866979361outcome:
passed📌 Teardown phase
duration:
0.0001848749816417694outcome:
passed -
✅ Test 20
📌 Setup phase
duration:
0.0003173290751874447outcome:
passed📌 Call phase
duration:
0.000529431039467454outcome:
passed📌 Teardown phase
duration:
0.00019472511485219002outcome:
passed -
✅ Test 21
📌 Setup phase
duration:
0.0003215479664504528outcome:
passed📌 Call phase
duration:
0.0006734349299222231outcome:
passed📌 Teardown phase
duration:
0.0001891050487756729outcome:
passed -
✅ Test 22
📌 Setup phase
duration:
0.0003344330471009016outcome:
passed📌 Call phase
duration:
0.000543834874406457outcome:
passed📌 Teardown phase
duration:
0.00018917606212198734outcome:
passed -
✅ Test 23
📌 Setup phase
duration:
0.00033241789788007736outcome:
passed📌 Call phase
duration:
0.0005295169539749622outcome:
passed📌 Teardown phase
duration:
0.00018628290854394436outcome:
passed
↳ Function: test_ask_yes_no_ctrl_d
-
✅ Test 24
📌 Setup phase
duration:
0.00034828996285796165outcome:
passed📌 Call phase
duration:
0.0005866559222340584outcome:
passed📌 Teardown phase
duration:
0.00019116303883492947outcome:
passed -
✅ Test 25
📌 Setup phase
duration:
0.0003165118396282196outcome:
passed📌 Call phase
duration:
0.000514480983838439outcome:
passed📌 Teardown phase
duration:
0.00019394699484109879outcome:
passed -
✅ Test 26
📌 Setup phase
duration:
0.00032233307138085365outcome:
passed📌 Call phase
duration:
0.0005109079647809267outcome:
passed📌 Teardown phase
duration:
0.0001870801206678152outcome:
passed -
✅ Test 27
📌 Setup phase
duration:
0.0003296609502285719outcome:
passed📌 Call phase
duration:
0.0004978189244866371outcome:
passed📌 Teardown phase
duration:
0.00018880702555179596outcome:
passed -
✅ Test 28
📌 Setup phase
duration:
0.0003197421319782734outcome:
passed📌 Call phase
duration:
0.0005945279262959957outcome:
passed📌 Teardown phase
duration:
0.0001923050731420517outcome:
passed -
✅ Test 29
📌 Setup phase
duration:
0.0003168440889567137outcome:
passed📌 Call phase
duration:
0.0005125771276652813outcome:
passed📌 Teardown phase
duration:
0.0001786251086741686outcome:
passed -
✅ Test 30
📌 Setup phase
duration:
0.0003195169847458601outcome:
passed📌 Call phase
duration:
0.0005102639552205801outcome:
passed📌 Teardown phase
duration:
0.0001936198677867651outcome:
passed -
✅ Test 31
📌 Setup phase
duration:
0.0003257039934396744outcome:
passed📌 Call phase
duration:
0.000496111111715436outcome:
passed📌 Teardown phase
duration:
0.000198072986677289outcome:
passed -
✅ Test 32
📌 Setup phase
duration:
0.0003216029144823551outcome:
passed📌 Call phase
duration:
0.0006109639070928097outcome:
passed📌 Teardown phase
duration:
0.00018098298460245132outcome:
passed -
✅ Test 33
📌 Setup phase
duration:
0.0003144419752061367outcome:
passed📌 Call phase
duration:
0.0005600969307124615outcome:
passed📌 Teardown phase
duration:
0.00017855502665042877outcome:
passed -
✅ Test 34
📌 Setup phase
duration:
0.00033159879967570305outcome:
passed📌 Call phase
duration:
0.0004944780375808477outcome:
passed📌 Teardown phase
duration:
0.00018072291277348995outcome:
passed -
✅ Test 35
📌 Setup phase
duration:
0.0003189870622009039outcome:
passed📌 Call phase
duration:
0.0006646618712693453outcome:
passed📌 Teardown phase
duration:
0.00022128690034151077outcome:
passed -
✅ Test 36
📌 Setup phase
duration:
0.0003376798704266548outcome:
passed📌 Call phase
duration:
0.01621220796369016outcome:
passed📌 Teardown phase
duration:
0.00021197297610342503outcome:
passed -
✅ Test 37
📌 Setup phase
duration:
0.00035120081156492233outcome:
passed📌 Call phase
duration:
0.0005763540975749493outcome:
passed📌 Teardown phase
duration:
0.00018582399934530258outcome:
passed
↳ Function: test_ask_yes_no_mixed_sequences
-
✅ Test 38
📌 Setup phase
duration:
0.00037093600258231163outcome:
passed📌 Call phase
duration:
0.0005816319026052952outcome:
passed📌 Teardown phase
duration:
0.00020186789333820343outcome:
passed -
✅ Test 39
📌 Setup phase
duration:
0.0009295849595218897outcome:
passed📌 Call phase
duration:
0.0005938620306551456outcome:
passed📌 Teardown phase
duration:
0.00020722812041640282outcome:
passed -
✅ Test 40
📌 Setup phase
duration:
0.000378189142793417outcome:
passed📌 Call phase
duration:
0.0005780139472335577outcome:
passed📌 Teardown phase
duration:
0.00019674701616168022outcome:
passed
-
-
📄 test_utils_channels.py
↳ Function: test_load_channels_and_channels_class_with_professional_names
-
✅ Test 41
📌 Setup phase
duration:
0.00013830279931426048outcome:
passed📌 Call phase
duration:
0.0010120898950845003outcome:
passed📌 Teardown phase
duration:
0.0001176388468593359outcome:
passed
-
-
📄 test_utils_cpint.py
↳ Function: test_load_color_variants_all_keys_and_types
-
✅ Test 42
📌 Setup phase
duration:
0.00021043489687144756outcome:
passed📌 Call phase
duration:
0.00016647321172058582outcome:
passed📌 Teardown phase
duration:
0.0001242698635905981outcome:
passed -
✅ Test 43
📌 Setup phase
duration:
0.0001889381092041731outcome:
passed📌 Call phase
duration:
0.0001611888874322176outcome:
passed📌 Teardown phase
duration:
0.00012658210471272469outcome:
passed -
✅ Test 44
📌 Setup phase
duration:
0.00017465115524828434outcome:
passed📌 Call phase
duration:
0.0001471550203859806outcome:
passed📌 Teardown phase
duration:
0.00011959602124989033outcome:
passed -
✅ Test 45
📌 Setup phase
duration:
0.00017802300862967968outcome:
passed📌 Call phase
duration:
0.00014865491539239883outcome:
passed📌 Teardown phase
duration:
0.00012114387936890125outcome:
passed -
✅ Test 46
📌 Setup phase
duration:
0.0001903160009533167outcome:
passed📌 Call phase
duration:
0.00017359922640025616outcome:
passed📌 Teardown phase
duration:
0.00014693313278257847outcome:
passed -
✅ Test 47
📌 Setup phase
duration:
0.00017822696827352047outcome:
passed📌 Call phase
duration:
0.00015481002628803253outcome:
passed📌 Teardown phase
duration:
0.00012538093142211437outcome:
passed -
✅ Test 48
📌 Setup phase
duration:
0.00017266115173697472outcome:
passed📌 Call phase
duration:
0.00014420785009860992outcome:
passed📌 Teardown phase
duration:
0.00012035504914820194outcome:
passed -
✅ Test 49
📌 Setup phase
duration:
0.00017394614405930042outcome:
passed📌 Call phase
duration:
0.00015169987455010414outcome:
passed📌 Teardown phase
duration:
0.00012216717004776outcome:
passed
↳ Function: test_cprint_all_cases_fancy
-
✅ Test 50
📌 Setup phase
duration:
0.0007771269883960485outcome:
passed📌 Call phase
duration:
0.00025245104916393757outcome:
passed📌 Teardown phase
duration:
0.00027637300081551075outcome:
passed -
✅ Test 51
📌 Setup phase
duration:
0.00046428292989730835outcome:
passed📌 Call phase
duration:
0.00022962503135204315outcome:
passed📌 Teardown phase
duration:
0.0002491849008947611outcome:
passed -
✅ Test 52
📌 Setup phase
duration:
0.00045321392826735973outcome:
passed📌 Call phase
duration:
0.0002147429622709751outcome:
passed📌 Teardown phase
duration:
0.0002469560131430626outcome:
passed -
✅ Test 53
📌 Setup phase
duration:
0.0004656868986785412outcome:
passed📌 Call phase
duration:
0.00021837791427969933outcome:
passed📌 Teardown phase
duration:
0.00024676998145878315outcome:
passed -
✅ Test 54
📌 Setup phase
duration:
0.0004566700663417578outcome:
passed📌 Call phase
duration:
0.0002230301033705473outcome:
passed📌 Teardown phase
duration:
0.00023965002037584782outcome:
passed -
✅ Test 55
📌 Setup phase
duration:
0.0004732420202344656outcome:
passed📌 Call phase
duration:
0.000212221872061491outcome:
passed📌 Teardown phase
duration:
0.00026537198573350906outcome:
passed -
✅ Test 56
📌 Setup phase
duration:
0.0004544269759207964outcome:
passed📌 Call phase
duration:
0.00023030396550893784outcome:
passed📌 Teardown phase
duration:
0.0002516100648790598outcome:
passed -
✅ Test 57
📌 Setup phase
duration:
0.0004740338772535324outcome:
passed📌 Call phase
duration:
0.00021524191834032536outcome:
passed📌 Teardown phase
duration:
0.00025363313034176826outcome:
passed -
✅ Test 58
📌 Setup phase
duration:
0.0004498839844018221outcome:
passed📌 Call phase
duration:
0.00022673304192721844outcome:
passed📌 Teardown phase
duration:
0.000243806978687644outcome:
passed -
✅ Test 59
📌 Setup phase
duration:
0.00045022391714155674outcome:
passed📌 Call phase
duration:
0.0002066700253635645outcome:
passed📌 Teardown phase
duration:
0.00023657595738768578outcome:
passed -
✅ Test 60
📌 Setup phase
duration:
0.00044900085777044296outcome:
passed📌 Call phase
duration:
0.00021547102369368076outcome:
passed📌 Teardown phase
duration:
0.00023758900351822376outcome:
passed -
✅ Test 61
📌 Setup phase
duration:
0.00046056509017944336outcome:
passed📌 Call phase
duration:
0.00020824815146625042outcome:
passed📌 Teardown phase
duration:
0.00024718092754483223outcome:
passed -
✅ Test 62
📌 Setup phase
duration:
0.000466133002191782outcome:
passed📌 Call phase
duration:
0.00043523614294826984outcome:
passed📌 Teardown phase
duration:
0.0002643759362399578outcome:
passed -
✅ Test 63
📌 Setup phase
duration:
0.0004555690102279186outcome:
passed📌 Call phase
duration:
0.00022779498249292374outcome:
passed📌 Teardown phase
duration:
0.00023179803974926472outcome:
passed -
✅ Test 64
📌 Setup phase
duration:
0.0004669218324124813outcome:
passed📌 Call phase
duration:
0.00022760010324418545outcome:
passed📌 Teardown phase
duration:
0.00023912289179861546outcome:
passed -
✅ Test 65
📌 Setup phase
duration:
0.00045577692799270153outcome:
passed📌 Call phase
duration:
0.00022647297009825706outcome:
passed📌 Teardown phase
duration:
0.00023982184939086437outcome:
passed
-
-
📄 test_utils_debug.py
↳ Function: test_traceable
-
✅ Test 66
📌 Setup phase
duration:
0.000289401039481163outcome:
passed📌 Call phase
duration:
0.0008838479407131672outcome:
passed📌 Teardown phase
duration:
0.00018880493007600307outcome:
passed -
✅ Test 67
📌 Setup phase
duration:
0.0002788039855659008outcome:
passed📌 Call phase
duration:
0.0007881189230829477outcome:
passed📌 Teardown phase
duration:
0.00017754803411662579outcome:
passed -
✅ Test 68
📌 Setup phase
duration:
0.0002840289380401373outcome:
passed📌 Call phase
duration:
0.000845425995066762outcome:
passed📌 Teardown phase
duration:
0.00017742998898029327outcome:
passed -
✅ Test 69
📌 Setup phase
duration:
0.0002784258686006069outcome:
passed📌 Call phase
duration:
0.0007792350370436907outcome:
passed📌 Teardown phase
duration:
0.00017474498599767685outcome:
passed -
✅ Test 70
📌 Setup phase
duration:
0.00027717696502804756outcome:
passed📌 Call phase
duration:
0.0008550831116735935outcome:
passed📌 Teardown phase
duration:
0.0001741880550980568outcome:
passed
↳ Function: test_short_repr
-
✅ Test 71
📌 Setup phase
duration:
0.00028413604013621807outcome:
passed📌 Call phase
duration:
0.00014518504031002522outcome:
passed📌 Teardown phase
duration:
0.00016441801562905312outcome:
passed -
✅ Test 73
📌 Setup phase
duration:
0.00032809097319841385outcome:
passed📌 Call phase
duration:
0.0001534761395305395outcome:
passed📌 Teardown phase
duration:
0.00015876302495598793outcome:
passed -
✅ Test 74
📌 Setup phase
duration:
0.000280620064586401outcome:
passed📌 Call phase
duration:
0.00014383206143975258outcome:
passed📌 Teardown phase
duration:
0.00015410594642162323outcome:
passed -
✅ Test 75
📌 Setup phase
duration:
0.0002818671055138111outcome:
passed📌 Call phase
duration:
0.0001397870946675539outcome:
passed📌 Teardown phase
duration:
0.00016086897812783718outcome:
passed
-
-
📄 test_utils_dictext.py
↳ Function: test_attrdict_getattr
-
✅ Test 77
📌 Setup phase
duration:
0.000309930881485343outcome:
passed📌 Call phase
duration:
0.00015489989891648293outcome:
passed📌 Teardown phase
duration:
0.00017408211715519428outcome:
passed -
✅ Test 78
📌 Setup phase
duration:
0.00027010682970285416outcome:
passed📌 Call phase
duration:
0.0001403100322932005outcome:
passed📌 Teardown phase
duration:
0.00014961115084588528outcome:
passed -
✅ Test 79
📌 Setup phase
duration:
0.00026157498359680176outcome:
passed📌 Call phase
duration:
0.00015302607789635658outcome:
passed📌 Teardown phase
duration:
0.00015251897275447845outcome:
passed
↳ Function: test_attrdict_setattr
-
✅ Test 80
📌 Setup phase
duration:
0.0002668709494173527outcome:
passed📌 Call phase
duration:
0.00014034705236554146outcome:
passed📌 Teardown phase
duration:
0.00015363912098109722outcome:
passed -
✅ Test 81
📌 Setup phase
duration:
0.000274264020845294outcome:
passed📌 Call phase
duration:
0.00013651815243065357outcome:
passed📌 Teardown phase
duration:
0.0001554279588162899outcome:
passed
↳ Function: test_attrdict_delattr
-
✅ Test 82
📌 Setup phase
duration:
0.00027385097928345203outcome:
passed📌 Call phase
duration:
0.00017491099424660206outcome:
passed📌 Teardown phase
duration:
0.0001697540283203125outcome:
passed -
✅ Test 83
📌 Setup phase
duration:
0.0002725801896303892outcome:
passed📌 Call phase
duration:
0.00016933097504079342outcome:
passed📌 Teardown phase
duration:
0.0001567280851304531outcome:
passed
↳ Function: test_attrdict_dir
-
✅ Test 84
📌 Setup phase
duration:
0.00021905917674303055outcome:
passed📌 Call phase
duration:
0.00013789907097816467outcome:
passed📌 Teardown phase
duration:
0.00014547398313879967outcome:
passed -
✅ Test 85
📌 Setup phase
duration:
0.00022031809203326702outcome:
passed📌 Call phase
duration:
0.0001745831687003374outcome:
passed📌 Teardown phase
duration:
0.0001354818232357502outcome:
passed
↳ Function: test_attrdict_getattr_and_missing
-
✅ Test 86
📌 Setup phase
duration:
0.000321362866088748outcome:
passed📌 Call phase
duration:
0.00013995100744068623outcome:
passed📌 Teardown phase
duration:
0.00016524014063179493outcome:
passed -
✅ Test 87
📌 Setup phase
duration:
0.0003279079683125019outcome:
passed📌 Call phase
duration:
0.0001653048675507307outcome:
passed📌 Teardown phase
duration:
0.00016864598728716373outcome:
passed
↳ Function: test_dictupdatemixin_init_and_update
-
✅ Test 88
📌 Setup phase
duration:
0.0003069189842790365outcome:
passed📌 Call phase
duration:
0.00014415616169571877outcome:
passed📌 Teardown phase
duration:
0.00017442484386265278outcome:
passed -
✅ Test 89
📌 Setup phase
duration:
0.0003075499553233385outcome:
passed📌 Call phase
duration:
0.00016579986549913883outcome:
passed📌 Teardown phase
duration:
0.00017551705241203308outcome:
passed -
✅ Test 90
📌 Setup phase
duration:
0.0003184000961482525outcome:
passed📌 Call phase
duration:
0.00014654896222054958outcome:
passed📌 Teardown phase
duration:
0.00016227294690907001outcome:
passed -
✅ Test 91
📌 Setup phase
duration:
0.00031004613265395164outcome:
passed📌 Call phase
duration:
0.00014572404325008392outcome:
passed📌 Teardown phase
duration:
0.0001664471346884966outcome:
passed -
✅ Test 92
📌 Setup phase
duration:
0.000307608162984252outcome:
passed📌 Call phase
duration:
0.00014437688514590263outcome:
passed📌 Teardown phase
duration:
0.0001763119362294674outcome:
passed -
✅ Test 93
📌 Setup phase
duration:
0.00030364212580025196outcome:
passed📌 Call phase
duration:
0.0002860280219465494outcome:
passed📌 Teardown phase
duration:
0.00017449003644287586outcome:
passed
-
-
📄 test_utils_dotdir.py
↳ Function: test_dotdir_creation_and_base_exists
-
✅ Test 94
📌 Setup phase
duration:
0.0014116049278527498outcome:
passed📌 Call phase
duration:
0.00025311694480478764outcome:
passed📌 Teardown phase
duration:
0.00023700809106230736outcome:
passed
↳ Function: test_dotdir_repr_returns_path_str
-
✅ Test 95
📌 Setup phase
duration:
0.0006581670604646206outcome:
passed📌 Call phase
duration:
0.00023428210988640785outcome:
passed📌 Teardown phase
duration:
0.000210984842851758outcome:
passed
↳ Function: test_dotdir_call
-
✅ Test 96
📌 Setup phase
duration:
0.0006620860658586025outcome:
passed📌 Call phase
duration:
0.00025269901379942894outcome:
passed📌 Teardown phase
duration:
0.00020743790082633495outcome:
passed
-
-
📄 test_utils_jsonext.py
↳ Function: test_json_validate_save_load
-
✅ Test 97
📌 Setup phase
duration:
0.0005831071175634861outcome:
passed📌 Call phase
duration:
0.00043155206367373466outcome:
passed📌 Teardown phase
duration:
0.0001793508417904377outcome:
passed -
✅ Test 98
📌 Setup phase
duration:
0.0005904620047658682outcome:
passed📌 Call phase
duration:
0.00039199599996209145outcome:
passed📌 Teardown phase
duration:
0.00018430408090353012outcome:
passed -
✅ Test 99
📌 Setup phase
duration:
0.0005968669429421425outcome:
passed📌 Call phase
duration:
0.0004117721691727638outcome:
passed📌 Teardown phase
duration:
0.00017507490701973438outcome:
passed -
✅ Test 100
📌 Setup phase
duration:
0.000587706919759512outcome:
passed📌 Call phase
duration:
0.00035595311783254147outcome:
passed📌 Teardown phase
duration:
0.00017571705393493176outcome:
passed -
✅ Test 101
📌 Setup phase
duration:
0.0005674888379871845outcome:
passed📌 Call phase
duration:
0.0003700200468301773outcome:
passed📌 Teardown phase
duration:
0.00021052313968539238outcome:
passed -
✅ Test 102
📌 Setup phase
duration:
0.0005714870058000088outcome:
passed📌 Call phase
duration:
0.0003953480627387762outcome:
passed📌 Teardown phase
duration:
0.00021270103752613068outcome:
passed -
✅ Test 103
📌 Setup phase
duration:
0.0005900219548493624outcome:
passed📌 Call phase
duration:
0.0004022209905087948outcome:
passed📌 Teardown phase
duration:
0.0001778770238161087outcome:
passed -
✅ Test 104
📌 Setup phase
duration:
0.0006581698544323444outcome:
passed📌 Call phase
duration:
0.0005441280081868172outcome:
passed📌 Teardown phase
duration:
0.00019411486573517323outcome:
passed
-
-
📄 test_utils_picklio.py
↳ Function: test_pickle_and_unpickle
-
✅ Test 106
📌 Setup phase
duration:
0.0011004148982465267outcome:
passed📌 Call phase
duration:
0.00044372305274009705outcome:
passed📌 Teardown phase
duration:
0.00019235187210142612outcome:
passed -
✅ Test 107
📌 Setup phase
duration:
0.0005871180910617113outcome:
passed📌 Call phase
duration:
0.00030989409424364567outcome:
passed📌 Teardown phase
duration:
0.00016871094703674316outcome:
passed -
✅ Test 108
📌 Setup phase
duration:
0.0005717899184674025outcome:
passed📌 Call phase
duration:
0.0003526580985635519outcome:
passed📌 Teardown phase
duration:
0.00015972205437719822outcome:
passed -
✅ Test 109
📌 Setup phase
duration:
0.0005593940149992704outcome:
passed📌 Call phase
duration:
0.00028951000422239304outcome:
passed📌 Teardown phase
duration:
0.0001716199330985546outcome:
passed -
✅ Test 110
📌 Setup phase
duration:
0.0006000979337841272outcome:
passed📌 Call phase
duration:
0.0002829069271683693outcome:
passed📌 Teardown phase
duration:
0.00017205881886184216outcome:
passed -
✅ Test 111
📌 Setup phase
duration:
0.0005535699892789125outcome:
passed📌 Call phase
duration:
0.0002977270632982254outcome:
passed📌 Teardown phase
duration:
0.0001632410567253828outcome:
passed -
✅ Test 112
📌 Setup phase
duration:
0.0005456339567899704outcome:
passed📌 Call phase
duration:
0.00031462893821299076outcome:
passed📌 Teardown phase
duration:
0.000745618948712945outcome:
passed
-
❌ Failed (3)
-
📄 test_utils_debug.py
↳ Function: test_short_repr
-
❌ Test 72
📌 Setup phase
duration:
0.0002630290109664202outcome:
passed📌 Call phase
duration:
0.0008504160214215517outcome:
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.0002570520155131817outcome:
passed -
❌ Test 76
📌 Setup phase
duration:
0.0002614450640976429outcome:
passed📌 Call phase
duration:
0.0005647279322147369outcome:
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.00019965600222349167outcome:
passed
-
-
📄 test_utils_lazypv.py
↳ Function: test_getattr
-
❌ Test 105
📌 Setup phase
duration:
0.00013072299771010876outcome:
passed📌 Call phase
duration:
0.0919754218775779outcome:
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 0x7f7cf81c3790>._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 0x7f7cf81c3790>._pv tests/test_utils_lazypv.py:34: AssertionError📌 Teardown phase
duration:
0.00044195703230798244outcome:
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