Table of Contents
Test Report
View CI Run 1806 | Commit a5b47eb
🧪 Test Report
Generated on 2025-08-07 13:15:27 CEST
🧾 General Info
- duration: 13.403074979782104
- root: /workspace/tligui_y/slic
- environment: {}
📋 Summary
- Passed: 476
- Failed: 34
- Total: 510
- Collected: 510
🔎 Tests
✅ Passed (476)
-
📄 morbidissimo/morbidissimo/morioc/test_infer_type.py
↳ Function: test_it_type_str
-
✅ Test 1
📌 Setup phase
duration:
0.0007476932369172573outcome:
passed📌 Call phase
duration:
0.0002462100237607956outcome:
passed📌 Teardown phase
duration:
0.0002132677473127842outcome:
passed
↳ Function: test_it_type_float
-
✅ Test 2
📌 Setup phase
duration:
0.00012379512190818787outcome:
passed📌 Call phase
duration:
0.00014830892905592918outcome:
passed📌 Teardown phase
duration:
0.00010225176811218262outcome:
passed
↳ Function: test_it_type_int
-
✅ Test 3
📌 Setup phase
duration:
0.00012682005763053894outcome:
passed📌 Call phase
duration:
0.0001504039391875267outcome:
passed📌 Teardown phase
duration:
0.0001023528166115284outcome:
passed
↳ Function: test_it_value_str
-
✅ Test 4
📌 Setup phase
duration:
0.00010829884558916092outcome:
passed📌 Call phase
duration:
0.0001499168574810028outcome:
passed📌 Teardown phase
duration:
0.00010438868775963783outcome:
passed
↳ Function: test_it_value_long_str
-
✅ Test 5
📌 Setup phase
duration:
0.00011653173714876175outcome:
passed📌 Call phase
duration:
0.00014151586219668388outcome:
passed📌 Teardown phase
duration:
9.9940225481987e-05outcome:
passed
↳ Function: test_it_value_float
-
✅ Test 6
📌 Setup phase
duration:
0.00010762596502900124outcome:
passed📌 Call phase
duration:
0.00015825266018509865outcome:
passed📌 Teardown phase
duration:
9.861728176474571e-05outcome:
passed
↳ Function: test_it_value_int
-
✅ Test 7
📌 Setup phase
duration:
0.00011158175766468048outcome:
passed📌 Call phase
duration:
0.00015616882592439651outcome:
passed📌 Teardown phase
duration:
0.00012020301073789597outcome:
passed
↳ Function: test_it_empty_value_str
-
✅ Test 8
📌 Setup phase
duration:
0.00010712305083870888outcome:
passed📌 Call phase
duration:
0.00013300124555826187outcome:
passed📌 Teardown phase
duration:
0.00011066626757383347outcome:
passed
↳ Function: test_it_empty_value_float
-
✅ Test 9
📌 Setup phase
duration:
0.00010834401473402977outcome:
passed📌 Call phase
duration:
0.00014277594164013863outcome:
passed📌 Teardown phase
duration:
9.840400889515877e-05outcome:
passed
↳ Function: test_it_empty_value_int
-
✅ Test 10
📌 Setup phase
duration:
0.0001056077890098095outcome:
passed📌 Call phase
duration:
0.00013765040785074234outcome:
passed📌 Teardown phase
duration:
9.938888251781464e-05outcome:
passed
↳ Function: test_pstrue_str
-
✅ Test 11
📌 Setup phase
duration:
0.0001076236367225647outcome:
passed📌 Call phase
duration:
0.00013933610171079636outcome:
passed📌 Teardown phase
duration:
0.0001039113849401474outcome:
passed
↳ Function: test_pstrue_float
-
✅ Test 12
📌 Setup phase
duration:
0.00011507607996463776outcome:
passed📌 Call phase
duration:
0.0001327567733824253outcome:
passed📌 Teardown phase
duration:
9.402120485901833e-05outcome:
passed
↳ Function: test_pstrue_int
-
✅ Test 13
📌 Setup phase
duration:
0.00010826904326677322outcome:
passed📌 Call phase
duration:
0.0001378110609948635outcome:
passed📌 Teardown phase
duration:
9.809713810682297e-05outcome:
passed
↳ Function: test_psfalse_str
-
✅ Test 14
📌 Setup phase
duration:
0.00010477332398295403outcome:
passed📌 Call phase
duration:
0.00014258502051234245outcome:
passed📌 Teardown phase
duration:
9.974418208003044e-05outcome:
passed
↳ Function: test_psfalse_float
-
✅ Test 15
📌 Setup phase
duration:
0.00010780291631817818outcome:
passed📌 Call phase
duration:
0.00013718195259571075outcome:
passed📌 Teardown phase
duration:
9.844917804002762e-05outcome:
passed
↳ Function: test_psfalse_int
-
✅ Test 16
📌 Setup phase
duration:
0.00010457122698426247outcome:
passed📌 Call phase
duration:
0.0001353789120912552outcome:
passed📌 Teardown phase
duration:
9.872578084468842e-05outcome:
passed
↳ Function: test_it_None
-
✅ Test 17
📌 Setup phase
duration:
0.00010548392310738564outcome:
passed📌 Call phase
duration:
0.00016375305131077766outcome:
passed📌 Teardown phase
duration:
0.00010930979624390602outcome:
passed
↳ Function: test_it_True
-
✅ Test 18
📌 Setup phase
duration:
0.00011288793757557869outcome:
passed📌 Call phase
duration:
0.0001377142034471035outcome:
passed📌 Teardown phase
duration:
9.750388562679291e-05outcome:
passed
↳ Function: test_it_False
-
✅ Test 19
📌 Setup phase
duration:
0.00010616891086101532outcome:
passed📌 Call phase
duration:
0.00037126336246728897outcome:
passed📌 Teardown phase
duration:
0.0001210290938615799outcome:
passed
↳ Function: test_it_nan
-
✅ Test 20
📌 Setup phase
duration:
0.0001293262466788292outcome:
passed📌 Call phase
duration:
0.00014451565220952034outcome:
passed📌 Teardown phase
duration:
0.0001066010445356369outcome:
passed
↳ Function: test_it_np_nan
-
✅ Test 21
📌 Setup phase
duration:
0.0001165708526968956outcome:
passed📌 Call phase
duration:
0.00014247512444853783outcome:
passed📌 Teardown phase
duration:
0.00010044407099485397outcome:
passed
↳ Function: test_it_np1D_int
-
✅ Test 22
📌 Setup phase
duration:
0.00010667229071259499outcome:
passed📌 Call phase
duration:
0.0002146693877875805outcome:
passed📌 Teardown phase
duration:
0.00010193511843681335outcome:
passed
↳ Function: test_it_np2D_int
-
✅ Test 23
📌 Setup phase
duration:
0.0001058969646692276outcome:
passed📌 Call phase
duration:
0.00018518883734941483outcome:
passed📌 Teardown phase
duration:
0.00011525396257638931outcome:
passed
↳ Function: test_it_np1D_float
-
✅ Test 24
📌 Setup phase
duration:
0.00010881712660193443outcome:
passed📌 Call phase
duration:
0.00024399906396865845outcome:
passed📌 Teardown phase
duration:
0.00011131307110190392outcome:
passed
↳ Function: test_it_np2D_float
-
✅ Test 25
📌 Setup phase
duration:
0.00011684093624353409outcome:
passed📌 Call phase
duration:
0.00020804209634661674outcome:
passed📌 Teardown phase
duration:
0.00010257167741656303outcome:
passed
↳ Function: test_it_np1D_bool
-
✅ Test 26
📌 Setup phase
duration:
0.00011954596266150475outcome:
passed📌 Call phase
duration:
0.00016996311023831367outcome:
passed📌 Teardown phase
duration:
0.00010338937863707542outcome:
passed
↳ Function: test_it_np1D_object
-
✅ Test 27
📌 Setup phase
duration:
0.00010940991342067719outcome:
passed📌 Call phase
duration:
0.0001513897441327572outcome:
passed📌 Teardown phase
duration:
0.00010893493890762329outcome:
passed
↳ Function: test_it_np_scalar_int
-
✅ Test 28
📌 Setup phase
duration:
0.00011073984205722809outcome:
passed📌 Call phase
duration:
0.0001750909723341465outcome:
passed📌 Teardown phase
duration:
0.00010932888835668564outcome:
passed
↳ Function: test_it_np_scalar_float
-
✅ Test 29
📌 Setup phase
duration:
0.00010587507858872414outcome:
passed📌 Call phase
duration:
0.00016874494031071663outcome:
passed📌 Teardown phase
duration:
9.764730930328369e-05outcome:
passed
↳ Function: test_it_np_scalar_bool
-
✅ Test 30
📌 Setup phase
duration:
0.00011218385770916939outcome:
passed📌 Call phase
duration:
0.00017327815294265747outcome:
passed📌 Teardown phase
duration:
9.943591430783272e-05outcome:
passed
↳ Function: test_it_list
-
✅ Test 31
📌 Setup phase
duration:
0.0001050001010298729outcome:
passed📌 Call phase
duration:
0.00014283042401075363outcome:
passed📌 Teardown phase
duration:
0.00010290229693055153outcome:
passed
↳ Function: test_it_tuple
-
✅ Test 32
📌 Setup phase
duration:
0.00011433707550168037outcome:
passed📌 Call phase
duration:
0.0001488281413912773outcome:
passed📌 Teardown phase
duration:
0.00010634306818246841outcome:
passed
-
-
📄 test_utils_argfwd.py
↳ Function: test_split_at
-
✅ Test 33
params: lst=["a", "b", "c", "d"], index=2, expected="a", "b"], ["c", "d"📌 Runtime Parameters
params: lst: - a - b - c - d index: 2 expected: - - a - b - - c - d id: lst0-2-expected0📌 Setup phase
duration:
0.000460037961602211outcome:
passed📌 Call phase
duration:
0.00016444874927401543outcome:
passed📌 Teardown phase
duration:
0.0001782858744263649outcome:
passed -
✅ Test 34
params: lst=["x", "y"], index=1, expected="x"], ["y"📌 Runtime Parameters
params: lst: - x - y index: 1 expected: - - x - - y id: lst1-1-expected1📌 Setup phase
duration:
0.0002879481762647629outcome:
passed📌 Call phase
duration:
0.00015218090265989304outcome:
passed📌 Teardown phase
duration:
0.00016402779147028923outcome:
passed -
✅ Test 35
params: lst=[], index=0, expected=], [📌 Runtime Parameters
params: lst: [] index: 0 expected: - (vide) - (vide) id: lst2-0-expected2📌 Setup phase
duration:
0.0002801748923957348outcome:
passed📌 Call phase
duration:
0.00013718381524085999outcome:
passed📌 Teardown phase
duration:
0.0001546875573694706outcome:
passed
↳ Function: test_merge_lists_unique
-
✅ Test 36
params: a=["a", "b"], b=["b", "c"], expected=["a", "b", "c"]📌 Runtime Parameters
params: a: - a - b b: - b - c expected: - a - b - c id: a0-b0-expected0📌 Setup phase
duration:
0.00028074486181139946outcome:
passed📌 Call phase
duration:
0.00014017010107636452outcome:
passed📌 Teardown phase
duration:
0.00014908192679286003outcome:
passed -
✅ Test 37
params: a=[], b=["x"], expected=["x"]📌 Runtime Parameters
params: a: [] b: - x expected: - x id: a1-b1-expected1📌 Setup phase
duration:
0.0002640369348227978outcome:
passed📌 Call phase
duration:
0.00014212168753147125outcome:
passed📌 Teardown phase
duration:
0.00017128372564911842outcome:
passed -
✅ Test 38
params: a=["x", "y"], b=["x", "y"], expected=["x", "y"]📌 Runtime Parameters
params: a: - x - y b: - x - y expected: - x - y id: a2-b2-expected2📌 Setup phase
duration:
0.000260740052908659outcome:
passed📌 Call phase
duration:
0.00013448484241962433outcome:
passed📌 Teardown phase
duration:
0.00014960626140236855outcome:
passed
↳ Function: test_merge_dicts_unique
-
✅ Test 39
params: a={"a": 1}, b={"b": 2}, expected={"a": 1, "b": 2}📌 Runtime Parameters
params: a: a: 1 b: b: 2 expected: a: 1 b: 2 id: a0-b0-expected0📌 Setup phase
duration:
0.0002724672667682171outcome:
passed📌 Call phase
duration:
0.00016609393060207367outcome:
passed📌 Teardown phase
duration:
0.00015440722927451134outcome:
passed -
✅ Test 40
params: a={"x": 1}, b={"x": 9, "y": 3}, expected={"x": 1, "y": 3}📌 Runtime Parameters
params: a: x: 1 b: x: 9 y: 3 expected: x: 1 y: 3 id: a1-b1-expected1📌 Setup phase
duration:
0.0008003287948668003outcome:
passed📌 Call phase
duration:
0.0001735258847475052outcome:
passed📌 Teardown phase
duration:
0.00016524316743016243outcome:
passed -
✅ Test 41
params: a={}, b={"k": 4}, expected={"k": 4}📌 Runtime Parameters
params: a: {} b: k: 4 expected: k: 4 id: a2-b2-expected2📌 Setup phase
duration:
0.0002909651957452297outcome:
passed📌 Call phase
duration:
0.00015824474394321442outcome:
passed📌 Teardown phase
duration:
0.00016382243484258652outcome:
passed
↳ Function: test_make_params_pos_basic
-
✅ Test 42
params: pos=["a", "b"], expected_names=["a", "b"]📌 Runtime Parameters
params: pos: - a - b expected_names: - a - b id: pos0-expected_names0📌 Setup phase
duration:
0.00022331997752189636outcome:
passed📌 Call phase
duration:
0.00018162094056606293outcome:
passed📌 Teardown phase
duration:
0.00014722999185323715outcome:
passed -
✅ Test 43
params: pos=["param1", "value_2", "Z"], expected_names=["param1", "value_2", "Z"]📌 Runtime Parameters
params: pos: - param1 - value_2 - Z expected_names: - param1 - value_2 - Z id: pos1-expected_names1📌 Setup phase
duration:
0.0002371431328356266outcome:
passed📌 Call phase
duration:
0.00016969488933682442outcome:
passed📌 Teardown phase
duration:
0.00015120068565011024outcome:
passed -
✅ Test 44
params: pos=[], expected_names=[]📌 Runtime Parameters
params: pos: [] expected_names: [] id: pos2-expected_names2📌 Setup phase
duration:
0.0002280939370393753outcome:
passed📌 Call phase
duration:
0.00015507405623793602outcome:
passed📌 Teardown phase
duration:
0.00014017894864082336outcome:
passed
↳ Function: test_make_params_kw_basic
-
✅ Test 45
params: kw={"a": 1, "b": 2}, expected_keys=["a", "b"], expected_defaults=[1, 2]📌 Runtime Parameters
params: kw: a: 1 b: 2 expected_keys: - a - b expected_defaults: - 1 - 2 id: kw0-expected_keys0-expected_defaults0📌 Setup phase
duration:
0.00028243381530046463outcome:
passed📌 Call phase
duration:
0.00017268769443035126outcome:
passed📌 Teardown phase
duration:
0.00016007199883460999outcome:
passed -
✅ Test 46
params: kw={"param_x": 0}, expected_keys=["param_x"], expected_defaults=[0]📌 Runtime Parameters
params: kw: param_x: 0 expected_keys: - param_x expected_defaults: - (vide) id: kw1-expected_keys1-expected_defaults1📌 Setup phase
duration:
0.00026667118072509766outcome:
passed📌 Call phase
duration:
0.00017526932060718536outcome:
passed📌 Teardown phase
duration:
0.0001552230678498745outcome:
passed -
✅ Test 47
params: kw={}, expected_keys=[], expected_defaults=[]📌 Runtime Parameters
params: kw: {} expected_keys: [] expected_defaults: [] id: kw2-expected_keys2-expected_defaults2📌 Setup phase
duration:
0.00027061719447374344outcome:
passed📌 Call phase
duration:
0.00015263492241501808outcome:
passed📌 Teardown phase
duration:
0.00015148194506764412outcome:
passed
↳ Function: test_make_signature_parametrized
-
✅ Test 48
params: pos=["x", "y"], kw={"z": 3}, expected_signature="(x, y, z=3)"📌 Runtime Parameters
params: pos: - x - y kw: z: 3 expected_signature: (x, y, z=3) id: pos0-kw0-(x, y, z=3)📌 Setup phase
duration:
0.00027097295969724655outcome:
passed📌 Call phase
duration:
0.0001977989450097084outcome:
passed📌 Teardown phase
duration:
0.00015542702749371529outcome:
passed -
✅ Test 49
params: pos=["a"], kw={"b": 1, "c": 2}, expected_signature="(a, b=1, c=2)"📌 Runtime Parameters
params: pos: - a kw: b: 1 c: 2 expected_signature: (a, b=1, c=2) id: pos1-kw1-(a, b=1, c=2)📌 Setup phase
duration:
0.00027257297188043594outcome:
passed📌 Call phase
duration:
0.00018502399325370789outcome:
passed📌 Teardown phase
duration:
0.0001660119742155075outcome:
passed -
✅ Test 50
params: pos=[], kw={"flag": false}, expected_signature="(flag=False)"📌 Runtime Parameters
params: pos: [] kw: flag: False expected_signature: (flag=False) id: pos2-kw2-(flag=False)📌 Setup phase
duration:
0.00027551501989364624outcome:
passed📌 Call phase
duration:
0.00016551418229937553outcome:
passed📌 Teardown phase
duration:
0.00016719987615942955outcome:
passed
↳ Function: test_get_args_parametrized
-
✅ Test 51
params: func=" at 0x7f0d7d29e5e0>", expected_pos=["a", "b"], expected_kw={"c": 3, "d": 4}📌 Runtime Parameters
params: func: <function <lambda> at 0x7f0d7d29e5e0> expected_pos: - a - b expected_kw: c: 3 d: 4 id: <lambda>-expected_pos0-expected_kw0📌 Setup phase
duration:
0.00027353083714842796outcome:
passed📌 Call phase
duration:
0.00022667599841952324outcome:
passed📌 Teardown phase
duration:
0.0001585450954735279outcome:
passed -
✅ Test 52
params: func=" at 0x7f0d7d2b2550>", expected_pos=[], expected_kw="{'x': 1, 'y': , 'z': 0}"📌 Runtime Parameters
params: func: <function <lambda> at 0x7f0d7d2b2550> expected_pos: [] expected_kw: {'x': 1, 'y': <class 'inspect._empty'>, 'z': 0} id: <lambda>-expected_pos1-expected_kw1📌 Setup phase
duration:
0.00028394022956490517outcome:
passed📌 Call phase
duration:
0.00019863201305270195outcome:
passed📌 Teardown phase
duration:
0.00018355203792452812outcome:
passed -
✅ Test 53
params: func=" at 0x7f0d7d2b2670>", expected_pos=[], expected_kw={}📌 Runtime Parameters
params: func: <function <lambda> at 0x7f0d7d2b2670> expected_pos: [] expected_kw: {} id: <lambda>-expected_pos2-expected_kw2📌 Setup phase
duration:
0.00030581606552004814outcome:
passed📌 Call phase
duration:
0.00019971001893281937outcome:
passed📌 Teardown phase
duration:
0.00018162885680794716outcome:
passed
↳ Function: test_signature_visible
-
✅ Test 54
params: func="", expected_sig="(a, b, d=30, c=10)"📌 Runtime Parameters
params: func: <function wrap_all at 0x7f0d7d2b28b0> expected_sig: (a, b, d=30, c=10) id: wrap_all-(a, b, d=30, c=10)📌 Setup phase
duration:
0.0002585449256002903outcome:
passed📌 Call phase
duration:
0.00019032461568713188outcome:
passed📌 Teardown phase
duration:
0.0001559699885547161outcome:
passed -
✅ Test 55
params: func="", expected_sig="(a, b, c=10, d=20)"📌 Runtime Parameters
params: func: <function wrap_skip at 0x7f0d7d2b2940> expected_sig: (a, b, c=10, d=20) id: wrap_skip-(a, b, c=10, d=20)📌 Setup phase
duration:
0.00025164894759655outcome:
passed📌 Call phase
duration:
0.00017573917284607887outcome:
passed📌 Teardown phase
duration:
0.0001566130667924881outcome:
passed -
✅ Test 56
params: func="", expected_sig="(x, y, c=10, d=20)"📌 Runtime Parameters
params: func: <function wrap_ignore_all at 0x7f0d7d2b29d0> expected_sig: (x, y, c=10, d=20) id: wrap_ignore_all-(x, y, c=10, d=20)📌 Setup phase
duration:
0.00022580940276384354outcome:
passed📌 Call phase
duration:
0.00017311563715338707outcome:
passed📌 Teardown phase
duration:
0.00015149777755141258outcome:
passed
↳ Function: test_wrapper_behavior
-
✅ Test 57
params: func="", args=[1, 2, 3], kwargs={}, expected_result=36📌 Runtime Parameters
params: func: <function wrap_all at 0x7f0d7d2b28b0> args: - 1 - 2 - 3 kwargs: {} expected_result: 36 id: wrap_all-args0-kwargs0-36📌 Setup phase
duration:
0.00031569553539156914outcome:
passed📌 Call phase
duration:
0.0001424560323357582outcome:
passed📌 Teardown phase
duration:
0.00016541080549359322outcome:
passed -
✅ Test 58
params: func="", args=[1, 2, 3], kwargs={"d": 5}, expected_result=11📌 Runtime Parameters
params: func: <function wrap_all at 0x7f0d7d2b28b0> args: - 1 - 2 - 3 kwargs: d: 5 expected_result: 11 id: wrap_all-args1-kwargs1-11📌 Setup phase
duration:
0.0003112531267106533outcome:
passed📌 Call phase
duration:
0.0001484309323132038outcome:
passed📌 Teardown phase
duration:
0.00016588112339377403outcome:
passed -
✅ Test 59
params: func="", args=[0, 0], kwargs={"c": 3, "d": 4}, expected_result=10📌 Runtime Parameters
params: func: <function wrap_skip at 0x7f0d7d2b2940> args: - (vide) - (vide) kwargs: c: 3 d: 4 expected_result: 10 id: wrap_skip-args2-kwargs2-10📌 Setup phase
duration:
0.0003144647926092148outcome:
passed📌 Call phase
duration:
0.0001395917497575283outcome:
passed📌 Teardown phase
duration:
0.0001647663302719593outcome:
passed -
✅ Test 60
params: func="", args=[0, 0], kwargs={}, expected_result=10📌 Runtime Parameters
params: func: <function wrap_ignore_all at 0x7f0d7d2b29d0> args: - (vide) - (vide) kwargs: {} expected_result: 10 id: wrap_ignore_all-args3-kwargs3-10📌 Setup phase
duration:
0.0003097471781075001outcome:
passed📌 Call phase
duration:
0.0001345309428870678outcome:
passed📌 Teardown phase
duration:
0.00017423881217837334outcome:
passed
-
-
📄 test_utils_ask_yes_no.py
↳ Function: test_ask_yes_no
-
✅ Test 61
params: default=null, user_input="y", expected_output=true, expected_prompt="Question? [y/n] "📌 Runtime Parameters
params: default: None user_input: y expected_output: True expected_prompt: Question? [y/n] id: None-y-True-Question? [y/n]📌 Setup phase
duration:
0.0003234422765672207outcome:
passed📌 Call phase
duration:
0.0010214741341769695outcome:
passed📌 Teardown phase
duration:
0.00021963100880384445outcome:
passed -
✅ Test 62
params: default=null, user_input="yes", expected_output=true, expected_prompt="Question? [y/n] "📌 Runtime Parameters
params: default: None user_input: yes expected_output: True expected_prompt: Question? [y/n] id: None-yes-True-Question? [y/n]📌 Setup phase
duration:
0.00034508202224969864outcome:
passed📌 Call phase
duration:
0.0006138840690255165outcome:
passed📌 Teardown phase
duration:
0.00020788796246051788outcome:
passed -
✅ Test 63
params: default=null, user_input="n", expected_output=false, expected_prompt="Question? [y/n] "📌 Runtime Parameters
params: default: None user_input: n expected_output: False expected_prompt: Question? [y/n] id: None-n-False-Question? [y/n]📌 Setup phase
duration:
0.0003265221603214741outcome:
passed📌 Call phase
duration:
0.0005852053873240948outcome:
passed📌 Teardown phase
duration:
0.00018357811495661736outcome:
passed -
✅ Test 64
params: default=null, user_input="no", expected_output=false, expected_prompt="Question? [y/n] "📌 Runtime Parameters
params: default: None user_input: no expected_output: False expected_prompt: Question? [y/n] id: None-no-False-Question? [y/n]📌 Setup phase
duration:
0.00031391391530632973outcome:
passed📌 Call phase
duration:
0.0006615477614104748outcome:
passed📌 Teardown phase
duration:
0.00019007595255970955outcome:
passed -
✅ Test 65
params: default=null, user_input=["maybe", "y"], expected_output=true, expected_prompt="Question? [y/n] "📌 Runtime Parameters
params: default: None user_input: - maybe - y expected_output: True expected_prompt: Question? [y/n] id: None-user_input4-True-Question? [y/n]📌 Setup phase
duration:
0.000330447219312191outcome:
passed📌 Call phase
duration:
0.0005281688645482063outcome:
passed📌 Teardown phase
duration:
0.00018601398915052414outcome:
passed -
✅ Test 66
params: default=null, user_input=["", "no"], expected_output=false, expected_prompt="Question? [y/n] "📌 Runtime Parameters
params: default: None user_input: - (vide) - no expected_output: False expected_prompt: Question? [y/n] id: None-user_input5-False-Question? [y/n]📌 Setup phase
duration:
0.00032428791746497154outcome:
passed📌 Call phase
duration:
0.0005339058116078377outcome:
passed📌 Teardown phase
duration:
0.0001923171803355217outcome:
passed -
✅ Test 67
params: default=null, user_input=["invalid", "", "invalid", "yes"], expected_output=true, expected_prompt="Question? [y/n] "📌 Runtime Parameters
params: default: None user_input: - invalid - (vide) - invalid - yes expected_output: True expected_prompt: Question? [y/n] id: None-user_input6-True-Question? [y/n]📌 Setup phase
duration:
0.00033807801082730293outcome:
passed📌 Call phase
duration:
0.0005636550486087799outcome:
passed📌 Teardown phase
duration:
0.00019074184820055962outcome:
passed -
✅ Test 68
params: default="y", user_input="y", expected_output=true, expected_prompt="Question? [Y/n] "📌 Runtime Parameters
params: default: y user_input: y expected_output: True expected_prompt: Question? [Y/n] id: y-y-True-Question? [Y/n]📌 Setup phase
duration:
0.000316486693918705outcome:
passed📌 Call phase
duration:
0.0006165211088955402outcome:
passed📌 Teardown phase
duration:
0.00018827803432941437outcome:
passed -
✅ Test 69
params: default="y", user_input="n", expected_output=false, expected_prompt="Question? [Y/n] "📌 Runtime Parameters
params: default: y user_input: n expected_output: False expected_prompt: Question? [Y/n] id: y-n-False-Question? [Y/n]📌 Setup phase
duration:
0.00032814498990774155outcome:
passed📌 Call phase
duration:
0.0004975888878107071outcome:
passed📌 Teardown phase
duration:
0.0001959698274731636outcome:
passed -
✅ Test 70
params: default="y", user_input="", expected_output=true, expected_prompt="Question? [Y/n] "📌 Runtime Parameters
params: default: y user_input: None expected_output: True expected_prompt: Question? [Y/n] id: y--True-Question? [Y/n]📌 Setup phase
duration:
0.00032317405566573143outcome:
passed📌 Call phase
duration:
0.0005210316739976406outcome:
passed📌 Teardown phase
duration:
0.00019020820036530495outcome:
passed -
✅ Test 71
params: default="n", user_input="y", expected_output=true, expected_prompt="Question? [y/N] "📌 Runtime Parameters
params: default: n user_input: y expected_output: True expected_prompt: Question? [y/N] id: n-y-True-Question? [y/N]📌 Setup phase
duration:
0.0003122990019619465outcome:
passed📌 Call phase
duration:
0.0006120740436017513outcome:
passed📌 Teardown phase
duration:
0.00018484238535165787outcome:
passed -
✅ Test 72
params: default="n", user_input="n", expected_output=false, expected_prompt="Question? [y/N] "📌 Runtime Parameters
params: default: n user_input: n expected_output: False expected_prompt: Question? [y/N] id: n-n-False-Question? [y/N]📌 Setup phase
duration:
0.00031402334570884705outcome:
passed📌 Call phase
duration:
0.0005060890689492226outcome:
passed📌 Teardown phase
duration:
0.0001839720644056797outcome:
passed -
✅ Test 73
params: default="n", user_input="", expected_output=false, expected_prompt="Question? [y/N] "📌 Runtime Parameters
params: default: n user_input: None expected_output: False expected_prompt: Question? [y/N] id: n--False-Question? [y/N]📌 Setup phase
duration:
0.00032846396788954735outcome:
passed📌 Call phase
duration:
0.0005077668465673923outcome:
passed📌 Teardown phase
duration:
0.00019101472571492195outcome:
passed
↳ Function: test_ask_yes_no_ctrl_c
-
✅ Test 74
params: default=null, user_input="", expected_output=false, ctrl_c="n"📌 Runtime Parameters
params: default: None user_input: <class 'KeyboardInterrupt'> expected_output: False ctrl_c: n id: None-KeyboardInterrupt-False-n📌 Setup phase
duration:
0.0003163367509841919outcome:
passed📌 Call phase
duration:
0.0005157683044672012outcome:
passed📌 Teardown phase
duration:
0.00019621290266513824outcome:
passed -
✅ Test 75
params: default=null, user_input="", expected_output=true, ctrl_c="y"📌 Runtime Parameters
params: default: None user_input: <class 'KeyboardInterrupt'> expected_output: True ctrl_c: y id: None-KeyboardInterrupt-True-y📌 Setup phase
duration:
0.00031858962029218674outcome:
passed📌 Call phase
duration:
0.0006015649996697903outcome:
passed📌 Teardown phase
duration:
0.0001871371641755104outcome:
passed -
✅ Test 76
params: default="y", user_input="", expected_output=false, ctrl_c="n"📌 Runtime Parameters
params: default: y user_input: <class 'KeyboardInterrupt'> expected_output: False ctrl_c: n id: y-KeyboardInterrupt-False-n📌 Setup phase
duration:
0.0003275778144598007outcome:
passed📌 Call phase
duration:
0.0005019172094762325outcome:
passed📌 Teardown phase
duration:
0.0001878952607512474outcome:
passed -
✅ Test 77
params: default="y", user_input="", expected_output=true, ctrl_c="y"📌 Runtime Parameters
params: default: y user_input: <class 'KeyboardInterrupt'> expected_output: True ctrl_c: y id: y-KeyboardInterrupt-True-y📌 Setup phase
duration:
0.00031368620693683624outcome:
passed📌 Call phase
duration:
0.000500149093568325outcome:
passed📌 Teardown phase
duration:
0.0001907232217490673outcome:
passed -
✅ Test 78
params: default="n", user_input="", expected_output=false, ctrl_c="n"📌 Runtime Parameters
params: default: n user_input: <class 'KeyboardInterrupt'> expected_output: False ctrl_c: n id: n-KeyboardInterrupt-False-n📌 Setup phase
duration:
0.00032392190769314766outcome:
passed📌 Call phase
duration:
0.0005261823534965515outcome:
passed📌 Teardown phase
duration:
0.00018547195941209793outcome:
passed -
✅ Test 79
params: default=null, user_input="['invalid', '', 'invalid', ]", expected_output=false, ctrl_c="n"📌 Runtime Parameters
params: default: None user_input: ['invalid', '', 'invalid', <class 'KeyboardInterrupt'>] expected_output: False ctrl_c: n id: None-user_input5-False-n📌 Setup phase
duration:
0.000328900758177042outcome:
passed📌 Call phase
duration:
0.0006328257732093334outcome:
passed📌 Teardown phase
duration:
0.00018791994079947472outcome:
passed -
✅ Test 80
params: default=null, user_input="['invalid', '', 'invalid', ]", expected_output=true, ctrl_c="y"📌 Runtime Parameters
params: default: None user_input: ['invalid', '', 'invalid', <class 'KeyboardInterrupt'>] expected_output: True ctrl_c: y id: None-user_input6-True-y📌 Setup phase
duration:
0.0003302288241684437outcome:
passed📌 Call phase
duration:
0.000527476891875267outcome:
passed📌 Teardown phase
duration:
0.00019172392785549164outcome:
passed -
✅ Test 81
params: default=null, user_input="['foo', '', , '', 'invalid', , 'no']", expected_output=false, ctrl_c=null📌 Runtime Parameters
params: default: None user_input: ['foo', '', <class 'KeyboardInterrupt'>, '', 'invalid', <class 'KeyboardInterrupt'>, 'no'] expected_output: False ctrl_c: None id: None-user_input7-False-None📌 Setup phase
duration:
0.0003140498884022236outcome:
passed📌 Call phase
duration:
0.0005815108306705952outcome:
passed📌 Teardown phase
duration:
0.0001848558895289898outcome:
passed -
✅ Test 82
params: default="n", user_input="[, , , '']", expected_output=false, ctrl_c=null📌 Runtime Parameters
params: default: n user_input: [<class 'KeyboardInterrupt'>, <class 'KeyboardInterrupt'>, <class 'KeyboardInterrupt'>, ''] expected_output: False ctrl_c: None id: n-user_input8-False-None📌 Setup phase
duration:
0.00031749065965414047outcome:
passed📌 Call phase
duration:
0.0006434288807213306outcome:
passed📌 Teardown phase
duration:
0.0001883702352643013outcome:
passed -
✅ Test 83
params: default="n", user_input="[, , , '']", expected_output=false, ctrl_c="Invalid"📌 Runtime Parameters
params: default: n user_input: [<class 'KeyboardInterrupt'>, <class 'KeyboardInterrupt'>, <class 'KeyboardInterrupt'>, ''] expected_output: False ctrl_c: Invalid id: n-user_input9-False-Invalid📌 Setup phase
duration:
0.00031945062801241875outcome:
passed📌 Call phase
duration:
0.0005644937045872211outcome:
passed📌 Teardown phase
duration:
0.00018777279183268547outcome:
passed
↳ Function: test_ask_yes_no_ctrl_d
-
✅ Test 84
params: default=null, user_input="", expected_output=false, ctrl_d="n"📌 Runtime Parameters
params: default: None user_input: <class 'EOFError'> expected_output: False ctrl_d: n id: None-EOFError-False-n📌 Setup phase
duration:
0.0003313980996608734outcome:
passed📌 Call phase
duration:
0.0004920698702335358outcome:
passed📌 Teardown phase
duration:
0.00019901199266314507outcome:
passed -
✅ Test 85
params: default=null, user_input="", expected_output=true, ctrl_d="y"📌 Runtime Parameters
params: default: None user_input: <class 'EOFError'> expected_output: True ctrl_d: y id: None-EOFError-True-y📌 Setup phase
duration:
0.0003315410576760769outcome:
passed📌 Call phase
duration:
0.0005161999724805355outcome:
passed📌 Teardown phase
duration:
0.00019273022189736366outcome:
passed -
✅ Test 86
params: default="y", user_input="", expected_output=true, ctrl_d="y"📌 Runtime Parameters
params: default: y user_input: <class 'EOFError'> expected_output: True ctrl_d: y id: y-EOFError-True-y📌 Setup phase
duration:
0.0003240141086280346outcome:
passed📌 Call phase
duration:
0.0006068130023777485outcome:
passed📌 Teardown phase
duration:
0.0001945970579981804outcome:
passed -
✅ Test 87
params: default="n", user_input="", expected_output=true, ctrl_d="y"📌 Runtime Parameters
params: default: n user_input: <class 'EOFError'> expected_output: True ctrl_d: y id: n-EOFError-True-y📌 Setup phase
duration:
0.00032072514295578003outcome:
passed📌 Call phase
duration:
0.0004941169172525406outcome:
passed📌 Teardown phase
duration:
0.00017981696873903275outcome:
passed -
✅ Test 88
params: default="n", user_input="", expected_output=false, ctrl_d="n"📌 Runtime Parameters
params: default: n user_input: <class 'EOFError'> expected_output: False ctrl_d: n id: n-EOFError-False-n📌 Setup phase
duration:
0.0003172396682202816outcome:
passed📌 Call phase
duration:
0.0005083847790956497outcome:
passed📌 Teardown phase
duration:
0.00018998794257640839outcome:
passed -
✅ Test 89
params: default=null, user_input="['foo', ]", expected_output=true, ctrl_d="y"📌 Runtime Parameters
params: default: None user_input: ['foo', <class 'EOFError'>] expected_output: True ctrl_d: y id: None-user_input5-True-y📌 Setup phase
duration:
0.00032090209424495697outcome:
passed📌 Call phase
duration:
0.0005262689664959908outcome:
passed📌 Teardown phase
duration:
0.00018284935504198074outcome:
passed -
✅ Test 90
params: default=null, user_input="['foo', ]", expected_output=false, ctrl_d="n"📌 Runtime Parameters
params: default: None user_input: ['foo', <class 'EOFError'>] expected_output: False ctrl_d: n id: None-user_input6-False-n📌 Setup phase
duration:
0.00031416211277246475outcome:
passed📌 Call phase
duration:
0.000613912008702755outcome:
passed📌 Teardown phase
duration:
0.0001863068901002407outcome:
passed -
✅ Test 91
params: default="y", user_input="", expected_output=true, ctrl_d=null📌 Runtime Parameters
params: default: y user_input: <class 'EOFError'> expected_output: True ctrl_d: None id: y-EOFError-True-None📌 Setup phase
duration:
0.00032253190875053406outcome:
passed📌 Call phase
duration:
0.0004910933785140514outcome:
passed📌 Teardown phase
duration:
0.00018765032291412354outcome:
passed -
✅ Test 92
params: default="n", user_input="", expected_output=false, ctrl_d=null📌 Runtime Parameters
params: default: n user_input: <class 'EOFError'> expected_output: False ctrl_d: None id: n-EOFError-False-None📌 Setup phase
duration:
0.0003214809112250805outcome:
passed📌 Call phase
duration:
0.0005182637833058834outcome:
passed📌 Teardown phase
duration:
0.0001847781240940094outcome:
passed -
✅ Test 93
params: default=null, user_input="['invalid', 'ok', '', , 'ok', 'y']", expected_output=true, ctrl_d=null📌 Runtime Parameters
params: default: None user_input: ['invalid', 'ok', '', <class 'EOFError'>, 'ok', 'y'] expected_output: True ctrl_d: None id: None-user_input9-True-None📌 Setup phase
duration:
0.0003287200815975666outcome:
passed📌 Call phase
duration:
0.0006595230661332607outcome:
passed📌 Teardown phase
duration:
0.00018404191359877586outcome:
passed -
✅ Test 94
params: default="n", user_input="['no', ]", expected_output=false, ctrl_d=null📌 Runtime Parameters
params: default: n user_input: ['no', <class 'EOFError'>] expected_output: False ctrl_d: None id: n-user_input10-False-None📌 Setup phase
duration:
0.00034818612039089203outcome:
passed📌 Call phase
duration:
0.0005046753212809563outcome:
passed📌 Teardown phase
duration:
0.00018344121053814888outcome:
passed -
✅ Test 95
params: default=null, user_input="[, , , 'y']", expected_output=true, ctrl_d=null📌 Runtime Parameters
params: default: None user_input: [<class 'EOFError'>, <class 'EOFError'>, <class 'EOFError'>, 'y'] expected_output: True ctrl_d: None id: None-user_input11-True-None📌 Setup phase
duration:
0.0003249943256378174outcome:
passed📌 Call phase
duration:
0.0005442383699119091outcome:
passed📌 Teardown phase
duration:
0.000202943105250597outcome:
passed -
✅ Test 96
params: default=null, user_input="['invalid', '', 'nope', ]", expected_output=false, ctrl_d="n"📌 Runtime Parameters
params: default: None user_input: ['invalid', '', 'nope', <class 'EOFError'>] expected_output: False ctrl_d: n id: None-user_input12-False-n📌 Setup phase
duration:
0.0003162780776619911outcome:
passed📌 Call phase
duration:
0.0005448120646178722outcome:
passed📌 Teardown phase
duration:
0.00018797721713781357outcome:
passed -
✅ Test 97
params: default=null, user_input="['nope', 'nope', ]", expected_output=true, ctrl_d="y"📌 Runtime Parameters
params: default: None user_input: ['nope', 'nope', <class 'EOFError'>] expected_output: True ctrl_d: y id: None-user_input13-True-y📌 Setup phase
duration:
0.00031845178455114365outcome:
passed📌 Call phase
duration:
0.0006316499784588814outcome:
passed📌 Teardown phase
duration:
0.00018778862431645393outcome:
passed
↳ Function: test_ask_yes_no_mixed_sequences
-
✅ Test 98
params: default=null, ctrl_c="invalid", ctrl_d=null, user_input="['what', '', 'nope', , 'ok', , 'no']", expected_output=false📌 Runtime Parameters
params: default: None ctrl_c: invalid ctrl_d: None user_input: ['what', '', 'nope', <class 'KeyboardInterrupt'>, 'ok', <class 'EOFError'>, 'no'] expected_output: False id: None-invalid-None-user_input0-False📌 Setup phase
duration:
0.00037599122151732445outcome:
passed📌 Call phase
duration:
0.0005720858462154865outcome:
passed📌 Teardown phase
duration:
0.00020413706079125404outcome:
passed -
✅ Test 99
params: default=null, ctrl_c=null, ctrl_d="notananswer", user_input="['maybe', , 'nop', 'yep', , 'yes']", expected_output=true📌 Runtime Parameters
params: default: None ctrl_c: None ctrl_d: notananswer user_input: ['maybe', <class 'KeyboardInterrupt'>, 'nop', 'yep', <class 'EOFError'>, 'yes'] expected_output: True id: None-None-notananswer-user_input1-True📌 Setup phase
duration:
0.00042090006172657013outcome:
passed📌 Call phase
duration:
0.0005938010290265083outcome:
passed📌 Teardown phase
duration:
0.00020012585446238518outcome:
passed -
✅ Test 100
params: default=null, ctrl_c="n", ctrl_d="nop", user_input="['ok', , , 'maybe', , 'nah', ]", expected_output=false📌 Runtime Parameters
params: default: None ctrl_c: n ctrl_d: nop user_input: ['ok', <class 'EOFError'>, <class 'EOFError'>, 'maybe', <class 'EOFError'>, 'nah', <class 'KeyboardInterrupt'>] expected_output: False id: None-n-nop-user_input2-False📌 Setup phase
duration:
0.0003708186559379101outcome:
passed📌 Call phase
duration:
0.0010177413932979107outcome:
passed📌 Teardown phase
duration:
0.00019905390217900276outcome:
passed
-
-
📄 test_utils_channels.py
↳ Function: test_load_channels_and_channels_class_with_professional_names
-
✅ Test 101
📌 Setup phase
duration:
0.00013221567496657372outcome:
passed📌 Call phase
duration:
0.0010758922435343266outcome:
passed📌 Teardown phase
duration:
0.00011748773977160454outcome:
passed
-
-
📄 test_utils_config.py
↳ Function: test_config_with_nested_and_list_data
-
✅ Test 102
📌 Setup phase
duration:
0.00012946315109729767outcome:
passed📌 Call phase
duration:
0.0006152722053229809outcome:
passed📌 Teardown phase
duration:
0.00011672498658299446outcome:
passed
↳ Function: test_config_with_strange_and_edge_keys
-
✅ Test 103
📌 Setup phase
duration:
0.00011520134285092354outcome:
passed📌 Call phase
duration:
0.0007550655864179134outcome:
passed📌 Teardown phase
duration:
0.00012429896742105484outcome:
passed
-
-
📄 test_utils_cpint.py
↳ Function: test_load_color_variants_all_keys_and_types
-
✅ Test 104
params: base_color="red"📌 Runtime Parameters
params: base_color: red id: red📌 Setup phase
duration:
0.0002009030431509018outcome:
passed📌 Call phase
duration:
0.00016348157078027725outcome:
passed📌 Teardown phase
duration:
0.00013283593580126762outcome:
passed -
✅ Test 105
params: base_color="blue"📌 Runtime Parameters
params: base_color: blue id: blue📌 Setup phase
duration:
0.00018959678709506989outcome:
passed📌 Call phase
duration:
0.000166306272149086outcome:
passed📌 Teardown phase
duration:
0.00012353714555501938outcome:
passed -
✅ Test 106
params: base_color="yellow"📌 Runtime Parameters
params: base_color: yellow id: yellow📌 Setup phase
duration:
0.00016831979155540466outcome:
passed📌 Call phase
duration:
0.00015687011182308197outcome:
passed📌 Teardown phase
duration:
0.00011893408372998238outcome:
passed -
✅ Test 107
params: base_color="green"📌 Runtime Parameters
params: base_color: green id: green📌 Setup phase
duration:
0.00016584992408752441outcome:
passed📌 Call phase
duration:
0.00015910575166344643outcome:
passed📌 Teardown phase
duration:
0.00012742122635245323outcome:
passed -
✅ Test 108
params: base_color="cyan"📌 Runtime Parameters
params: base_color: cyan id: cyan📌 Setup phase
duration:
0.00017089396715164185outcome:
passed📌 Call phase
duration:
0.00016588205471634865outcome:
passed📌 Teardown phase
duration:
0.00011852569878101349outcome:
passed -
✅ Test 109
params: base_color="magenta"📌 Runtime Parameters
params: base_color: magenta id: magenta📌 Setup phase
duration:
0.0001712762750685215outcome:
passed📌 Call phase
duration:
0.00016400497406721115outcome:
passed📌 Teardown phase
duration:
0.00012154318392276764outcome:
passed -
✅ Test 110
params: base_color="white"📌 Runtime Parameters
params: base_color: white id: white📌 Setup phase
duration:
0.00018349476158618927outcome:
passed📌 Call phase
duration:
0.00014581624418497086outcome:
passed📌 Teardown phase
duration:
0.000119050033390522outcome:
passed -
✅ Test 111
params: base_color="black"📌 Runtime Parameters
params: base_color: black id: black📌 Setup phase
duration:
0.00017742998898029327outcome:
passed📌 Call phase
duration:
0.00015157600864768028outcome:
passed📌 Teardown phase
duration:
0.00012042280286550522outcome:
passed
↳ Function: test_cprint_all_cases_fancy
-
✅ Test 112
params: objects=[["Fancy", "list"], {"a": 7}, null], color_spec=["red", "+"], sep=" | ", expected_flatten="['Fancy', 'list'] | {'a': 7} | None", expected_error=null📌 Runtime Parameters
params: objects: - - Fancy - list - a: 7 - (vide) color_spec: - red - + sep: | expected_flatten: ['Fancy', 'list'] | {'a': 7} | None expected_error: None id: objects0-color_spec0- | -['Fancy', 'list'] | {'a': 7} | None-None📌 Setup phase
duration:
0.000658170785754919outcome:
passed📌 Call phase
duration:
0.0002447478473186493outcome:
passed📌 Teardown phase
duration:
0.0002524689771234989outcome:
passed -
✅ Test 113
params: objects=[{"k": [1, 2]}, 99, ["X", ["Y"]]], color_spec=["blue", "++"], sep=" - ", expected_flatten="{'k': [1, 2]} - 99 - ['X', ['Y']]", expected_error=null📌 Runtime Parameters
params: objects: - k: - 1 - 2 - 99 - - X - - Y color_spec: - blue - ++ sep: - expected_flatten: {'k': [1, 2]} - 99 - ['X', ['Y']] expected_error: None id: objects1-color_spec1- - -{'k': [1, 2]} - 99 - ['X', ['Y']]-None📌 Setup phase
duration:
0.00046469876542687416outcome:
passed📌 Call phase
duration:
0.00022922735661268234outcome:
passed📌 Teardown phase
duration:
0.00024186819791793823outcome:
passed -
✅ Test 114
params: objects=[[], {}, "End"], color_spec=["magenta", "--"], sep=" / ", expected_flatten="[] / {} / End", expected_error=null📌 Runtime Parameters
params: objects: - (vide) - (vide) - End color_spec: - magenta - -- sep: / expected_flatten: [] / {} / End expected_error: None id: objects2-color_spec2- / -[] / {} / End-None📌 Setup phase
duration:
0.000441849697381258outcome:
passed📌 Call phase
duration:
0.0002179616130888462outcome:
passed📌 Teardown phase
duration:
0.00023705698549747467outcome:
passed -
✅ Test 115
params: objects="", [3, 4, "done", 0], color_spec=["green", ""], sep=";", expected_flatten="['', [3, 4]];done;0", expected_error=null📌 Runtime Parameters
params: objects: - - (vide) - - 3 - 4 - done - (vide) color_spec: - green - (vide) sep: ; expected_flatten: ['', [3, 4]];done;0 expected_error: None id: objects3-color_spec3-;-['', [3, 4]];done;0-None📌 Setup phase
duration:
0.00045952480286359787outcome:
passed📌 Call phase
duration:
0.0002175332047045231outcome:
passed📌 Teardown phase
duration:
0.00023715989664196968outcome:
passed -
✅ Test 116
params: objects=[["alpha", null], ["beta", {}], "stop"], color_spec=["yellow", ""], sep="::", expected_flatten="['alpha', None]::['beta', {}]::stop", expected_error=null📌 Runtime Parameters
params: objects: - - alpha - (vide) - - beta - (vide) - stop color_spec: - yellow - (vide) sep: :: expected_flatten: ['alpha', None]::['beta', {}]::stop expected_error: None id: objects4-color_spec4-::-['alpha', None]::['beta', {}]::stop-None📌 Setup phase
duration:
0.0004527219571173191outcome:
passed📌 Call phase
duration:
0.0002253251150250435outcome:
passed📌 Teardown phase
duration:
0.0002418002113699913outcome:
passed -
✅ Test 117
params: objects="deep", ["deeper", ["deepest"], "X"], color_spec=["cyan", "+"], sep=" ... ", expected_flatten="['deep', ['deeper', ['deepest']]] ... X", expected_error=null📌 Runtime Parameters
params: objects: - - deep - - deeper - - deepest - X color_spec: - cyan - + sep: ... expected_flatten: ['deep', ['deeper', ['deepest']]] ... X expected_error: None id: objects5-color_spec5- ... -['deep', ['deeper', ['deepest']]] ... X-None📌 Setup phase
duration:
0.00046601612120866776outcome:
passed📌 Call phase
duration:
0.00021579070016741753outcome:
passed📌 Teardown phase
duration:
0.00024233805015683174outcome:
passed -
✅ Test 118
params: objects=[{"dict": {"nested": [4, 5]}}, [true, false], 6.28], color_spec=["white", "++"], sep=" // ", expected_flatten="{'dict': {'nested': [4, 5]}} // [True, False] // 6.28", expected_error=null📌 Runtime Parameters
params: objects: - dict: nested: - 4 - 5 - - True - (vide) - 6.28 color_spec: - white - ++ sep: // expected_flatten: {'dict': {'nested': [4, 5]}} // [True, False] // 6.28 expected_error: None id: objects6-color_spec6- // -{'dict': {'nested': [4, 5]}} // [True, False] // 6.28-None📌 Setup phase
duration:
0.00043158233165740967outcome:
passed📌 Call phase
duration:
0.0002409820444881916outcome:
passed📌 Teardown phase
duration:
0.0002468610182404518outcome:
passed -
✅ Test 119
params: objects="A", ["B", "string", "C"], color_spec=["red", "--"], sep="==", expected_flatten="['A', ['B']]==string==C", expected_error=null📌 Runtime Parameters
params: objects: - - A - - B - string - C color_spec: - red - -- sep: == expected_flatten: ['A', ['B']]==string==C expected_error: None id: objects7-color_spec7-==-['A', ['B']]==string==C-None📌 Setup phase
duration:
0.0005797701887786388outcome:
passed📌 Call phase
duration:
0.00022889720275998116outcome:
passed📌 Teardown phase
duration:
0.0002492540515959263outcome:
passed -
✅ Test 120
params: objects="Test", null, [, {"v": 0}], color_spec=["green", "++"], sep=" ++ ", expected_flatten="['Test', None, []] ++ {'v': 0}", expected_error=null📌 Runtime Parameters
params: objects: - - Test - (vide) - (vide) - v: 0 color_spec: - green - ++ sep: ++ expected_flatten: ['Test', None, []] ++ {'v': 0} expected_error: None id: objects8-color_spec8- ++ -['Test', None, []] ++ {'v': 0}-None📌 Setup phase
duration:
0.0004568719305098057outcome:
passed📌 Call phase
duration:
0.00022196583449840546outcome:
passed📌 Teardown phase
duration:
0.00024091685190796852outcome:
passed -
✅ Test 121
params: objects=[["no", "color"], "plain"], color_spec=null, sep=";", expected_flatten="['no', 'color'];plain", expected_error=null📌 Runtime Parameters
params: objects: - - no - color - plain color_spec: None sep: ; expected_flatten: ['no', 'color'];plain expected_error: None id: objects9-None-;-['no', 'color'];plain-None📌 Setup phase
duration:
0.0004467172548174858outcome:
passed📌 Call phase
duration:
0.00020524626597762108outcome:
passed📌 Teardown phase
duration:
0.00024992600083351135outcome:
passed -
✅ Test 122
params: objects=[["simple"], "", 12], color_spec=null, sep=" | ", expected_flatten="['simple'] | | 12", expected_error=null📌 Runtime Parameters
params: objects: - - simple - (vide) - 12 color_spec: None sep: | expected_flatten: ['simple'] | | 12 expected_error: None id: objects10-None- | -['simple'] | | 12-None📌 Setup phase
duration:
0.0004568849690258503outcome:
passed📌 Call phase
duration:
0.0002113240770995617outcome:
passed📌 Teardown phase
duration:
0.00023911474272608757outcome:
passed -
✅ Test 123
params: objects=["very", "deep", {"ok": true}], color_spec=null, sep=" : ", expected_flatten="'very', 'deep' : {'ok': True}", expected_error=null📌 Runtime Parameters
params: objects: - - - very - deep - ok: True color_spec: None sep: : expected_flatten: [['very', 'deep']] : {'ok': True} expected_error: None id: objects11-None- : -[['very', 'deep']] : {'ok': True}-None📌 Setup phase
duration:
0.0004537571221590042outcome:
passed📌 Call phase
duration:
0.00021132826805114746outcome:
passed📌 Teardown phase
duration:
0.0002504577860236168outcome:
passed -
✅ Test 124
params: objects=[["fail", "color"], 123], color_spec=["green", "!!"], sep="|", expected_flatten="['fail', 'color']|123", expected_error=""📌 Runtime Parameters
params: objects: - - fail - color - 123 color_spec: - green - !! sep: | expected_flatten: ['fail', 'color']|123 expected_error: <class 'ValueError'> id: objects12-color_spec12-|-['fail', 'color']|123-ValueError📌 Setup phase
duration:
0.00046335533261299133outcome:
passed📌 Call phase
duration:
0.00025607505813241005outcome:
passed📌 Teardown phase
duration:
0.000273378100246191outcome:
passed -
✅ Test 125
params: objects=[["error"], {}], color_spec=["cyan", "xxx"], sep=" * ", expected_flatten="['error'] * {}", expected_error=""📌 Runtime Parameters
params: objects: - - error - (vide) color_spec: - cyan - xxx sep: * expected_flatten: ['error'] * {} expected_error: <class 'ValueError'> id: objects13-color_spec13- * -['error'] * {}-ValueError📌 Setup phase
duration:
0.0004484807141125202outcome:
passed📌 Call phase
duration:
0.00023895222693681717outcome:
passed📌 Teardown phase
duration:
0.00023594172671437263outcome:
passed -
✅ Test 126
params: objects="nope"], ["bad", color_spec=["magenta", "invalid"], sep="//", expected_flatten="['nope']//['bad']", expected_error=""📌 Runtime Parameters
params: objects: - - nope - - bad color_spec: - magenta - invalid sep: // expected_flatten: ['nope']//['bad'] expected_error: <class 'ValueError'> id: objects14-color_spec14-//-['nope']//['bad']-ValueError📌 Setup phase
duration:
0.00046099722385406494outcome:
passed📌 Call phase
duration:
0.0002219630405306816outcome:
passed📌 Teardown phase
duration:
0.00024130428209900856outcome:
passed -
✅ Test 127
params: objects=["wrong", "base"], color_spec=["notacolor", ""], sep="--", expected_flatten="wrong--base", expected_error=""📌 Runtime Parameters
params: objects: - wrong - base color_spec: - notacolor - (vide) sep: -- expected_flatten: wrong--base expected_error: <class 'ValueError'> id: objects15-color_spec15----wrong--base-ValueError📌 Setup phase
duration:
0.0004528248682618141outcome:
passed📌 Call phase
duration:
0.0002233581617474556outcome:
passed📌 Teardown phase
duration:
0.00024500489234924316outcome:
passed
-
-
📄 test_utils_debug.py
↳ Function: test_traceable
-
✅ Test 128
params: cls="", entry=[[10, 20], {}], expected="creating: A(10, 20)"📌 Runtime Parameters
params: cls: <class 'test_utils_debug.A'> entry: - - 10 - 20 - (vide) expected: creating: A(10, 20) id: A-entry0-creating: A(10, 20)📌 Setup phase
duration:
0.000284477137029171outcome:
passed📌 Call phase
duration:
0.0009837839752435684outcome:
passed📌 Teardown phase
duration:
0.00020769843831658363outcome:
passed -
✅ Test 129
params: cls="", entry=[[10, 20], {"e": 100}], expected="creating: A(10, 20, e=100)"📌 Runtime Parameters
params: cls: <class 'test_utils_debug.A'> entry: - - 10 - 20 - e: 100 expected: creating: A(10, 20, e=100) id: A-entry1-creating: A(10, 20, e=100)📌 Setup phase
duration:
0.00028727808967232704outcome:
passed📌 Call phase
duration:
0.0009635048918426037outcome:
passed📌 Teardown phase
duration:
0.00017823278903961182outcome:
passed -
✅ Test 130
params: cls="", entry="foo", [1, 2, 3, {"flag": true, "data": {"x": 9}}], expected="creating: A('foo', [1, 2, 3], flag=True, data={'x': 9})"📌 Runtime Parameters
params: cls: <class 'test_utils_debug.A'> entry: - - foo - - 1 - 2 - 3 - flag: True data: x: 9 expected: creating: A('foo', [1, 2, 3], flag=True, data={'x': 9}) id: A-entry2-creating: A('foo', [1, 2, 3], flag=True, data={'x': 9})📌 Setup phase
duration:
0.0002760649658739567outcome:
passed📌 Call phase
duration:
0.0008312086574733257outcome:
passed📌 Teardown phase
duration:
0.00018307799473404884outcome:
passed -
✅ Test 131
params: cls="", entry="([CustomObj(big), [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]], {'name': 'test', 'meta': 'yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy'})", expected="creating: A(CustomObj(big), [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], name='test', meta='yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy...)"📌 Runtime Parameters
params: cls: <class 'test_utils_debug.A'> entry: ([CustomObj(big), [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]], {'name': 'test', 'meta': 'yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy'}) expected: creating: A(CustomObj(big), [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], name='test', meta='yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy...) id: A-entry3-creating: A(CustomObj(big), [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], name='test', meta='yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy...)📌 Setup phase
duration:
0.0002897735685110092outcome:
passed📌 Call phase
duration:
0.0008950917981564999outcome:
passed📌 Teardown phase
duration:
0.00017376011237502098outcome:
passed -
✅ Test 132
params: cls="", entry="AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA", [0, 0, 0, 0, 0, {}], expected="creating: A('AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA..., [0, 0, 0, 0, 0])"📌 Runtime Parameters
params: cls: <class 'test_utils_debug.A'> entry: - - AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA - - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) expected: creating: A('AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA..., [0, 0, 0, 0, 0]) id: A-entry4-creating: A('AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA..., [0, 0, 0, 0, 0])📌 Setup phase
duration:
0.0002866857685148716outcome:
passed📌 Call phase
duration:
0.0008026701398193836outcome:
passed📌 Teardown phase
duration:
0.0001860358752310276outcome:
passed
↳ Function: test_short_repr
-
✅ Test 133
params: value="abc", cutoff=10, expected="'abc'"📌 Runtime Parameters
params: value: abc cutoff: 10 expected: 'abc' id: abc-10-'abc'📌 Setup phase
duration:
0.00027833180502057076outcome:
passed📌 Call phase
duration:
0.00016124313697218895outcome:
passed📌 Teardown phase
duration:
0.00015976699069142342outcome:
passed -
✅ Test 135
params: value=12345, cutoff=10, expected="12345"📌 Runtime Parameters
params: value: 12345 cutoff: 10 expected: 12345 id: 12345-10-12345📌 Setup phase
duration:
0.0003710179589688778outcome:
passed📌 Call phase
duration:
0.0001683039590716362outcome:
passed📌 Teardown phase
duration:
0.00015930179506540298outcome:
passed -
✅ Test 136
params: value=[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], cutoff=15, expected="[0, 0, 0, 0, 0,..."📌 Runtime Parameters
params: value: - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) - (vide) cutoff: 15 expected: [0, 0, 0, 0, 0,... id: value3-15-[0, 0, 0, 0, 0,...📌 Setup phase
duration:
0.0003044949844479561outcome:
passed📌 Call phase
duration:
0.00015724217519164085outcome:
passed📌 Teardown phase
duration:
0.0001572216860949993outcome:
passed -
✅ Test 137
params: value=null, cutoff=10, expected="None"📌 Runtime Parameters
params: value: None cutoff: 10 expected: None id: None-10-None📌 Setup phase
duration:
0.00026660598814487457outcome:
passed📌 Call phase
duration:
0.0001390567049384117outcome:
passed📌 Teardown phase
duration:
0.00016216887161135674outcome:
passed
-
-
📄 test_utils_dictext.py
↳ Function: test_attrdict_getattr
-
✅ Test 139
params: data={"x": 1, "y": 2}, attr="x", expected=1📌 Runtime Parameters
params: data: x: 1 y: 2 attr: x expected: 1 id: data0-x-1📌 Setup phase
duration:
0.000314952339977026outcome:
passed📌 Call phase
duration:
0.00016543781384825706outcome:
passed📌 Teardown phase
duration:
0.00015901634469628334outcome:
passed -
✅ Test 140
params: data={"world": "ok"}, attr="world", expected="ok"📌 Runtime Parameters
params: data: world: ok attr: world expected: ok id: data1-world-ok📌 Setup phase
duration:
0.0002875593490898609outcome:
passed📌 Call phase
duration:
0.00014807097613811493outcome:
passed📌 Teardown phase
duration:
0.00016612093895673752outcome:
passed -
✅ Test 141
params: data={"outer": {"inner": 42}}, attr="outer", expected={"inner": 42}📌 Runtime Parameters
params: data: outer: inner: 42 attr: outer expected: inner: 42 id: data2-outer-expected2📌 Setup phase
duration:
0.0002669398672878742outcome:
passed📌 Call phase
duration:
0.0001430693082511425outcome:
passed📌 Teardown phase
duration:
0.00015641981735825539outcome:
passed
↳ Function: test_attrdict_setattr
-
✅ Test 142
params: initial={}, attr="nouveau", value=123📌 Runtime Parameters
params: initial: {} attr: nouveau value: 123 id: initial0-nouveau-123📌 Setup phase
duration:
0.00027180416509509087outcome:
passed📌 Call phase
duration:
0.00014228234067559242outcome:
passed📌 Teardown phase
duration:
0.00015268474817276outcome:
passed -
✅ Test 143
params: initial={"a": 1}, attr="b", value="valeur"📌 Runtime Parameters
params: initial: a: 1 attr: b value: valeur id: initial1-b-valeur📌 Setup phase
duration:
0.0002833651378750801outcome:
passed📌 Call phase
duration:
0.0001495317555963993outcome:
passed📌 Teardown phase
duration:
0.00015307310968637466outcome:
passed
↳ Function: test_attrdict_delattr
-
✅ Test 144
params: initial={"a": 1, "b": 2}, to_del="a", expected_keys=["b"]📌 Runtime Parameters
params: initial: a: 1 b: 2 to_del: a expected_keys: - b id: initial0-a-expected_keys0📌 Setup phase
duration:
0.00030235666781663895outcome:
passed📌 Call phase
duration:
0.00019221613183617592outcome:
passed📌 Teardown phase
duration:
0.00015769898891448975outcome:
passed -
✅ Test 145
params: initial={"k": "v"}, to_del="k", expected_keys=[]📌 Runtime Parameters
params: initial: k: v to_del: k expected_keys: [] id: initial1-k-expected_keys1📌 Setup phase
duration:
0.0002701161429286003outcome:
passed📌 Call phase
duration:
0.00017682882025837898outcome:
passed📌 Teardown phase
duration:
0.00016170786693692207outcome:
passed
↳ Function: test_attrdict_dir
-
✅ Test 146
params: data={"alpha": 1, "beta": 2}, expected_keys="{'alpha', 'beta'}"📌 Runtime Parameters
params: data: alpha: 1 beta: 2 expected_keys: {'alpha', 'beta'} id: data0-expected_keys0📌 Setup phase
duration:
0.00022558914497494698outcome:
passed📌 Call phase
duration:
0.00014973478391766548outcome:
passed📌 Teardown phase
duration:
0.00015482306480407715outcome:
passed -
✅ Test 147
params: data={}, expected_keys="set()"📌 Runtime Parameters
params: data: {} expected_keys: set() id: data1-expected_keys1📌 Setup phase
duration:
0.0002272757701575756outcome:
passed📌 Call phase
duration:
0.00016947975382208824outcome:
passed📌 Teardown phase
duration:
0.00013943016529083252outcome:
passed
↳ Function: test_attrdict_getattr_and_missing
-
✅ Test 148
params: data={"x": 1, "y": 2}, attr="x", expect_value=1, expect_error=null📌 Runtime Parameters
params: data: x: 1 y: 2 attr: x expect_value: 1 expect_error: None id: data0-x-1-None📌 Setup phase
duration:
0.0003287121653556824outcome:
passed📌 Call phase
duration:
0.00015037693083286285outcome:
passed📌 Teardown phase
duration:
0.00016768183559179306outcome:
passed -
✅ Test 149
params: data={"number": 42}, attr="missing", expect_value=null, expect_error="'MyDict' object has no attribute 'missing'"📌 Runtime Parameters
params: data: number: 42 attr: missing expect_value: None expect_error: 'MyDict' object has no attribute 'missing' id: data1-missing-None-'MyDict' object has no attribute 'missing'📌 Setup phase
duration:
0.00030797719955444336outcome:
passed📌 Call phase
duration:
0.00016599008813500404outcome:
passed📌 Teardown phase
duration:
0.0001853550784289837outcome:
passed
↳ Function: test_dictupdatemixin_init_and_update
-
✅ Test 150
params: init_kwargs={"a": 1, "b": 2}, other=null, kwargs={}, expected={"a": 1, "b": 2}📌 Runtime Parameters
params: init_kwargs: a: 1 b: 2 other: None kwargs: {} expected: a: 1 b: 2 id: init_kwargs0-None-kwargs0-expected0📌 Setup phase
duration:
0.00033158203586935997outcome:
passed📌 Call phase
duration:
0.00014837691560387611outcome:
passed📌 Teardown phase
duration:
0.000163267832249403outcome:
passed -
✅ Test 151
params: init_kwargs={}, other={"x": 10, "y": 20}, kwargs={}, expected={"x": 10, "y": 20}📌 Runtime Parameters
params: init_kwargs: {} other: x: 10 y: 20 kwargs: {} expected: x: 10 y: 20 id: init_kwargs1-other1-kwargs1-expected1📌 Setup phase
duration:
0.00029783230274915695outcome:
passed📌 Call phase
duration:
0.00016437890008091927outcome:
passed📌 Teardown phase
duration:
0.00016867602244019508outcome:
passed -
✅ Test 152
params: init_kwargs={"world": "ok"}, other={"number": 42}, kwargs={"num2": 100}, expected={"world": "ok", "number": 42, "num2": 100}📌 Runtime Parameters
params: init_kwargs: world: ok other: number: 42 kwargs: num2: 100 expected: world: ok number: 42 num2: 100 id: init_kwargs2-other2-kwargs2-expected2📌 Setup phase
duration:
0.0003126021474599838outcome:
passed📌 Call phase
duration:
0.00015513179823756218outcome:
passed📌 Teardown phase
duration:
0.00017096614465117455outcome:
passed -
✅ Test 153
params: init_kwargs={}, other=null, kwargs={"alpha": "beta"}, expected={"alpha": "beta"}📌 Runtime Parameters
params: init_kwargs: {} other: None kwargs: alpha: beta expected: alpha: beta id: init_kwargs3-None-kwargs3-expected3📌 Setup phase
duration:
0.00032139290124177933outcome:
passed📌 Call phase
duration:
0.00014510424807667732outcome:
passed📌 Teardown phase
duration:
0.0001753922551870346outcome:
passed -
✅ Test 154
params: init_kwargs={}, other={"key": "value"}, kwargs={"extra": 1}, expected={"key": "value", "extra": 1}📌 Runtime Parameters
params: init_kwargs: {} other: key: value kwargs: extra: 1 expected: key: value extra: 1 id: init_kwargs4-other4-kwargs4-expected4📌 Setup phase
duration:
0.00031221285462379456outcome:
passed📌 Call phase
duration:
0.00014487933367490768outcome:
passed📌 Teardown phase
duration:
0.00016971910372376442outcome:
passed -
✅ Test 155
params: init_kwargs={}, other="key", "value"], ["list", [5, 6], kwargs={"extra": {"subkey": 123}}, expected={"key": "value", "list": [5, 6], "extra": {"subkey": 123}}📌 Runtime Parameters
params: init_kwargs: {} other: - - key - value - - list - - 5 - 6 kwargs: extra: subkey: 123 expected: key: value list: - 5 - 6 extra: subkey: 123 id: init_kwargs5-other5-kwargs5-expected5📌 Setup phase
duration:
0.0003099348396062851outcome:
passed📌 Call phase
duration:
0.0003048740327358246outcome:
passed📌 Teardown phase
duration:
0.00018518976867198944outcome:
passed
-
-
📄 test_utils_dotdir.py
↳ Function: test_dotdir_creation_and_base_exists
-
✅ Test 156
📌 Setup phase
duration:
0.0016765766777098179outcome:
passed📌 Call phase
duration:
0.00028046872466802597outcome:
passed📌 Teardown phase
duration:
0.00022264989092946053outcome:
passed
↳ Function: test_dotdir_repr_returns_path_str
-
✅ Test 157
📌 Setup phase
duration:
0.0006678709760308266outcome:
passed📌 Call phase
duration:
0.00023865606635808945outcome:
passed📌 Teardown phase
duration:
0.00022230995818972588outcome:
passed
↳ Function: test_dotdir_call
-
✅ Test 158
📌 Setup phase
duration:
0.0006891950033605099outcome:
passed📌 Call phase
duration:
0.000269921962171793outcome:
passed📌 Teardown phase
duration:
0.00020933523774147034outcome:
passed
-
-
📄 test_utils_elog.py
↳ Function: test_get_default_elog_instance_with_direct_password_and_real_check
-
✅ Test 160
📌 Setup phase
duration:
0.0001511983573436737outcome:
passed📌 Call phase
duration:
0.00926697626709938outcome:
passed📌 Teardown phase
duration:
0.00014980416744947433outcome:
passed
↳ Function: test_get_default_elog_instance_asks_password_and_opens
-
✅ Test 161
📌 Setup phase
duration:
0.0003296239301562309outcome:
passed📌 Call phase
duration:
0.00903921015560627outcome:
passed📌 Teardown phase
duration:
0.0001326962374150753outcome:
passed
↳ Function: test_get_default_elog_with_path_home
-
✅ Test 162
📌 Setup phase
duration:
0.00012593204155564308outcome:
passed📌 Call phase
duration:
0.009383381810039282outcome:
passed📌 Teardown phase
duration:
0.00013490766286849976outcome:
passed
-
-
📄 test_utils_eval.py
↳ Function: test_arithmetic_eval_valid
-
✅ Test 165
params: expr="1 + 2", expected=3📌 Runtime Parameters
params: expr: 1 + 2 expected: 3 id: 1 + 2-3📌 Setup phase
duration:
0.00033107632771134377outcome:
passed📌 Call phase
duration:
0.000190740916877985outcome:
passed📌 Teardown phase
duration:
0.00015589920803904533outcome:
passed -
✅ Test 166
params: expr="4 - 2", expected=2📌 Runtime Parameters
params: expr: 4 - 2 expected: 2 id: 4 - 2-2📌 Setup phase
duration:
0.00024772388860583305outcome:
passed📌 Call phase
duration:
0.00019035488367080688outcome:
passed📌 Teardown phase
duration:
0.0001408248208463192outcome:
passed -
✅ Test 167
params: expr="3 * 5", expected=15📌 Runtime Parameters
params: expr: 3 * 5 expected: 15 id: 3 * 5-15📌 Setup phase
duration:
0.00022120401263237outcome:
passed📌 Call phase
duration:
0.0001596449874341488outcome:
passed📌 Teardown phase
duration:
0.00014017987996339798outcome:
passed -
✅ Test 168
params: expr="10 / 2", expected=5.0📌 Runtime Parameters
params: expr: 10 / 2 expected: 5.0 id: 10 / 2-5.0📌 Setup phase
duration:
0.0002327081747353077outcome:
passed📌 Call phase
duration:
0.0001502777449786663outcome:
passed📌 Teardown phase
duration:
0.00014761928468942642outcome:
passed -
✅ Test 169
params: expr="10 % 3", expected=1📌 Runtime Parameters
params: expr: 10 % 3 expected: 1 id: 10 % 3-1📌 Setup phase
duration:
0.00023822486400604248outcome:
passed📌 Call phase
duration:
0.00015215296298265457outcome:
passed📌 Teardown phase
duration:
0.00013943295925855637outcome:
passed -
✅ Test 170
params: expr="-5", expected=-5📌 Runtime Parameters
params: expr: -5 expected: -5 id: -5--5📌 Setup phase
duration:
0.0002212109975516796outcome:
passed📌 Call phase
duration:
0.00015002908185124397outcome:
passed📌 Teardown phase
duration:
0.00013791536912322044outcome:
passed -
✅ Test 171
params: expr="+7", expected=7📌 Runtime Parameters
params: expr: +7 expected: 7 id: +7-7📌 Setup phase
duration:
0.00022696470841765404outcome:
passed📌 Call phase
duration:
0.00015652133151888847outcome:
passed📌 Teardown phase
duration:
0.00016643572598695755outcome:
passed -
✅ Test 172
params: expr="1 + 2 * 3", expected=7📌 Runtime Parameters
params: expr: 1 + 2 * 3 expected: 7 id: 1 + 2 * 3-7📌 Setup phase
duration:
0.00022377120330929756outcome:
passed📌 Call phase
duration:
0.00016299402341246605outcome:
passed📌 Teardown phase
duration:
0.00014186697080731392outcome:
passed -
✅ Test 173
params: expr="(1 + 2) * 3", expected=9📌 Runtime Parameters
params: expr: (1 + 2) * 3 expected: 9 id: (1 + 2) * 3-9📌 Setup phase
duration:
0.00021240487694740295outcome:
passed📌 Call phase
duration:
0.00016593467444181442outcome:
passed📌 Teardown phase
duration:
0.00014377105981111526outcome:
passed -
✅ Test 174
params: expr="-(-3)", expected=3📌 Runtime Parameters
params: expr: -(-3) expected: 3 id: -(-3)-3📌 Setup phase
duration:
0.00022079376503825188outcome:
passed📌 Call phase
duration:
0.0001560240052640438outcome:
passed📌 Teardown phase
duration:
0.00013441499322652817outcome:
passed -
✅ Test 175
params: expr="-2 + 4 * 2", expected=6📌 Runtime Parameters
params: expr: -2 + 4 * 2 expected: 6 id: -2 + 4 * 2-6📌 Setup phase
duration:
0.0002192310057580471outcome:
passed📌 Call phase
duration:
0.00016169389709830284outcome:
passed📌 Teardown phase
duration:
0.0001370348036289215outcome:
passed -
✅ Test 176
params: expr="(4 + 5) * (6 - 1)", expected=45📌 Runtime Parameters
params: expr: (4 + 5) * (6 - 1) expected: 45 id: (4 + 5) * (6 - 1)-45📌 Setup phase
duration:
0.0002235393039882183outcome:
passed📌 Call phase
duration:
0.00016118306666612625outcome:
passed📌 Teardown phase
duration:
0.00015177996829152107outcome:
passed -
✅ Test 177
params: expr="(((3)))", expected=3📌 Runtime Parameters
params: expr: (((3))) expected: 3 id: (((3)))-3📌 Setup phase
duration:
0.00023361900821328163outcome:
passed📌 Call phase
duration:
0.00014943396672606468outcome:
passed📌 Teardown phase
duration:
0.00014218268916010857outcome:
passed -
✅ Test 178
params: expr="-(-(-2))", expected=-2📌 Runtime Parameters
params: expr: -(-(-2)) expected: -2 id: -(-(-2))--2📌 Setup phase
duration:
0.00022766506299376488outcome:
passed📌 Call phase
duration:
0.00015920214354991913outcome:
passed📌 Teardown phase
duration:
0.00013513676822185516outcome:
passed -
✅ Test 179
params: expr="3 + +4", expected=7📌 Runtime Parameters
params: expr: 3 + +4 expected: 7 id: 3 + +4-7📌 Setup phase
duration:
0.0002179727889597416outcome:
passed📌 Call phase
duration:
0.00017426209524273872outcome:
passed📌 Teardown phase
duration:
0.00015099532902240753outcome:
passed -
✅ Test 180
params: expr="3 + -4", expected=-1📌 Runtime Parameters
params: expr: 3 + -4 expected: -1 id: 3 + -4--1📌 Setup phase
duration:
0.00021370593458414078outcome:
passed📌 Call phase
duration:
0.000151114072650671outcome:
passed📌 Teardown phase
duration:
0.00013620266690850258outcome:
passed -
✅ Test 181
params: expr="True + 1", expected=2📌 Runtime Parameters
params: expr: True + 1 expected: 2 id: True + 1-2📌 Setup phase
duration:
0.00022248132154345512outcome:
passed📌 Call phase
duration:
0.00015350105240941048outcome:
passed📌 Teardown phase
duration:
0.00013808207586407661outcome:
passed -
✅ Test 182
params: expr="'string'", expected="string"📌 Runtime Parameters
params: expr: 'string' expected: string id: 'string'-string📌 Setup phase
duration:
0.00021067773923277855outcome:
passed📌 Call phase
duration:
0.000158652663230896outcome:
passed📌 Teardown phase
duration:
0.00013837870210409164outcome:
passed -
✅ Test 183
params: expr="1e1000 * 1e1000", expected=Infinity📌 Runtime Parameters
params: expr: 1e1000 * 1e1000 expected: inf id: 1e1000 * 1e1000-inf📌 Setup phase
duration:
0.00021600211039185524outcome:
passed📌 Call phase
duration:
0.0001610228791832924outcome:
passed📌 Teardown phase
duration:
0.00014421483501791954outcome:
passed -
✅ Test 184
params: expr="'a' + 'b'", expected="ab"📌 Runtime Parameters
params: expr: 'a' + 'b' expected: ab id: 'a' + 'b'-ab📌 Setup phase
duration:
0.00021902518346905708outcome:
passed📌 Call phase
duration:
0.0001535927876830101outcome:
passed📌 Teardown phase
duration:
0.00013503478839993477outcome:
passed
↳ Function: test_arithmetic_eval_raises_with_message
-
✅ Test 185
params: expr="2 ** 3", expected_message="Unsupported BinOp Pow"📌 Runtime Parameters
params: expr: 2 ** 3 expected_message: Unsupported BinOp Pow id: 2 ** 3-Unsupported BinOp Pow📌 Setup phase
duration:
0.000236614141613245outcome:
passed📌 Call phase
duration:
0.0004273317754268646outcome:
passed📌 Teardown phase
duration:
0.00014558341354131699outcome:
passed -
✅ Test 186
params: expr="3 << 1", expected_message="Unsupported BinOp LShift"📌 Runtime Parameters
params: expr: 3 << 1 expected_message: Unsupported BinOp LShift id: 3 << 1-Unsupported BinOp LShift📌 Setup phase
duration:
0.00023097172379493713outcome:
passed📌 Call phase
duration:
0.0003780587576329708outcome:
passed📌 Teardown phase
duration:
0.00015087798237800598outcome:
passed -
✅ Test 187
params: expr="1 < 2", expected_message="Unsupported node type Compare"📌 Runtime Parameters
params: expr: 1 < 2 expected_message: Unsupported node type Compare id: 1 < 2-Unsupported node type Compare📌 Setup phase
duration:
0.00024167681112885475outcome:
passed📌 Call phase
duration:
0.0003737262450158596outcome:
passed📌 Teardown phase
duration:
0.00016956543549895287outcome:
passed -
✅ Test 188
params: expr="abs(3)", expected_message="Unsupported node type Call"📌 Runtime Parameters
params: expr: abs(3) expected_message: Unsupported node type Call id: abs(3)-Unsupported node type Call📌 Setup phase
duration:
0.00022778520360589027outcome:
passed📌 Call phase
duration:
0.0003405897878110409outcome:
passed📌 Teardown phase
duration:
0.0001575700007379055outcome:
passed -
✅ Test 189
params: expr="a + 2", expected_message="Unsupported node type Name"📌 Runtime Parameters
params: expr: a + 2 expected_message: Unsupported node type Name id: a + 2-Unsupported node type Name📌 Setup phase
duration:
0.0002249232493340969outcome:
passed📌 Call phase
duration:
0.0003492371179163456outcome:
passed📌 Teardown phase
duration:
0.00013961084187030792outcome:
passed -
✅ Test 190
params: expr="string", expected_message="Unsupported node type Name"📌 Runtime Parameters
params: expr: string expected_message: Unsupported node type Name id: string-Unsupported node type Name📌 Setup phase
duration:
0.0002506440505385399outcome:
passed📌 Call phase
duration:
0.0002809986472129822outcome:
passed📌 Teardown phase
duration:
0.0001451447606086731outcome:
passed -
✅ Test 191
params: expr="[1, 2] + [3]", expected_message="Unsupported node type List"📌 Runtime Parameters
params: expr: [1, 2] + [3] expected_message: Unsupported node type List id: [1, 2] + [3]-Unsupported node type List📌 Setup phase
duration:
0.0002287682145833969outcome:
passed📌 Call phase
duration:
0.0003720158711075783outcome:
passed📌 Teardown phase
duration:
0.00015847990289330482outcome:
passed -
✅ Test 192
params: expr="{1: 2}", expected_message="Unsupported node type Dict"📌 Runtime Parameters
params: expr: {1: 2} expected_message: Unsupported node type Dict id: {1: 2}-Unsupported node type Dict📌 Setup phase
duration:
0.00022818194702267647outcome:
passed📌 Call phase
duration:
0.0003494489938020706outcome:
passed📌 Teardown phase
duration:
0.0001464439556002617outcome:
passed
↳ Function: test_arithmetic_eval_runtime_errors
-
✅ Test 193
params: expr="1 / 0", exception=""📌 Runtime Parameters
params: expr: 1 / 0 exception: <class 'ZeroDivisionError'> id: 1 / 0-ZeroDivisionError📌 Setup phase
duration:
0.0002391948364675045outcome:
passed📌 Call phase
duration:
0.00018133409321308136outcome:
passed📌 Teardown phase
duration:
0.00014562718570232391outcome:
passed -
✅ Test 194
params: expr="10 % 0", exception=""📌 Runtime Parameters
params: expr: 10 % 0 exception: <class 'ZeroDivisionError'> id: 10 % 0-ZeroDivisionError📌 Setup phase
duration:
0.00023329630494117737outcome:
passed📌 Call phase
duration:
0.0001702890731394291outcome:
passed📌 Teardown phase
duration:
0.0001373416744172573outcome:
passed
↳ Function: test_forgiving_eval
-
✅ Test 195
params: expr="1 + 2", expected=3📌 Runtime Parameters
params: expr: 1 + 2 expected: 3 id: 1 + 2-3📌 Setup phase
duration:
0.00023129303008317947outcome:
passed📌 Call phase
duration:
0.00015754997730255127outcome:
passed📌 Teardown phase
duration:
0.00014301296323537827outcome:
passed -
✅ Test 196
params: expr="bad + 2", expected="bad + 2"📌 Runtime Parameters
params: expr: bad + 2 expected: bad + 2 id: bad + 2-bad + 2📌 Setup phase
duration:
0.0002124798484146595outcome:
passed📌 Call phase
duration:
0.00015486637130379677outcome:
passed📌 Teardown phase
duration:
0.00014009792357683182outcome:
passed -
✅ Test 197
params: expr="1 / 0", expected="1 / 0"📌 Runtime Parameters
params: expr: 1 / 0 expected: 1 / 0 id: 1 / 0-1 / 0📌 Setup phase
duration:
0.0002267998643219471outcome:
passed📌 Call phase
duration:
0.00015753880143165588outcome:
passed📌 Teardown phase
duration:
0.0001476537436246872outcome:
passed -
✅ Test 198
params: expr="2 ** 10", expected="2 ** 10"📌 Runtime Parameters
params: expr: 2 ** 10 expected: 2 ** 10 id: 2 ** 10-2 ** 10📌 Setup phase
duration:
0.00021289987489581108outcome:
passed📌 Call phase
duration:
0.00015136180445551872outcome:
passed📌 Teardown phase
duration:
0.00014369329437613487outcome:
passed
↳ Function: test_defaulting_eval
-
✅ Test 199
params: expr="3 * 4", default=0, expected=12📌 Runtime Parameters
params: expr: 3 * 4 default: 0 expected: 12 id: 3 * 4-0-12📌 Setup phase
duration:
0.0002647130750119686outcome:
passed📌 Call phase
duration:
0.00016347086057066917outcome:
passed📌 Teardown phase
duration:
0.00014952197670936584outcome:
passed -
✅ Test 200
params: expr="invalid + 1", default=99, expected=99📌 Runtime Parameters
params: expr: invalid + 1 default: 99 expected: 99 id: invalid + 1-99-99📌 Setup phase
duration:
0.0002868971787393093outcome:
passed📌 Call phase
duration:
0.00020135240629315376outcome:
passed📌 Teardown phase
duration:
0.00015606964007019997outcome:
passed -
✅ Test 201
params: expr="1 / 0", default=-1, expected=-1📌 Runtime Parameters
params: expr: 1 / 0 default: -1 expected: -1 id: 1 / 0--1--1📌 Setup phase
duration:
0.0002671019174158573outcome:
passed📌 Call phase
duration:
0.00016134092584252357outcome:
passed📌 Teardown phase
duration:
0.0001533101312816143outcome:
passed -
✅ Test 202
params: expr="2 ** 10", default=42, expected=42📌 Runtime Parameters
params: expr: 2 ** 10 default: 42 expected: 42 id: 2 ** 10-42-42📌 Setup phase
duration:
0.0002606138586997986outcome:
passed📌 Call phase
duration:
0.00015910807996988297outcome:
passed📌 Teardown phase
duration:
0.0001507052220404148outcome:
passed
-
-
📄 test_utils_exceptions.py
↳ Function: test_chained_exception_various
-
✅ Test 203
params: func="", expected_output="High-level task failed\ncaused by KeyError: 'missing'"📌 Runtime Parameters
params: func: <function cause_key_error at 0x7f0d90718d30> expected_output: High-level task failed caused by KeyError: 'missing' id: cause_key_error-High-level task failed\ncaused by KeyError: 'missing'📌 Setup phase
duration:
0.00024035712704062462outcome:
passed📌 Call phase
duration:
0.00016114208847284317outcome:
passed📌 Teardown phase
duration:
0.0001394650898873806outcome:
passed -
✅ Test 204
params: func="", expected_output="High-level task failed\ncaused by IndexError: list index out of range"📌 Runtime Parameters
params: func: <function cause_index_error at 0x7f0d90718e50> expected_output: High-level task failed caused by IndexError: list index out of range id: cause_index_error-High-level task failed\ncaused by IndexError: list index out of range📌 Setup phase
duration:
0.00023984117433428764outcome:
passed📌 Call phase
duration:
0.00016365386545658112outcome:
passed📌 Teardown phase
duration:
0.0001400727778673172outcome:
passed -
✅ Test 205
params: func="", expected_output="High-level task failed\ncaused by ZeroDivisionError: division by zero"📌 Runtime Parameters
params: func: <function cause_zero_division at 0x7f0d90718ee0> expected_output: High-level task failed caused by ZeroDivisionError: division by zero id: cause_zero_division-High-level task failed\ncaused by ZeroDivisionError: division by zero📌 Setup phase
duration:
0.00021496694535017014outcome:
passed📌 Call phase
duration:
0.00016783829778432846outcome:
passed📌 Teardown phase
duration:
0.00013575004413723946outcome:
passed -
✅ Test 206
params: func="", expected_output="High-level task failed\ncaused by ValueError: invalid literal for int() with base 10: 'not_a_number'"📌 Runtime Parameters
params: func: <function cause_value_error at 0x7f0d90718f70> expected_output: High-level task failed caused by ValueError: invalid literal for int() with base 10: 'not_a_number' id: cause_value_error-High-level task failed\ncaused by ValueError: invalid literal for int() with base 10: 'not_a_number'📌 Setup phase
duration:
0.00022240029647946358outcome:
passed📌 Call phase
duration:
0.0001510055735707283outcome:
passed📌 Teardown phase
duration:
0.00013711676001548767outcome:
passed -
✅ Test 207
params: func="", expected_output="High-level task failed\ncaused by TypeError: can only concatenate str (not \"int\") to str"📌 Runtime Parameters
params: func: <function cause_type_error at 0x7f0de3b7c040> expected_output: High-level task failed caused by TypeError: can only concatenate str (not "int") to str id: cause_type_error-High-level task failed\ncaused by TypeError: can only concatenate str (not "int") to str📌 Setup phase
duration:
0.00022150017321109772outcome:
passed📌 Call phase
duration:
0.00014411984011530876outcome:
passed📌 Teardown phase
duration:
0.00014683464542031288outcome:
passed
↳ Function: test_printed_exception
-
✅ Test 208
params: func="", expected_output="KeyError: 'missing'"📌 Runtime Parameters
params: func: <function cause_key_error at 0x7f0d90718d30> expected_output: KeyError: 'missing' id: cause_key_error-KeyError: 'missing'📌 Setup phase
duration:
0.0007731672376394272outcome:
passed📌 Call phase
duration:
0.0015089251101016998outcome:
passed📌 Teardown phase
duration:
0.00044937990605831146outcome:
passed -
✅ Test 209
params: func="", expected_output="IndexError: list index out of range"📌 Runtime Parameters
params: func: <function cause_index_error at 0x7f0d90718e50> expected_output: IndexError: list index out of range id: cause_index_error-IndexError: list index out of range📌 Setup phase
duration:
0.0005664457567036152outcome:
passed📌 Call phase
duration:
0.0008978592231869698outcome:
passed📌 Teardown phase
duration:
0.00043830694630742073outcome:
passed -
✅ Test 210
params: func="", expected_output="ZeroDivisionError: division by zero"📌 Runtime Parameters
params: func: <function cause_zero_division at 0x7f0d90718ee0> expected_output: ZeroDivisionError: division by zero id: cause_zero_division-ZeroDivisionError: division by zero📌 Setup phase
duration:
0.000569415744394064outcome:
passed📌 Call phase
duration:
0.0008301520720124245outcome:
passed📌 Teardown phase
duration:
0.0004372638650238514outcome:
passed -
✅ Test 211
params: func="", expected_output="ValueError: invalid literal for int() with base 10: 'not_a_number'"📌 Runtime Parameters
params: func: <function cause_value_error at 0x7f0d90718f70> expected_output: ValueError: invalid literal for int() with base 10: 'not_a_number' id: cause_value_error-ValueError: invalid literal for int() with base 10: 'not_a_number'📌 Setup phase
duration:
0.0005536200478672981outcome:
passed📌 Call phase
duration:
0.0010158950462937355outcome:
passed📌 Teardown phase
duration:
0.00044382689520716667outcome:
passed -
✅ Test 212
params: func="", expected_output="TypeError: can only concatenate str (not \"int\") to str"📌 Runtime Parameters
params: func: <function cause_type_error at 0x7f0de3b7c040> expected_output: TypeError: can only concatenate str (not "int") to str id: cause_type_error-TypeError: can only concatenate str (not "int") to str📌 Setup phase
duration:
0.0005395771004259586outcome:
passed📌 Call phase
duration:
0.0009237881749868393outcome:
passed📌 Teardown phase
duration:
0.0004147919826209545outcome:
passed
-
-
📄 test_utils_get_adj.py
↳ Function: test_get_adj_success
-
✅ Test 213
📌 Setup phase
duration:
0.00015404075384140015outcome:
passed📌 Call phase
duration:
0.0009008343331515789outcome:
passed📌 Teardown phase
duration:
0.0001156199723482132outcome:
passed
↳ Function: test_get_adj_not_found
-
✅ Test 214
📌 Setup phase
duration:
0.0004852740094065666outcome:
passed📌 Call phase
duration:
0.0009402907453477383outcome:
passed📌 Teardown phase
duration:
0.00037468504160642624outcome:
passed
↳ Function: test_ensure_adjs_mixed
-
✅ Test 215
📌 Setup phase
duration:
0.0001280447468161583outcome:
passed📌 Call phase
duration:
0.000788872130215168outcome:
passed📌 Teardown phase
duration:
0.00011301832273602486outcome:
passed
↳ Function: test_get_adjs_filter
-
✅ Test 216
📌 Setup phase
duration:
0.00012946408241987228outcome:
passed📌 Call phase
duration:
0.0008826549164950848outcome:
passed📌 Teardown phase
duration:
0.00011645490303635597outcome:
passed
-
-
📄 test_utils_hastyepics.py
↳ Function: test_motor_invalid_name_raises
-
✅ Test 219
📌 Setup phase
duration:
0.00013306643813848495outcome:
passed📌 Call phase
duration:
0.00025648484006524086outcome:
passed📌 Teardown phase
duration:
0.00011428631842136383outcome:
passed
↳ Function: test_motor_init_list_has_no_disabled
-
✅ Test 220
📌 Setup phase
duration:
0.00013128621503710747outcome:
passed📌 Call phase
duration:
0.00014539295807480812outcome:
passed📌 Teardown phase
duration:
0.00010029412806034088outcome:
passed
↳ Function: test_motor_pv_connection_skipped_by_default
-
✅ Test 222
📌 Setup phase
duration:
0.00013306085020303726outcome:
passed📌 Call phase
duration:
0.0003620968200266361outcome:
passed📌 Teardown phase
duration:
0.00011333636939525604outcome:
passed
↳ Function: test_motor_adds_all_extras_pvs
-
✅ Test 223
📌 Setup phase
duration:
0.00011406512930989265outcome:
passed📌 Call phase
duration:
0.0003503761254251003outcome:
passed📌 Teardown phase
duration:
0.00010453583672642708outcome:
passed
↳ Function: test_motor_PV_method_exists_and_works
-
✅ Test 224
📌 Setup phase
duration:
0.00010716123506426811outcome:
passed📌 Call phase
duration:
0.00034276116639375687outcome:
passed📌 Teardown phase
duration:
0.0001245979219675064outcome:
passed
-
-
📄 test_utils_ipy.py
↳ Function: test_devices_repr_fallback_and_ignore
-
✅ Test 225
📌 Setup phase
duration:
0.0007972060702741146outcome:
passed📌 Call phase
duration:
0.0008457638323307037outcome:
passed📌 Teardown phase
duration:
0.00025950418785214424outcome:
passed
-
-
📄 test_utils_jsonext.py
↳ Function: test_json_validate_save_load
-
✅ Test 226
params: input_obj="[1 2 3]", expected=[1, 2, 3]📌 Runtime Parameters
params: input_obj: [1 2 3] expected: - 1 - 2 - 3 id: input_obj0-expected0📌 Setup phase
duration:
0.0009571211412549019outcome:
passed📌 Call phase
duration:
0.0006897151470184326outcome:
passed📌 Teardown phase
duration:
0.00019897613674402237outcome:
passed -
✅ Test 227
params: input_obj="42", expected=42📌 Runtime Parameters
params: input_obj: 42 expected: 42 id: input_obj1-42📌 Setup phase
duration:
0.000677421223372221outcome:
passed📌 Call phase
duration:
0.0004244418814778328outcome:
passed📌 Teardown phase
duration:
0.00018501468002796173outcome:
passed -
✅ Test 228
params: input_obj="(1-1j)", expected={"real": 1.0, "imag": -1.0}📌 Runtime Parameters
params: input_obj: (1-1j) expected: real: 1.0 imag: -1.0 id: (1-1j)-expected2📌 Setup phase
duration:
0.0006349170580506325outcome:
passed📌 Call phase
duration:
0.0004132632166147232outcome:
passed📌 Teardown phase
duration:
0.0001815417781472206outcome:
passed -
✅ Test 229
params: input_obj="/tmp/file.txt", expected="/tmp/file.txt"📌 Runtime Parameters
params: input_obj: /tmp/file.txt expected: /tmp/file.txt id: input_obj3-/tmp/file.txt📌 Setup phase
duration:
0.0006156708113849163outcome:
passed📌 Call phase
duration:
0.0003827088512480259outcome:
passed📌 Teardown phase
duration:
0.00017452798783779144outcome:
passed -
✅ Test 230
params: input_obj="{1, 2, 3}", expected=[1, 2, 3]📌 Runtime Parameters
params: input_obj: {1, 2, 3} expected: - 1 - 2 - 3 id: input_obj4-expected4📌 Setup phase
duration:
0.0006064320914447308outcome:
passed📌 Call phase
duration:
0.0003816313110291958outcome:
passed📌 Teardown phase
duration:
0.00021318579092621803outcome:
passed -
✅ Test 231
params: input_obj="{'a': array([10, 20])}", expected={"a": [10, 20]}📌 Runtime Parameters
params: input_obj: {'a': array([10, 20])} expected: a: - 10 - 20 id: input_obj5-expected5📌 Setup phase
duration:
0.0005963458679616451outcome:
passed📌 Call phase
duration:
0.0003846418112516403outcome:
passed📌 Teardown phase
duration:
0.0002154349349439144outcome:
passed -
✅ Test 232
params: input_obj="{'c': (2+3j)}", expected={"c": {"real": 2.0, "imag": 3.0}}📌 Runtime Parameters
params: input_obj: {'c': (2+3j)} expected: c: real: 2.0 imag: 3.0 id: input_obj6-expected6📌 Setup phase
duration:
0.0006142761558294296outcome:
passed📌 Call phase
duration:
0.0005030189640820026outcome:
passed📌 Teardown phase
duration:
0.00022882595658302307outcome:
passed -
✅ Test 233
params: input_obj="{'nested': {'arr': array(10, 20],\n [30, 40), 'complex_num': (-1+5j), 'files': [PosixPath('/file1'), PosixPath('/file2')], 'set_values': {200, 100}, 'inner': {'num': 7}}}", expected={"nested": {"arr": 10, 20], [30, 40, "complex_num": {"real": -1.0, "imag": 5.0}, "files": ["/file1", "/file2"], "set_values": [100, 200], "inner": {"num": 7}}}📌 Runtime Parameters
params: input_obj: {'nested': {'arr': array([[10, 20], [30, 40]]), 'complex_num': (-1+5j), 'files': [PosixPath('/file1'), PosixPath('/file2')], 'set_values': {200, 100}, 'inner': {'num': 7}}} expected: nested: arr: - - 10 - 20 - - 30 - 40 complex_num: real: -1.0 imag: 5.0 files: - /file1 - /file2 set_values: - 100 - 200 inner: num: 7 id: input_obj7-expected7📌 Setup phase
duration:
0.0005732248537242413outcome:
passed📌 Call phase
duration:
0.0005690688267350197outcome:
passed📌 Teardown phase
duration:
0.00020384090021252632outcome:
passed
-
-
📄 test_utils_lazypv.py
↳ Function: test_getattr
-
✅ Test 234
📌 Setup phase
duration:
0.0001323837786912918outcome:
passed📌 Call phase
duration:
0.0003018118441104889outcome:
passed📌 Teardown phase
duration:
0.00012094900012016296outcome:
passed
-
-
📄 test_utils_logcfg.py
↳ Function: test_custom_log_outputs
-
✅ Test 235
params: levelname="LONG", logfunc=" at 0x7f0de39cb790>", message="This is a LONG message"📌 Runtime Parameters
params: levelname: LONG logfunc: <function <lambda> at 0x7f0de39cb790> message: This is a LONG message id: LONG-<lambda>-This is a LONG message📌 Setup phase
duration:
0.0015600929036736488outcome:
passed📌 Call phase
duration:
0.0008063348941504955outcome:
passed📌 Teardown phase
duration:
0.00024360790848731995outcome:
passed -
✅ Test 236
params: levelname="ENLARGE", logfunc=" at 0x7f0de39cb820>", message="Please ENLARGE this!"📌 Runtime Parameters
params: levelname: ENLARGE logfunc: <function <lambda> at 0x7f0de39cb820> message: Please ENLARGE this! id: ENLARGE-<lambda>-Please ENLARGE this!📌 Setup phase
duration:
0.0003950130194425583outcome:
passed📌 Call phase
duration:
0.0004552961327135563outcome:
passed📌 Teardown phase
duration:
0.00022804224863648415outcome:
passed
-
-
📄 test_utils_logign.py
↳ Function: test_ignore_log_msg_behavior
-
✅ Test 238
params: levelname="WARNING", msg_to_ignore="This should be ignored", msg_to_keep="This should appear"📌 Runtime Parameters
params: levelname: WARNING msg_to_ignore: This should be ignored msg_to_keep: This should appear id: WARNING-This should be ignored-This should appear📌 Setup phase
duration:
0.0009364797733724117outcome:
passed📌 Call phase
duration:
0.0011480371467769146outcome:
passed📌 Teardown phase
duration:
0.0003821137361228466outcome:
passed -
✅ Test 239
params: levelname="ENLARGE", msg_to_ignore="ENLARGE this", msg_to_keep="Keep this ENLARGE"📌 Runtime Parameters
params: levelname: ENLARGE msg_to_ignore: ENLARGE this msg_to_keep: Keep this ENLARGE id: ENLARGE-ENLARGE this-Keep this ENLARGE📌 Setup phase
duration:
0.0006205551326274872outcome:
passed📌 Call phase
duration:
0.0007046088576316833outcome:
passed📌 Teardown phase
duration:
0.0003718077205121517outcome:
passed
↳ Function: test_ignore_only_by_level
-
✅ Test 240
📌 Setup phase
duration:
0.00042107095941901207outcome:
passed📌 Call phase
duration:
0.0006047869101166725outcome:
passed📌 Teardown phase
duration:
0.000268526840955019outcome:
passed
↳ Function: test_ignore_only_by_msg
-
✅ Test 241
📌 Setup phase
duration:
0.0003984123468399048outcome:
passed📌 Call phase
duration:
0.0005769510753452778outcome:
passed📌 Teardown phase
duration:
0.000259599182754755outcome:
passed
↳ Function: test_filter_removed_after_context
-
✅ Test 242
📌 Setup phase
duration:
0.0003549708053469658outcome:
passed📌 Call phase
duration:
0.0005592969246208668outcome:
passed📌 Teardown phase
duration:
0.00026419060304760933outcome:
passed
-
-
📄 test_utils_metaclasses.py
↳ Function: test_combine_classes_combines_methods
-
✅ Test 243
📌 Setup phase
duration:
0.0002009999006986618outcome:
passed📌 Call phase
duration:
0.00030962424352765083outcome:
passed📌 Teardown phase
duration:
0.00016169296577572823outcome:
passed
↳ Function: test_registryabc_combines_registrymeta_and_abcmeta
-
✅ Test 244
📌 Setup phase
duration:
0.00018340302631258965outcome:
passed📌 Call phase
duration:
0.006754570174962282outcome:
passed📌 Teardown phase
duration:
0.00019518565386533737outcome:
passed
-
-
📄 test_utils_namespace.py
↳ Function: test_namespace_pretty_repr_mixed_and_nested
-
✅ Test 245
📌 Setup phase
duration:
0.00021047703921794891outcome:
passed📌 Call phase
duration:
0.0004457053728401661outcome:
passed📌 Teardown phase
duration:
0.00018344121053814888outcome:
passed
-
-
📄 test_utils_npy.py
↳ Function: test_nice_arange
-
✅ Test 246
params: start=0, stop=5, step=1, expected="[0. 1. 2. 3. 4. 5.]"📌 Runtime Parameters
params: start: 0 stop: 5 step: 1 expected: [0. 1. 2. 3. 4. 5.] id: 0-5-1-expected0📌 Setup phase
duration:
0.000554187223315239outcome:
passed📌 Call phase
duration:
0.024939272087067366outcome:
passed📌 Teardown phase
duration:
0.000250084325671196outcome:
passed -
✅ Test 248
params: start=1, stop=2, step=0.3, expected="[1. 1.33333333 1.66666667 2. ]"📌 Runtime Parameters
params: start: 1 stop: 2 step: 0.3 expected: [1. 1.33333333 1.66666667 2. ] id: 1-2-0.3-expected2📌 Setup phase
duration:
0.000368485227227211outcome:
passed📌 Call phase
duration:
0.0004216018132865429outcome:
passed📌 Teardown phase
duration:
0.00019950233399868011outcome:
passed
↳ Function: test_nice_linspace
-
✅ Test 251
params: start=0, stop=10, num=4, expected="[ 0. 2.5 5. 7.5 10. ]"📌 Runtime Parameters
params: start: 0 stop: 10 num: 4 expected: [ 0. 2.5 5. 7.5 10. ] id: 0-10-4-expected0📌 Setup phase
duration:
0.00036449916660785675outcome:
passed📌 Call phase
duration:
0.0004437258467078209outcome:
passed📌 Teardown phase
duration:
0.00020115915685892105outcome:
passed -
✅ Test 252
params: start=5, stop=15, num=2, expected="[ 5. 10. 15.]"📌 Runtime Parameters
params: start: 5 stop: 15 num: 2 expected: [ 5. 10. 15.] id: 5-15-2-expected1📌 Setup phase
duration:
0.00034860894083976746outcome:
passed📌 Call phase
duration:
0.00037694815546274185outcome:
passed📌 Teardown phase
duration:
0.0001930571161210537outcome:
passed -
✅ Test 253
params: start=-5, stop=5, num=4, expected="[-5. -2.5 0. 2.5 5. ]"📌 Runtime Parameters
params: start: -5 stop: 5 num: 4 expected: [-5. -2.5 0. 2.5 5. ] id: -5-5-4-expected2📌 Setup phase
duration:
0.00034363334998488426outcome:
passed📌 Call phase
duration:
0.0003300127573311329outcome:
passed📌 Teardown phase
duration:
0.00019190600141882896outcome:
passed -
✅ Test 254
params: start=0, stop=1, num=3, expected="[0. 0.33333333 0.66666667 1. ]"📌 Runtime Parameters
params: start: 0 stop: 1 num: 3 expected: [0. 0.33333333 0.66666667 1. ] id: 0-1-3-expected3📌 Setup phase
duration:
0.00035196682438254356outcome:
passed📌 Call phase
duration:
0.00034100189805030823outcome:
passed📌 Teardown phase
duration:
0.0001998026855289936outcome:
passed -
✅ Test 255
params: start=2, stop=2, num=3, expected="[2. 2. 2. 2.]"📌 Runtime Parameters
params: start: 2 stop: 2 num: 3 expected: [2. 2. 2. 2.] id: 2-2-3-expected4📌 Setup phase
duration:
0.00033360719680786133outcome:
passed📌 Call phase
duration:
0.00036454619839787483outcome:
passed📌 Teardown phase
duration:
0.00018344121053814888outcome:
passed -
✅ Test 256
params: start=3, stop=0, num=3, expected="[3. 2. 1. 0.]"📌 Runtime Parameters
params: start: 3 stop: 0 num: 3 expected: [3. 2. 1. 0.] id: 3-0-3-expected5📌 Setup phase
duration:
0.0003332863561809063outcome:
passed📌 Call phase
duration:
0.00035795336589217186outcome:
passed📌 Teardown phase
duration:
0.00018297601491212845outcome:
passed -
✅ Test 257
params: start=0, stop=1, num=0, expected="[0.]"📌 Runtime Parameters
params: start: 0 stop: 1 num: 0 expected: [0.] id: 0-1-0-expected6📌 Setup phase
duration:
0.0003463178873062134outcome:
passed📌 Call phase
duration:
0.00035310257226228714outcome:
passed📌 Teardown phase
duration:
0.0002076965756714344outcome:
passed
↳ Function: test_nice_steps_centered
-
✅ Test 258
params: start=-2, stop=2, step=2, endpoint=true, expected="[-2. 0. 2.]"📌 Runtime Parameters
params: start: -2 stop: 2 step: 2 endpoint: True expected: [-2. 0. 2.] id: -2-2-2-True-expected0📌 Setup phase
duration:
0.00038473401218652725outcome:
passed📌 Call phase
duration:
0.0003889561630785465outcome:
passed📌 Teardown phase
duration:
0.00019932398572564125outcome:
passed -
✅ Test 259
params: start=0, stop=5, step=2, endpoint=true, expected="[0. 2. 4.]"📌 Runtime Parameters
params: start: 0 stop: 5 step: 2 endpoint: True expected: [0. 2. 4.] id: 0-5-2-True-expected1📌 Setup phase
duration:
0.00039000483229756355outcome:
passed📌 Call phase
duration:
0.00036113476380705833outcome:
passed📌 Teardown phase
duration:
0.0002096523530781269outcome:
passed -
✅ Test 260
params: start=0, stop=5, step=2, endpoint=false, expected="[0. 2.]"📌 Runtime Parameters
params: start: 0 stop: 5 step: 2 endpoint: False expected: [0. 2.] id: 0-5-2-False-expected2📌 Setup phase
duration:
0.0003971308469772339outcome:
passed📌 Call phase
duration:
0.00036152591928839684outcome:
passed📌 Teardown phase
duration:
0.0001994892954826355outcome:
passed -
✅ Test 261
params: start=-1, stop=2, step=1.5, endpoint=true, expected="[-1.5 0. 1.5]"📌 Runtime Parameters
params: start: -1 stop: 2 step: 1.5 endpoint: True expected: [-1.5 0. 1.5] id: -1-2-1.5-True-expected3📌 Setup phase
duration:
0.00039336923509836197outcome:
passed📌 Call phase
duration:
0.0003354582004249096outcome:
passed📌 Teardown phase
duration:
0.0002070819027721882outcome:
passed
↳ Function: test_nice_steps_left_aligned
-
✅ Test 264
params: start=-1, stop=2, step=1.5, endpoint=true, expected="[-1. 0.5 2. ]"📌 Runtime Parameters
params: start: -1 stop: 2 step: 1.5 endpoint: True expected: [-1. 0.5 2. ] id: -1-2-1.5-True-expected2📌 Setup phase
duration:
0.0004124268889427185outcome:
passed📌 Call phase
duration:
0.00044413888826966286outcome:
passed📌 Teardown phase
duration:
0.00023132283240556717outcome:
passed -
✅ Test 265
params: start=-1, stop=2, step=1.5, endpoint=false, expected="[-1. 0.5]"📌 Runtime Parameters
params: start: -1 stop: 2 step: 1.5 endpoint: False expected: [-1. 0.5] id: -1-2-1.5-False-expected3📌 Setup phase
duration:
0.00037434883415699005outcome:
passed📌 Call phase
duration:
0.0003770235925912857outcome:
passed📌 Teardown phase
duration:
0.00020264601334929466outcome:
passed
↳ Function: test_within_scalar
-
✅ Test 276
params: val=5, vmin=0, vmax=10, expected=true📌 Runtime Parameters
params: val: 5 vmin: 0 vmax: 10 expected: True id: 5-0-10-True📌 Setup phase
duration:
0.0003513079136610031outcome:
passed📌 Call phase
duration:
0.00015610596165060997outcome:
passed📌 Teardown phase
duration:
0.00017977971583604813outcome:
passed -
✅ Test 277
params: val=5, vmin=6, vmax=10, expected=false📌 Runtime Parameters
params: val: 5 vmin: 6 vmax: 10 expected: False id: 5-6-10-False📌 Setup phase
duration:
0.0003234618343412876outcome:
passed📌 Call phase
duration:
0.00014149071648716927outcome:
passed📌 Teardown phase
duration:
0.00017488235607743263outcome:
passed -
✅ Test 278
params: val=5, vmin=null, vmax=10, expected=true📌 Runtime Parameters
params: val: 5 vmin: None vmax: 10 expected: True id: 5-None-10-True📌 Setup phase
duration:
0.00029771262779831886outcome:
passed📌 Call phase
duration:
0.00014022085815668106outcome:
passed📌 Teardown phase
duration:
0.000166997779160738outcome:
passed -
✅ Test 279
params: val=5, vmin=0, vmax=null, expected=true📌 Runtime Parameters
params: val: 5 vmin: 0 vmax: None expected: True id: 5-0-None-True📌 Setup phase
duration:
0.000308335293084383outcome:
passed📌 Call phase
duration:
0.00014481507241725922outcome:
passed📌 Teardown phase
duration:
0.00016412418335676193outcome:
passed -
✅ Test 280
params: val=5, vmin=null, vmax=null, expected=true📌 Runtime Parameters
params: val: 5 vmin: None vmax: None expected: True id: 5-None-None-True📌 Setup phase
duration:
0.000329670961946249outcome:
passed📌 Call phase
duration:
0.00013848207890987396outcome:
passed📌 Teardown phase
duration:
0.00016399705782532692outcome:
passed
↳ Function: test_within_fraction
-
✅ Test 281
params: data=[1, 2, 3, 4, 5], vmin=2, vmax=5, expected=0.6📌 Runtime Parameters
params: data: - 1 - 2 - 3 - 4 - 5 vmin: 2 vmax: 5 expected: 0.6 id: data0-2-5-0.6📌 Setup phase
duration:
0.00031660404056310654outcome:
passed📌 Call phase
duration:
0.0003071990795433521outcome:
passed📌 Teardown phase
duration:
0.00019695935770869255outcome:
passed -
✅ Test 282
params: data=[10, 20, 30], vmin=5, vmax=25, expected=0.6666666666666666📌 Runtime Parameters
params: data: - 10 - 20 - 30 vmin: 5 vmax: 25 expected: 0.6666666666666666 id: data1-5-25-0.6666666666666666📌 Setup phase
duration:
0.00032696500420570374outcome:
passed📌 Call phase
duration:
0.0002536368556320667outcome:
passed📌 Teardown phase
duration:
0.00016997894272208214outcome:
passed -
✅ Test 283
params: data=[1, 2, 3], vmin=null, vmax=2, expected=0.3333333333333333📌 Runtime Parameters
params: data: - 1 - 2 - 3 vmin: None vmax: 2 expected: 0.3333333333333333 id: data2-None-2-0.3333333333333333📌 Setup phase
duration:
0.00033171987161040306outcome:
passed📌 Call phase
duration:
0.00022969767451286316outcome:
passed📌 Teardown phase
duration:
0.0001717102713882923outcome:
passed -
✅ Test 284
params: data=[], vmin=0, vmax=1, expected=0📌 Runtime Parameters
params: data: [] vmin: 0 vmax: 1 expected: 0 id: data3-0-1-0📌 Setup phase
duration:
0.00032786792144179344outcome:
passed📌 Call phase
duration:
0.0002360241487622261outcome:
passed📌 Teardown phase
duration:
0.00017214100807905197outcome:
passed
↳ Function: test_fraction_to_percentage
-
✅ Test 285
params: fraction=0.456, ndigits=1, expected=45.6📌 Runtime Parameters
params: fraction: 0.456 ndigits: 1 expected: 45.6 id: 0.456-1-45.6📌 Setup phase
duration:
0.0002719080075621605outcome:
passed📌 Call phase
duration:
0.0001546279527246952outcome:
passed📌 Teardown phase
duration:
0.00015674298629164696outcome:
passed -
✅ Test 286
params: fraction=0.12345, ndigits=2, expected=12.35📌 Runtime Parameters
params: fraction: 0.12345 ndigits: 2 expected: 12.35 id: 0.12345-2-12.35📌 Setup phase
duration:
0.0002819881774485111outcome:
passed📌 Call phase
duration:
0.00014060502871870995outcome:
passed📌 Teardown phase
duration:
0.00015558628365397453outcome:
passed -
✅ Test 287
params: fraction=0.9999, ndigits=0, expected=100.0📌 Runtime Parameters
params: fraction: 0.9999 ndigits: 0 expected: 100.0 id: 0.9999-0-100.0📌 Setup phase
duration:
0.00027289800345897675outcome:
passed📌 Call phase
duration:
0.00013826508074998856outcome:
passed📌 Teardown phase
duration:
0.0001456509344279766outcome:
passed
↳ Function: test_get_dtype
-
✅ Test 288
params: val="[1 2 3]", expected=""📌 Runtime Parameters
params: val: [1 2 3] expected: <class 'numpy.ndarray'> id: val0-ndarray📌 Setup phase
duration:
0.00021685892716050148outcome:
passed📌 Call phase
duration:
0.00014440994709730148outcome:
passed📌 Teardown phase
duration:
0.00015936000272631645outcome:
passed -
✅ Test 289
params: val=[1, 2, 3], expected=""📌 Runtime Parameters
params: val: - 1 - 2 - 3 expected: <class 'list'> id: val1-list📌 Setup phase
duration:
0.00023422017693519592outcome:
passed📌 Call phase
duration:
0.00014511076733469963outcome:
passed📌 Teardown phase
duration:
0.0001426483504474163outcome:
passed -
✅ Test 290
params: val=3.14, expected=""📌 Runtime Parameters
params: val: 3.14 expected: <class 'float'> id: 3.14-float📌 Setup phase
duration:
0.00021817395463585854outcome:
passed📌 Call phase
duration:
0.00013561220839619637outcome:
passed📌 Teardown phase
duration:
0.00015230942517518997outcome:
passed
↳ Function: test_get_shape
-
✅ Test 291
params: val="1 2]\n [3 4", expected=[2, 2]📌 Runtime Parameters
params: val: [[1 2] [3 4]] expected: - 2 - 2 id: val0-expected0📌 Setup phase
duration:
0.00022268202155828476outcome:
passed📌 Call phase
duration:
0.00014979997649788857outcome:
passed📌 Teardown phase
duration:
0.00014596711844205856outcome:
passed -
✅ Test 292
params: val=[1, 2, 3], expected=[]📌 Runtime Parameters
params: val: - 1 - 2 - 3 expected: [] id: val1-expected1📌 Setup phase
duration:
0.00024017691612243652outcome:
passed📌 Call phase
duration:
0.00014433590695261955outcome:
passed📌 Teardown phase
duration:
0.0001392662525177002outcome:
passed -
✅ Test 293
params: val=42, expected=[]📌 Runtime Parameters
params: val: 42 expected: [] id: 42-expected2📌 Setup phase
duration:
0.0002352348528802395outcome:
passed📌 Call phase
duration:
0.00013903621584177017outcome:
passed📌 Teardown phase
duration:
0.00013642804697155952outcome:
passed
↳ Function: test_is_array
-
✅ Test 294
params: val="[1 2 3]", expected=true📌 Runtime Parameters
params: val: [1 2 3] expected: True id: val0-True📌 Setup phase
duration:
0.00021696509793400764outcome:
passed📌 Call phase
duration:
0.00013210205361247063outcome:
passed📌 Teardown phase
duration:
0.0001561562530696392outcome:
passed -
✅ Test 295
params: val=[1, 2, 3], expected=false📌 Runtime Parameters
params: val: - 1 - 2 - 3 expected: False id: val1-False📌 Setup phase
duration:
0.00023807818070054054outcome:
passed📌 Call phase
duration:
0.0001394418068230152outcome:
passed📌 Teardown phase
duration:
0.00014687469229102135outcome:
passed -
✅ Test 296
params: val=42, expected=false📌 Runtime Parameters
params: val: 42 expected: False id: 42-False📌 Setup phase
duration:
0.00022451579570770264outcome:
passed📌 Call phase
duration:
0.00013693096116185188outcome:
passed📌 Teardown phase
duration:
0.00013972120359539986outcome:
passed
-
-
📄 test_utils_path.py
↳ Function: test_can_create_all_files_user_says_yes
-
✅ Test 297
📌 Setup phase
duration:
0.00011850101873278618outcome:
passed📌 Call phase
duration:
0.000660470686852932outcome:
passed📌 Teardown phase
duration:
0.00012206193059682846outcome:
passed
↳ Function: test_can_create_all_files_user_says_no
-
✅ Test 298
📌 Setup phase
duration:
0.00011760927736759186outcome:
passed📌 Call phase
duration:
0.0004024673253297806outcome:
passed📌 Teardown phase
duration:
0.0001230393536388874outcome:
passed
↳ Function: test_make_missing_dir_creates_folder
-
✅ Test 299
📌 Setup phase
duration:
0.00012114224955439568outcome:
passed📌 Call phase
duration:
0.0005526500754058361outcome:
passed📌 Teardown phase
duration:
0.00010984623804688454outcome:
passed
↳ Function: test_glob_files_returns_matching_files_only
-
✅ Test 300
📌 Setup phase
duration:
0.00011058803647756577outcome:
passed📌 Call phase
duration:
0.000963273923844099outcome:
passed📌 Teardown phase
duration:
0.00011661183089017868outcome:
passed
↳ Function: test_filter_files_excludes_directories
-
✅ Test 301
📌 Setup phase
duration:
0.00011895736679434776outcome:
passed📌 Call phase
duration:
0.000766220036894083outcome:
passed📌 Teardown phase
duration:
0.00011820998042821884outcome:
passed
-
-
📄 test_utils_picklio.py
↳ Function: test_pickle_and_unpickle
-
✅ Test 302
params: test_obj={"a": 1, "b": [2, 3], "c": {"world": "ok"}}📌 Runtime Parameters
params: test_obj: a: 1 b: - 2 - 3 c: world: ok id: test_obj0📌 Setup phase
duration:
0.0006103259511291981outcome:
passed📌 Call phase
duration:
0.00037737423554062843outcome:
passed📌 Teardown phase
duration:
0.0001717628911137581outcome:
passed -
✅ Test 303
params: test_obj=[1, 2, 3, 4, 5]📌 Runtime Parameters
params: test_obj: - 1 - 2 - 3 - 4 - 5 id: test_obj1📌 Setup phase
duration:
0.0005371896550059319outcome:
passed📌 Call phase
duration:
0.0003011757507920265outcome:
passed📌 Teardown phase
duration:
0.00016539497300982475outcome:
passed -
✅ Test 304
params: test_obj="simple string"📌 Runtime Parameters
params: test_obj: simple string id: simple string📌 Setup phase
duration:
0.0005394499748945236outcome:
passed📌 Call phase
duration:
0.0002757967449724674outcome:
passed📌 Teardown phase
duration:
0.0001604883000254631outcome:
passed -
✅ Test 305
params: test_obj=42📌 Runtime Parameters
params: test_obj: 42 id: 42📌 Setup phase
duration:
0.0006200503557920456outcome:
passed📌 Call phase
duration:
0.0002852831967175007outcome:
passed📌 Teardown phase
duration:
0.0001535383053123951outcome:
passed -
✅ Test 306
params: test_obj=3.14159📌 Runtime Parameters
params: test_obj: 3.14159 id: 3.14159📌 Setup phase
duration:
0.0005318811163306236outcome:
passed📌 Call phase
duration:
0.0003129751421511173outcome:
passed📌 Teardown phase
duration:
0.00015842774882912636outcome:
passed -
✅ Test 307
params: test_obj=[true, false, null]📌 Runtime Parameters
params: test_obj: - True - (vide) - (vide) id: test_obj5📌 Setup phase
duration:
0.0005756127648055553outcome:
passed📌 Call phase
duration:
0.00027783820405602455outcome:
passed📌 Teardown phase
duration:
0.00016622897237539291outcome:
passed -
✅ Test 308
params: test_obj={"complex": [{"list": [1, 2]}, {"dict": {"x": 10}}]}📌 Runtime Parameters
params: test_obj: complex: - list: - 1 - 2 - dict: x: 10 id: test_obj6📌 Setup phase
duration:
0.0005323481746017933outcome:
passed📌 Call phase
duration:
0.0002893512137234211outcome:
passed📌 Teardown phase
duration:
0.0001716427505016327outcome:
passed
-
-
📄 test_utils_printing.py
↳ Function: test_maxlen_valid
-
✅ Test 309
params: seq=["a", "abc", ""], expected=3📌 Runtime Parameters
params: seq: - a - abc - (vide) expected: 3 id: seq0-3📌 Setup phase
duration:
0.0002479548566043377outcome:
passed📌 Call phase
duration:
0.00014749262481927872outcome:
passed📌 Teardown phase
duration:
0.00020558619871735573outcome:
passed -
✅ Test 310
params: seq=[], expected=0📌 Runtime Parameters
params: seq: [] expected: 0 id: seq1-0📌 Setup phase
duration:
0.0002346578985452652outcome:
passed📌 Call phase
duration:
0.00015856418758630753outcome:
passed📌 Teardown phase
duration:
0.00013834284618496895outcome:
passed -
✅ Test 311
params: seq=1, 2], [3], [4, 5, 6, expected=3📌 Runtime Parameters
params: seq: - - 1 - 2 - - 3 - - 4 - 5 - 6 expected: 3 id: seq2-3📌 Setup phase
duration:
0.00022793840616941452outcome:
passed📌 Call phase
duration:
0.00018882984295487404outcome:
passed📌 Teardown phase
duration:
0.00014358805492520332outcome:
passed -
✅ Test 312
params: seq=[{"a": 2, "b": 3}, {}, {"c": 4}], expected=2📌 Runtime Parameters
params: seq: - a: 2 b: 3 - (vide) - c: 4 expected: 2 id: seq3-2📌 Setup phase
duration:
0.00022513605654239655outcome:
passed📌 Call phase
duration:
0.0001382129266858101outcome:
passed📌 Teardown phase
duration:
0.00013930583372712135outcome:
passed
↳ Function: test_strlen
-
✅ Test 313
params: value=42, expected=2📌 Runtime Parameters
params: value: 42 expected: 2 id: 42-2📌 Setup phase
duration:
0.00023322086781263351outcome:
passed📌 Call phase
duration:
0.00013596704229712486outcome:
passed📌 Teardown phase
duration:
0.00013289228081703186outcome:
passed -
✅ Test 314
params: value="hello", expected=5📌 Runtime Parameters
params: value: hello expected: 5 id: hello-5📌 Setup phase
duration:
0.00024702027440071106outcome:
passed📌 Call phase
duration:
0.00013849185779690742outcome:
passed📌 Teardown phase
duration:
0.00013859383761882782outcome:
passed -
✅ Test 315
params: value=false, expected=5📌 Runtime Parameters
params: value: False expected: 5 id: False-5📌 Setup phase
duration:
0.00021415622904896736outcome:
passed📌 Call phase
duration:
0.00013663014397025108outcome:
passed📌 Teardown phase
duration:
0.0001380513422191143outcome:
passed -
✅ Test 316
params: value=null, expected=4📌 Runtime Parameters
params: value: None expected: 4 id: None-4📌 Setup phase
duration:
0.0002209641970694065outcome:
passed📌 Call phase
duration:
0.0001310049556195736outcome:
passed📌 Teardown phase
duration:
0.00013299891725182533outcome:
passed -
✅ Test 317
params: value=[1, 2, 3], expected=9📌 Runtime Parameters
params: value: - 1 - 2 - 3 expected: 9 id: value4-9📌 Setup phase
duration:
0.00023150164633989334outcome:
passed📌 Call phase
duration:
0.00013912608847022057outcome:
passed📌 Teardown phase
duration:
0.0001531783491373062outcome:
passed -
✅ Test 318
params: value={"a": 1}, expected=8📌 Runtime Parameters
params: value: a: 1 expected: 8 id: value5-8📌 Setup phase
duration:
0.00021143024787306786outcome:
passed📌 Call phase
duration:
0.00013527506962418556outcome:
passed📌 Teardown phase
duration:
0.00014332681894302368outcome:
passed -
✅ Test 319
params: value=[1, 2], expected=6📌 Runtime Parameters
params: value: - 1 - 2 expected: 6 id: value6-6📌 Setup phase
duration:
0.00021702470257878304outcome:
passed📌 Call phase
duration:
0.00014139525592327118outcome:
passed📌 Teardown phase
duration:
0.00013435911387205124outcome:
passed -
✅ Test 320
params: value="", expected=0📌 Runtime Parameters
params: value: None expected: 0 id: -0📌 Setup phase
duration:
0.00022010086104273796outcome:
passed📌 Call phase
duration:
0.00014739902690052986outcome:
passed📌 Teardown phase
duration:
0.00013846484944224358outcome:
passed -
✅ Test 321
params: value="this is a phrase", expected=16📌 Runtime Parameters
params: value: this is a phrase expected: 16 id: this is a phrase-16📌 Setup phase
duration:
0.00021787220612168312outcome:
passed📌 Call phase
duration:
0.00014156894758343697outcome:
passed📌 Teardown phase
duration:
0.00022738194093108177outcome:
passed
↳ Function: test_maxstrlen
-
✅ Test 322
params: seq=[1, true, 3.1415], expected=6📌 Runtime Parameters
params: seq: - 1 - True - 3.1415 expected: 6 id: seq0-6📌 Setup phase
duration:
0.000247761607170105outcome:
passed📌 Call phase
duration:
0.0001512519083917141outcome:
passed📌 Teardown phase
duration:
0.00013718800619244576outcome:
passed -
✅ Test 323
params: seq=["aa", "bbb", "c"], expected=3📌 Runtime Parameters
params: seq: - aa - bbb - c expected: 3 id: seq1-3📌 Setup phase
duration:
0.00024410011246800423outcome:
passed📌 Call phase
duration:
0.00014564301818609238outcome:
passed📌 Teardown phase
duration:
0.00013657892122864723outcome:
passed -
✅ Test 324
params: seq=1, 2], [], [1, 2, 3, expected=9📌 Runtime Parameters
params: seq: - - 1 - 2 - (vide) - - 1 - 2 - 3 expected: 9 id: seq2-9📌 Setup phase
duration:
0.00021296599879860878outcome:
passed📌 Call phase
duration:
0.0001438581384718418outcome:
passed📌 Teardown phase
duration:
0.0001438697800040245outcome:
passed -
✅ Test 325
params: seq=[{"a": 1}, {}, {"a": 1, "b": 2}], expected=16📌 Runtime Parameters
params: seq: - a: 1 - (vide) - a: 1 b: 2 expected: 16 id: seq3-16📌 Setup phase
duration:
0.00021668104454874992outcome:
passed📌 Call phase
duration:
0.0001413668505847454outcome:
passed📌 Teardown phase
duration:
0.0001419377513229847outcome:
passed -
✅ Test 326
params: seq=[null, false, 12345], expected=5📌 Runtime Parameters
params: seq: - (vide) - (vide) - 12345 expected: 5 id: seq4-5📌 Setup phase
duration:
0.00022446410730481148outcome:
passed📌 Call phase
duration:
0.00020485883578658104outcome:
passed📌 Teardown phase
duration:
0.0001511853188276291outcome:
passed
↳ Function: test_transpose_matrix
-
✅ Test 327
params: data=1, 2], [3, 4, expected=1, 3], [2, 4📌 Runtime Parameters
params: data: - - 1 - 2 - - 3 - 4 expected: - - 1 - 3 - - 2 - 4 id: data0-expected0📌 Setup phase
duration:
0.00022391090169548988outcome:
passed📌 Call phase
duration:
0.00014491891488432884outcome:
passed📌 Teardown phase
duration:
0.00014482112601399422outcome:
passed -
✅ Test 328
params: data="a", "b"], ["c", "d", expected="a", "c"], ["b", "d"📌 Runtime Parameters
params: data: - - a - b - - c - d expected: - - a - c - - b - d id: data1-expected1📌 Setup phase
duration:
0.00023122131824493408outcome:
passed📌 Call phase
duration:
0.00014992710202932358outcome:
passed📌 Teardown phase
duration:
0.00014142412692308426outcome:
passed -
✅ Test 329
params: data={"x": 1}, {"y": 2}], [{"x": 3}, {"y": 4}, expected={"x": 1}, {"x": 3}], [{"y": 2}, {"y": 4}📌 Runtime Parameters
params: data: - - x: 1 - y: 2 - - x: 3 - y: 4 expected: - - x: 1 - x: 3 - - y: 2 - y: 4 id: data2-expected2📌 Setup phase
duration:
0.00021918397396802902outcome:
passed📌 Call phase
duration:
0.0001390618272125721outcome:
passed📌 Teardown phase
duration:
0.0001413491554558277outcome:
passed
↳ Function: test_prepend
-
✅ Test 330
params: initial=[1, 2, 3], prepend=1, expected=[1, 2, 3]📌 Runtime Parameters
params: initial: - 1 - 2 - 3 prepend: 1 expected: - 1 - 2 - 3 id: initial0-1-expected0📌 Setup phase
duration:
0.0002818237990140915outcome:
passed📌 Call phase
duration:
0.0001359749585390091outcome:
passed📌 Teardown phase
duration:
0.00014952896162867546outcome:
passed -
✅ Test 331
params: initial=["a", "b", "c"], prepend="a", expected=["a", "b", "c"]📌 Runtime Parameters
params: initial: - a - b - c prepend: a expected: - a - b - c id: initial1-a-expected1📌 Setup phase
duration:
0.0002964939922094345outcome:
passed📌 Call phase
duration:
0.0001417342573404312outcome:
passed📌 Teardown phase
duration:
0.00020254170522093773outcome:
passed -
✅ Test 332
params: initial=[{"a": 1}, {"b": 2}], prepend={"a": 1}, expected=[{"a": 1}, {"b": 2}]📌 Runtime Parameters
params: initial: - a: 1 - b: 2 prepend: a: 1 expected: - a: 1 - b: 2 id: initial2-prepend2-expected2📌 Setup phase
duration:
0.0002812640741467476outcome:
passed📌 Call phase
duration:
0.00017884280532598495outcome:
passed📌 Teardown phase
duration:
0.00019389670342206955outcome:
passed -
✅ Test 333
params: initial=1], [2], [3, prepend=[1], expected=1], [2], [3📌 Runtime Parameters
params: initial: - - 1 - - 2 - - 3 prepend: - 1 expected: - - 1 - - 2 - - 3 id: initial3-prepend3-expected3📌 Setup phase
duration:
0.0002721897326409817outcome:
passed📌 Call phase
duration:
0.00014683697372674942outcome:
passed📌 Teardown phase
duration:
0.00018649687990546227outcome:
passed
↳ Function: test_fmt_table_line
-
✅ Test 334
params: entries=["a", "bbb"], widths=[3, 5], expected=" a bbb"📌 Runtime Parameters
params: entries: - a - bbb widths: - 3 - 5 expected: a bbb id: entries0-widths0- a bbb📌 Setup phase
duration:
0.00029813870787620544outcome:
passed📌 Call phase
duration:
0.0001495862379670143outcome:
passed📌 Teardown phase
duration:
0.00020752428099513054outcome:
passed -
✅ Test 335
params: entries=[1, 2], widths=[2, 2], expected=" 1 2"📌 Runtime Parameters
params: entries: - 1 - 2 widths: - 2 - 2 expected: 1 2 id: entries1-widths1- 1 2📌 Setup phase
duration:
0.00028493301942944527outcome:
passed📌 Call phase
duration:
0.00015150709077715874outcome:
passed📌 Teardown phase
duration:
0.00018583517521619797outcome:
passed -
✅ Test 336
params: entries=["long", "val"], widths=[6, 4], expected=" long val"📌 Runtime Parameters
params: entries: - long - val widths: - 6 - 4 expected: long val id: entries2-widths2- long val📌 Setup phase
duration:
0.0004114140756428242outcome:
passed📌 Call phase
duration:
0.00025544315576553345outcome:
passed📌 Teardown phase
duration:
0.00027787964791059494outcome:
passed -
✅ Test 337
params: entries=[true, false], widths=[5, 6], expected=" True False"📌 Runtime Parameters
params: entries: - True - (vide) widths: - 5 - 6 expected: True False id: entries3-widths3- True False📌 Setup phase
duration:
0.00041447440162301064outcome:
passed📌 Call phase
duration:
0.0001650420017540455outcome:
passed📌 Teardown phase
duration:
0.00016392813995480537outcome:
passed -
✅ Test 338
params: entries=[123, 4567], widths=[5, 5], expected=" 123 4567"📌 Runtime Parameters
params: entries: - 123 - 4567 widths: - 5 - 5 expected: 123 4567 id: entries4-widths4- 123 4567📌 Setup phase
duration:
0.0003981180489063263outcome:
passed📌 Call phase
duration:
0.00021459581330418587outcome:
passed📌 Teardown phase
duration:
0.00025158701464533806outcome:
passed -
✅ Test 339
params: entries=["text with space", "end"], widths=[16, 5], expected=" text with space end"📌 Runtime Parameters
params: entries: - text with space - end widths: - 16 - 5 expected: text with space end id: entries5-widths5- text with space end📌 Setup phase
duration:
0.0004639490507543087outcome:
passed📌 Call phase
duration:
0.00024419184774160385outcome:
passed📌 Teardown phase
duration:
0.000263105146586895outcome:
passed -
✅ Test 340
params: entries=[{"a": 1}, {"b": 2}], widths=[10, 10], expected=" {'a': 1} {'b': 2}"📌 Runtime Parameters
params: entries: - a: 1 - b: 2 widths: - 10 - 10 expected: {'a': 1} {'b': 2} id: entries6-widths6- {'a': 1} {'b': 2}📌 Setup phase
duration:
0.0004681963473558426outcome:
passed📌 Call phase
duration:
0.0002644546329975128outcome:
passed📌 Teardown phase
duration:
0.00023739319294691086outcome:
passed -
✅ Test 341
params: entries=1, 2], [3, 4, widths=[10, 10], expected=" [1, 2] [3, 4]"📌 Runtime Parameters
params: entries: - - 1 - 2 - - 3 - 4 widths: - 10 - 10 expected: [1, 2] [3, 4] id: entries7-widths7- [1, 2] [3, 4]📌 Setup phase
duration:
0.0002957279793918133outcome:
passed📌 Call phase
duration:
0.0001544291153550148outcome:
passed📌 Teardown phase
duration:
0.00015517231076955795outcome:
passed
↳ Function: test_fmt_label_sep
-
✅ Test 342
params: widths=[3, 4], line="-", expected="--- ----"📌 Runtime Parameters
params: widths: - 3 - 4 line: - expected: --- ---- id: widths0------ ----📌 Setup phase
duration:
0.00026538409292697906outcome:
passed📌 Call phase
duration:
0.00017014099285006523outcome:
passed📌 Teardown phase
duration:
0.00021008215844631195outcome:
passed -
✅ Test 343
params: widths=[2, 3], line="=", expected="== ==="📌 Runtime Parameters
params: widths: - 2 - 3 line: = expected: == === id: widths1-=-== ===📌 Setup phase
duration:
0.0003328300081193447outcome:
passed📌 Call phase
duration:
0.00015154527500271797outcome:
passed📌 Teardown phase
duration:
0.00017249584197998047outcome:
passed -
✅ Test 344
params: widths=[5, 2], line="*", expected="***** **"📌 Runtime Parameters
params: widths: - 5 - 2 line: * expected: ***** ** id: widths2-*-***** **📌 Setup phase
duration:
0.00027952203527092934outcome:
passed📌 Call phase
duration:
0.00014826282858848572outcome:
passed📌 Teardown phase
duration:
0.00015663914382457733outcome:
passed
↳ Function: test_printable_dict_with_header
-
✅ Test 345
params: d={"medium": true, "very_long_key": 3.14, "x": 1}, header="HeaderTest", expected_lines=["HeaderTest:", "-----------", "medium: True", "very_long_key: 3.14", "x: 1", ""]📌 Runtime Parameters
params: d: medium: True very_long_key: 3.14 x: 1 header: HeaderTest expected_lines: - HeaderTest: - ----------- - medium: True - very_long_key: 3.14 - x: 1 - (vide) id: d0-HeaderTest-expected_lines0📌 Setup phase
duration:
0.0007680910639464855outcome:
passed📌 Call phase
duration:
0.00025491975247859955outcome:
passed📌 Teardown phase
duration:
0.00016485527157783508outcome:
passed
↳ Function: test_printable_dict_of_dicts
-
✅ Test 346
📌 Setup phase
duration:
0.00012477394193410873outcome:
passed📌 Call phase
duration:
0.00022458191961050034outcome:
passed📌 Teardown phase
duration:
0.00010705413296818733outcome:
passed
↳ Function: test_printable_table
-
✅ Test 347
params: data="X1", true, 0.1234, {"meta": "ok"}], ["AnotherSample", false, 98765.4321, {"meta": [1, 2, 3]}], ["Z", null, 0.0, {"meta": {"nested_key": 42}}, labels=["ID", "✓ Success?", "SuperPrecisionValue", "Result Metadata"], expected="A: ID\nB: ✓ Success?\nC: SuperPrecisionValue\nD: Result Metadata\n\n# A B C D\n- ------------- ----- ---------- ----------------------------\n0 X1 True 0.1234 {'meta': 'ok'}\n1 AnotherSample False 98765.4321 {'meta': [1, 2, 3]}\n2 Z None 0.0 {'meta': {'nested_key': 42}}"📌 Runtime Parameters
params: data: - - X1 - True - 0.1234 - meta: ok - - AnotherSample - (vide) - 98765.4321 - meta: - 1 - 2 - 3 - - Z - (vide) - (vide) - meta: nested_key: 42 labels: - ID - ✓ Success? - SuperPrecisionValue - Result Metadata expected: A: ID B: ✓ Success? C: SuperPrecisionValue D: Result Metadata # A B C D - ------------- ----- ---------- ---------------------------- 0 X1 True 0.1234 {'meta': 'ok'} 1 AnotherSample False 98765.4321 {'meta': [1, 2, 3]} 2 Z None 0.0 {'meta': {'nested_key': 42}} id: data0-labels0-A: ID\nB: \u2713 Success?\nC: SuperPrecisionValue\nD: Result Metadata\n\n# A B C D\n- ------------- ----- ---------- ----------------------------\n0 X1 True 0.1234 {'meta': 'ok'}\n1 AnotherSample False 98765.4321 {'meta': [1, 2, 3]}\n2 Z None 0.0 {'meta': {'nested_key': 42}}📌 Setup phase
duration:
0.0002979910932481289outcome:
passed📌 Call phase
duration:
0.000309488270431757outcome:
passed📌 Teardown phase
duration:
0.00016844505444169044outcome:
passed
-
-
📄 test_utils_rangebar.py
↳ Function: test_full_progress_bar
-
✅ Test 356
📌 Setup phase
duration:
0.0006303470581769943outcome:
passed📌 Call phase
duration:
0.00042936718091368675outcome:
passed📌 Teardown phase
duration:
0.00030343420803546906outcome:
passed
↳ Function: test_half_progress_bar
-
✅ Test 357
📌 Setup phase
duration:
0.0004905620589852333outcome:
passed📌 Call phase
duration:
0.0003758990205824375outcome:
passed📌 Teardown phase
duration:
0.00028758682310581207outcome:
passed
↳ Function: test_zero_progress_bar
-
✅ Test 358
📌 Setup phase
duration:
0.0004730159416794777outcome:
passed📌 Call phase
duration:
0.0003176541067659855outcome:
passed📌 Teardown phase
duration:
0.0002788039855659008outcome:
passed
↳ Function: test_overflow_bar
-
✅ Test 359
📌 Setup phase
duration:
0.0004698229022324085outcome:
passed📌 Call phase
duration:
0.0003163130022585392outcome:
passed📌 Teardown phase
duration:
0.00033355923369526863outcome:
passed
↳ Function: test_underflow_bar
-
✅ Test 360
📌 Setup phase
duration:
0.00044893287122249603outcome:
passed📌 Call phase
duration:
0.0003140931949019432outcome:
passed📌 Teardown phase
duration:
0.00026485370472073555outcome:
passed
↳ Function: test_repr
-
✅ Test 361
📌 Setup phase
duration:
0.00019114697352051735outcome:
passed📌 Call phase
duration:
0.00024369405582547188outcome:
passed📌 Teardown phase
duration:
0.00016551418229937553outcome:
passed
↳ Function: test_each_value_separately
-
✅ Test 362
params: value=0, expected_bar_part=" "📌 Runtime Parameters
params: value: 0 expected_bar_part: id: 0-📌 Setup phase
duration:
0.0006287042051553726outcome:
passed📌 Call phase
duration:
0.0003166734240949154outcome:
passed📌 Teardown phase
duration:
0.00033452780917286873outcome:
passed -
✅ Test 363
params: value=10, expected_bar_part="█ "📌 Runtime Parameters
params: value: 10 expected_bar_part: █ id: 10-\u2588📌 Setup phase
duration:
0.0006250678561627865outcome:
passed📌 Call phase
duration:
0.00031874608248472214outcome:
passed📌 Teardown phase
duration:
0.000285537913441658outcome:
passed -
✅ Test 364
params: value=25, expected_bar_part="██▌ "📌 Runtime Parameters
params: value: 25 expected_bar_part: ██▌ id: 25-\u2588\u2588\u258c📌 Setup phase
duration:
0.00040416186675429344outcome:
passed📌 Call phase
duration:
0.00020051980391144753outcome:
passed📌 Teardown phase
duration:
0.00019808486104011536outcome:
passed -
✅ Test 365
params: value=27, expected_bar_part="██▊ "📌 Runtime Parameters
params: value: 27 expected_bar_part: ██▊ id: 27-\u2588\u2588\u258a📌 Setup phase
duration:
0.0003928341902792454outcome:
passed📌 Call phase
duration:
0.00021743681281805038outcome:
passed📌 Teardown phase
duration:
0.00019780965521931648outcome:
passed -
✅ Test 366
params: value=49, expected_bar_part="████▉ "📌 Runtime Parameters
params: value: 49 expected_bar_part: ████▉ id: 49-\u2588\u2588\u2588\u2588\u2589📌 Setup phase
duration:
0.00037781428545713425outcome:
passed📌 Call phase
duration:
0.00019656307995319366outcome:
passed📌 Teardown phase
duration:
0.00020489003509283066outcome:
passed -
✅ Test 367
params: value=50, expected_bar_part="█████ "📌 Runtime Parameters
params: value: 50 expected_bar_part: █████ id: 50-\u2588\u2588\u2588\u2588\u2588📌 Setup phase
duration:
0.00036056432873010635outcome:
passed📌 Call phase
duration:
0.0001995796337723732outcome:
passed📌 Teardown phase
duration:
0.0001899339258670807outcome:
passed -
✅ Test 368
params: value=51, expected_bar_part="█████▏ "📌 Runtime Parameters
params: value: 51 expected_bar_part: █████▏ id: 51-\u2588\u2588\u2588\u2588\u2588\u258f📌 Setup phase
duration:
0.0003906590864062309outcome:
passed📌 Call phase
duration:
0.00028370926156640053outcome:
passed📌 Teardown phase
duration:
0.00022932980209589005outcome:
passed -
✅ Test 369
params: value=73, expected_bar_part="███████▎ "📌 Runtime Parameters
params: value: 73 expected_bar_part: ███████▎ id: 73-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u258e📌 Setup phase
duration:
0.00037353718653321266outcome:
passed📌 Call phase
duration:
0.00020987773314118385outcome:
passed📌 Teardown phase
duration:
0.00019195210188627243outcome:
passed -
✅ Test 370
params: value=75, expected_bar_part="███████▌ "📌 Runtime Parameters
params: value: 75 expected_bar_part: ███████▌ id: 75-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u258c📌 Setup phase
duration:
0.00044193491339683533outcome:
passed📌 Call phase
duration:
0.00019662687554955482outcome:
passed📌 Teardown phase
duration:
0.00020128488540649414outcome:
passed -
✅ Test 371
params: value=90, expected_bar_part="█████████ "📌 Runtime Parameters
params: value: 90 expected_bar_part: █████████ id: 90-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588📌 Setup phase
duration:
0.0003493023104965687outcome:
passed📌 Call phase
duration:
0.0002073301002383232outcome:
passed📌 Teardown phase
duration:
0.0001987731084227562outcome:
passed -
✅ Test 372
params: value=100, expected_bar_part="██████████"📌 Runtime Parameters
params: value: 100 expected_bar_part: ██████████ id: 100-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588📌 Setup phase
duration:
0.0003800191916525364outcome:
passed📌 Call phase
duration:
0.00018576299771666527outcome:
passed📌 Teardown phase
duration:
0.00024769827723503113outcome:
passed
-
-
📄 test_utils_readable.py
↳ Function: test_readable_seconds
-
✅ Test 373
params: seconds=59.4, expected="59 seconds"📌 Runtime Parameters
params: seconds: 59.4 expected: 59 seconds id: 59.4-59 seconds📌 Setup phase
duration:
0.0002753911539912224outcome:
passed📌 Call phase
duration:
0.0002529667690396309outcome:
passed📌 Teardown phase
duration:
0.00027251802384853363outcome:
passed -
✅ Test 374
params: seconds=59.9, expected="60 seconds"📌 Runtime Parameters
params: seconds: 59.9 expected: 60 seconds id: 59.9-60 seconds📌 Setup phase
duration:
0.00027164164930582047outcome:
passed📌 Call phase
duration:
0.0001672450453042984outcome:
passed📌 Teardown phase
duration:
0.00014597224071621895outcome:
passed -
✅ Test 375
params: seconds=119.9, expected="120 seconds"📌 Runtime Parameters
params: seconds: 119.9 expected: 120 seconds id: 119.9-120 seconds📌 Setup phase
duration:
0.00025138910859823227outcome:
passed📌 Call phase
duration:
0.00020707864314317703outcome:
passed📌 Teardown phase
duration:
0.0001628706231713295outcome:
passed -
✅ Test 376
params: seconds=120.1, expected="2 minutes"📌 Runtime Parameters
params: seconds: 120.1 expected: 2 minutes id: 120.1-2 minutes📌 Setup phase
duration:
0.00028226664289832115outcome:
passed📌 Call phase
duration:
0.0001874552108347416outcome:
passed📌 Teardown phase
duration:
0.00019506504759192467outcome:
passed -
✅ Test 377
params: seconds=3599.9, expected="60 minutes"📌 Runtime Parameters
params: seconds: 3599.9 expected: 60 minutes id: 3599.9-60 minutes📌 Setup phase
duration:
0.00026013702154159546outcome:
passed📌 Call phase
duration:
0.0001634298823773861outcome:
passed📌 Teardown phase
duration:
0.00014828937128186226outcome:
passed -
✅ Test 378
params: seconds=3600.1, expected="60 minutes"📌 Runtime Parameters
params: seconds: 3600.1 expected: 60 minutes id: 3600.1-60 minutes📌 Setup phase
duration:
0.00026478199288249016outcome:
passed📌 Call phase
duration:
0.00014903023838996887outcome:
passed📌 Teardown phase
duration:
0.00015512295067310333outcome:
passed -
✅ Test 379
params: seconds=7199.9, expected="120 minutes"📌 Runtime Parameters
params: seconds: 7199.9 expected: 120 minutes id: 7199.9-120 minutes📌 Setup phase
duration:
0.0002319631166756153outcome:
passed📌 Call phase
duration:
0.00014595407992601395outcome:
passed📌 Teardown phase
duration:
0.0001423950307071209outcome:
passed -
✅ Test 380
params: seconds=7200.1, expected="2 hours"📌 Runtime Parameters
params: seconds: 7200.1 expected: 2 hours id: 7200.1-2 hours📌 Setup phase
duration:
0.00021971296519041061outcome:
passed📌 Call phase
duration:
0.00013833120465278625outcome:
passed📌 Teardown phase
duration:
0.00014940183609724045outcome:
passed -
✅ Test 381
params: seconds=90.4, expected="90 seconds"📌 Runtime Parameters
params: seconds: 90.4 expected: 90 seconds id: 90.4-90 seconds📌 Setup phase
duration:
0.00022573303431272507outcome:
passed📌 Call phase
duration:
0.00015564216300845146outcome:
passed📌 Teardown phase
duration:
0.00014958996325731277outcome:
passed -
✅ Test 382
params: seconds=90.6, expected="91 seconds"📌 Runtime Parameters
params: seconds: 90.6 expected: 91 seconds id: 90.6-91 seconds📌 Setup phase
duration:
0.0002215411514043808outcome:
passed📌 Call phase
duration:
0.00014390423893928528outcome:
passed📌 Teardown phase
duration:
0.00014237407594919205outcome:
passed -
✅ Test 383
params: seconds=121.9, expected="2 minutes"📌 Runtime Parameters
params: seconds: 121.9 expected: 2 minutes id: 121.9-2 minutes📌 Setup phase
duration:
0.00023632682859897614outcome:
passed📌 Call phase
duration:
0.00015745265409350395outcome:
passed📌 Teardown phase
duration:
0.0003057639114558697outcome:
passed -
✅ Test 384
params: seconds=1296000.0, expected="2 weeks"📌 Runtime Parameters
params: seconds: 1296000.0 expected: 2 weeks id: 1296000.0-2 weeks📌 Setup phase
duration:
0.00024860305711627007outcome:
passed📌 Call phase
duration:
0.00015360815450549126outcome:
passed📌 Teardown phase
duration:
0.00015123095363378525outcome:
passed -
✅ Test 385
params: seconds=2592000.0, expected="4 weeks"📌 Runtime Parameters
params: seconds: 2592000.0 expected: 4 weeks id: 2592000.0-4 weeks📌 Setup phase
duration:
0.00023953290656208992outcome:
passed📌 Call phase
duration:
0.00014474615454673767outcome:
passed📌 Teardown phase
duration:
0.00014273682609200478outcome:
passed -
✅ Test 386
params: seconds=2800000.0, expected="5 weeks"📌 Runtime Parameters
params: seconds: 2800000.0 expected: 5 weeks id: 2800000.0-5 weeks📌 Setup phase
duration:
0.00023534568026661873outcome:
passed📌 Call phase
duration:
0.0002019987441599369outcome:
passed📌 Teardown phase
duration:
0.00016029691323637962outcome:
passed -
✅ Test 387
params: seconds=3888000.0, expected="6 weeks"📌 Runtime Parameters
params: seconds: 3888000.0 expected: 6 weeks id: 3888000.0-6 weeks📌 Setup phase
duration:
0.00023357803001999855outcome:
passed📌 Call phase
duration:
0.00015541119500994682outcome:
passed📌 Teardown phase
duration:
0.00014281412586569786outcome:
passed -
✅ Test 388
params: seconds=5097600.0, expected="8 weeks"📌 Runtime Parameters
params: seconds: 5097600.0 expected: 8 weeks id: 5097600.0-8 weeks📌 Setup phase
duration:
0.00021978095173835754outcome:
passed📌 Call phase
duration:
0.00016434630379080772outcome:
passed📌 Teardown phase
duration:
0.00015752390027046204outcome:
passed -
✅ Test 389
params: seconds=5184000.0, expected="9 weeks"📌 Runtime Parameters
params: seconds: 5184000.0 expected: 9 weeks id: 5184000.0-9 weeks📌 Setup phase
duration:
0.00025544269010424614outcome:
passed📌 Call phase
duration:
0.0001429975964128971outcome:
passed📌 Teardown phase
duration:
0.00015457719564437866outcome:
passed -
✅ Test 390
params: seconds=5270400.0, expected="2 months"📌 Runtime Parameters
params: seconds: 5270400.0 expected: 2 months id: 5270400.0-2 months📌 Setup phase
duration:
0.00023433472961187363outcome:
passed📌 Call phase
duration:
0.000144170131534338outcome:
passed📌 Teardown phase
duration:
0.00014172308146953583outcome:
passed -
✅ Test 391
params: seconds=23328000.0, expected="9 months"📌 Runtime Parameters
params: seconds: 23328000.0 expected: 9 months id: 23328000.0-9 months📌 Setup phase
duration:
0.00021795602515339851outcome:
passed📌 Call phase
duration:
0.0001559928059577942outcome:
passed📌 Teardown phase
duration:
0.00015174876898527145outcome:
passed -
✅ Test 392
params: seconds=31104000.0, expected="12 months"📌 Runtime Parameters
params: seconds: 31104000.0 expected: 12 months id: 31104000.0-12 months📌 Setup phase
duration:
0.0002251160331070423outcome:
passed📌 Call phase
duration:
0.00014088209718465805outcome:
passed📌 Teardown phase
duration:
0.0001391228288412094outcome:
passed -
✅ Test 393
params: seconds=33696000.0, expected="13 months"📌 Runtime Parameters
params: seconds: 33696000.0 expected: 13 months id: 33696000.0-13 months📌 Setup phase
duration:
0.00024855462834239006outcome:
passed📌 Call phase
duration:
0.0001634238287806511outcome:
passed📌 Teardown phase
duration:
0.0001367400400340557outcome:
passed -
✅ Test 394
params: seconds=59616000.0, expected="23 months"📌 Runtime Parameters
params: seconds: 59616000.0 expected: 23 months id: 59616000.0-23 months📌 Setup phase
duration:
0.0002115420065820217outcome:
passed📌 Call phase
duration:
0.00015395600348711014outcome:
passed📌 Teardown phase
duration:
0.00013655098155140877outcome:
passed -
✅ Test 395
params: seconds=62208000.0, expected="24 months"📌 Runtime Parameters
params: seconds: 62208000.0 expected: 24 months id: 62208000.0-24 months📌 Setup phase
duration:
0.00021422794088721275outcome:
passed📌 Call phase
duration:
0.00013956381008028984outcome:
passed📌 Teardown phase
duration:
0.0001327679492533207outcome:
passed -
✅ Test 396
params: seconds=64208000.0, expected="2 years"📌 Runtime Parameters
params: seconds: 64208000.0 expected: 2 years id: 64208000.0-2 years📌 Setup phase
duration:
0.00023797107860445976outcome:
passed📌 Call phase
duration:
0.00014124205335974693outcome:
passed📌 Teardown phase
duration:
0.0001385929062962532outcome:
passed
-
-
📄 test_utils_registry.py
↳ Function: test_metaclass_creates_weakset
-
✅ Test 397
📌 Setup phase
duration:
0.00011955806985497475outcome:
passed📌 Call phase
duration:
0.0007987199351191521outcome:
passed📌 Teardown phase
duration:
0.00011704396456480026outcome:
passed
↳ Function: test_metaclass_tracks_instances
-
✅ Test 398
📌 Setup phase
duration:
0.000113682821393013outcome:
passed📌 Call phase
duration:
0.0002634963020682335outcome:
passed📌 Teardown phase
duration:
0.00011125626042485237outcome:
passed
↳ Function: test_registry_inheritance
-
✅ Test 399
📌 Setup phase
duration:
0.00020224181935191154outcome:
passed📌 Call phase
duration:
0.0006939801387488842outcome:
passed📌 Teardown phase
duration:
0.00014849798753857613outcome:
passed
↳ Function: test_instance_tracking
-
✅ Test 400
📌 Setup phase
duration:
0.00018216297030448914outcome:
passed📌 Call phase
duration:
0.00022746436297893524outcome:
passed📌 Teardown phase
duration:
0.00012456905096769333outcome:
passed
↳ Function: test_collect_instances_recursive
-
✅ Test 401
📌 Setup phase
duration:
0.00017793988808989525outcome:
passed📌 Call phase
duration:
0.0013846969231963158outcome:
passed📌 Teardown phase
duration:
0.00016450369730591774outcome:
passed
↳ Function: test_instances_function
-
✅ Test 402
📌 Setup phase
duration:
0.00019692955538630486outcome:
passed📌 Call phase
duration:
0.0008934070356190205outcome:
passed📌 Teardown phase
duration:
0.0001520821824669838outcome:
passed
↳ Function: test_non_registry_class_error
-
✅ Test 403
📌 Setup phase
duration:
0.00013814028352499008outcome:
passed📌 Call phase
duration:
0.00020657898858189583outcome:
passed📌 Teardown phase
duration:
0.00011380575597286224outcome:
passed
↳ Function: test_signature_preservation
-
✅ Test 404
📌 Setup phase
duration:
0.00012143002822995186outcome:
passed📌 Call phase
duration:
0.00026366719976067543outcome:
passed📌 Teardown phase
duration:
0.00012065796181559563outcome:
passed
-
-
📄 test_utils_richcfg.py
↳ Function: test_rich_inspector_outputs_more_than_builtin
-
✅ Test 405
📌 Setup phase
duration:
0.0002122577279806137outcome:
passed📌 Call phase
duration:
0.11507146339863539outcome:
passedlog:
- name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413322.52941735 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565322.0581763 msecs: 58.176279067993164 relativeCreated: 9957.3073387146 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903📌 Teardown phase
duration:
0.00034177908673882484outcome:
passed
-
-
📄 test_utils_run_later.py
↳ Function: test_init_and_repr
-
✅ Test 406
📌 Setup phase
duration:
0.00019775563850998878outcome:
passed📌 Call phase
duration:
0.00026995688676834106outcome:
passed📌 Teardown phase
duration:
0.00012332480400800705outcome:
passed
↳ Function: test_call
-
✅ Test 407
📌 Setup phase
duration:
0.0001285918988287449outcome:
passed📌 Call phase
duration:
0.0001877988688647747outcome:
passed📌 Teardown phase
duration:
0.00011677900329232216outcome:
passed
↳ Function: test_matmul_with_string
-
✅ Test 408
📌 Setup phase
duration:
0.00012051686644554138outcome:
passed📌 Call phase
duration:
0.00017887121066451073outcome:
passed📌 Teardown phase
duration:
0.00011458806693553925outcome:
passed
↳ Function: test_matmul_with_list
-
✅ Test 409
📌 Setup phase
duration:
0.00010964693501591682outcome:
passed📌 Call phase
duration:
0.00019260123372077942outcome:
passed📌 Teardown phase
duration:
0.00010700942948460579outcome:
passed
↳ Function: test_matmul_with_single_int
-
✅ Test 410
📌 Setup phase
duration:
0.00011296523734927177outcome:
passed📌 Call phase
duration:
0.00017081014811992645outcome:
passed📌 Teardown phase
duration:
0.0001141577959060669outcome:
passed
↳ Function: test_run_at_future_triggered_and_logs
-
✅ Test 411
📌 Setup phase
duration:
0.00038772309198975563outcome:
passed📌 Call phase
duration:
0.2069088160060346outcome:
passedlog:
- name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413322.163915003 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1735732800.0506182 msecs: 50.61817169189453 relativeCreated: -18832512050.25077 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413322.264730597 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1735732800.15148 msecs: 151.47995948791504 relativeCreated: -18832511949.38898 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903📌 Teardown phase
duration:
0.00034085195511579514outcome:
passed
↳ Function: test_run_at_already_past
-
✅ Test 412
📌 Setup phase
duration:
0.0003566187806427479outcome:
passed📌 Call phase
duration:
0.00036969734355807304outcome:
passed📌 Teardown phase
duration:
0.0001770765520632267outcome:
passed
↳ Function: test_run_in_future_triggered_and_logs
-
✅ Test 413
📌 Setup phase
duration:
0.00026414915919303894outcome:
passed📌 Call phase
duration:
0.2022362081333995outcome:
passedlog:
- name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413322.365574128 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1735732800.0423243 msecs: 42.32430458068848 relativeCreated: -18832512058.544636 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413322.466346661 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1735732800.1430278 msecs: 143.02778244018555 relativeCreated: -18832511957.841156 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903📌 Teardown phase
duration:
0.0005125184543430805outcome:
passed
↳ Function: test_run_in_past
-
✅ Test 414
📌 Setup phase
duration:
0.0005360222421586514outcome:
passed📌 Call phase
duration:
0.0005736220628023148outcome:
passed📌 Teardown phase
duration:
0.0002654688432812691outcome:
passed
↳ Function: test_run_later_with_seconds
-
✅ Test 415
📌 Setup phase
duration:
0.000322174746543169outcome:
passed📌 Call phase
duration:
0.20241254102438688outcome:
passedlog:
- name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413322.567073020 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1735740000.0365796 msecs: 36.57960891723633 relativeCreated: -18825312064.28933 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413322.667879308 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1735740000.1373835 msecs: 137.38346099853516 relativeCreated: -18825311963.48548 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903📌 Teardown phase
duration:
0.00036020204424858093outcome:
passed
↳ Function: test_run_later_with_past_datetime
-
✅ Test 416
📌 Setup phase
duration:
0.0003468012437224388outcome:
passed📌 Call phase
duration:
0.00036247819662094116outcome:
passed📌 Teardown phase
duration:
0.00018026819452643394outcome:
passed
↳ Function: test_today_basic
-
✅ Test 418
📌 Setup phase
duration:
0.00016239704564213753outcome:
passed📌 Call phase
duration:
0.0007997560314834118outcome:
passed📌 Teardown phase
duration:
0.00014317315071821213outcome:
passed
↳ Function: test_tomorrow_basic
-
✅ Test 419
📌 Setup phase
duration:
0.00012749480083584785outcome:
passed📌 Call phase
duration:
0.0004096217453479767outcome:
passed📌 Teardown phase
duration:
0.0001110592857003212outcome:
passed
↳ Function: test_yesterday_basic
-
✅ Test 420
📌 Setup phase
duration:
0.00011259689927101135outcome:
passed📌 Call phase
duration:
0.0003366749733686447outcome:
passed📌 Teardown phase
duration:
0.00010570604354143143outcome:
passed
↳ Function: test_today_matmul_string
-
✅ Test 421
📌 Setup phase
duration:
0.00011861231178045273outcome:
passed📌 Call phase
duration:
0.0003428882919251919outcome:
passed📌 Teardown phase
duration:
0.0001324550248682499outcome:
passed
↳ Function: test_tomorrow_matmul_list
-
✅ Test 422
📌 Setup phase
duration:
0.00011470681056380272outcome:
passed📌 Call phase
duration:
0.00035979365929961205outcome:
passed📌 Teardown phase
duration:
0.0001154397614300251outcome:
passed
↳ Function: test_yesterday_matmul_single
-
✅ Test 423
📌 Setup phase
duration:
0.00011360878124833107outcome:
passed📌 Call phase
duration:
0.00034675421193242073outcome:
passed📌 Teardown phase
duration:
0.00011079199612140656outcome:
passed
-
-
📄 test_utils_sendmail.py
↳ Function: test_sendmail_real_local_verbose
-
✅ Test 424
📌 Setup phase
duration:
0.0001421421766281128outcome:
passed📌 Call phase
duration:
2.093075341079384outcome:
passedlog:
- name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413322.970302067 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565322.970551 msecs: 970.5510139465332 relativeCreated: 10869.68207359314 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413323.71299413 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565323.071448 msecs: 71.44808769226074 relativeCreated: 10970.579147338867 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413323.172066503 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565323.1722443 msecs: 172.24431037902832 relativeCreated: 11071.375370025635 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413323.272814823 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565323.2729619 msecs: 272.9618549346924 relativeCreated: 11172.092914581299 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413323.373488530 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565323.3736286 msecs: 373.6286163330078 relativeCreated: 11272.759675979614 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413323.474275093 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565323.4745398 msecs: 474.53975677490234 relativeCreated: 11373.670816421509 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413323.575274090 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565323.5755186 msecs: 575.5186080932617 relativeCreated: 11474.649667739868 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413323.676240645 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565323.676494 msecs: 676.4938831329346 relativeCreated: 11575.624942779541 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413323.777123309 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565323.7772675 msecs: 777.2674560546875 relativeCreated: 11676.398515701294 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413323.877827920 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565323.8779697 msecs: 877.9697418212891 relativeCreated: 11777.100801467896 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413323.978539042 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565323.9787142 msecs: 978.7142276763916 relativeCreated: 11877.845287322998 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413324.79246330 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565324.0793877 msecs: 79.38766479492188 relativeCreated: 11978.518724441528 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413324.179925284 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565324.1800995 msecs: 180.0994873046875 relativeCreated: 12079.230546951294 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413324.280719902 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565324.2809258 msecs: 280.9257507324219 relativeCreated: 12180.056810379028 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413324.381439044 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565324.3815782 msecs: 381.5782070159912 relativeCreated: 12280.709266662598 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413324.482124230 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565324.482274 msecs: 482.27405548095703 relativeCreated: 12381.405115127563 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413324.582814548 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565324.5829575 msecs: 582.9575061798096 relativeCreated: 12482.088565826416 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413324.683499554 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565324.6836488 msecs: 683.6488246917725 relativeCreated: 12582.779884338379 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413324.784198933 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565324.7843432 msecs: 784.3432426452637 relativeCreated: 12683.47430229187 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413324.884876231 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565324.8850207 msecs: 885.0207328796387 relativeCreated: 12784.151792526245 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413324.985557643 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565324.9857154 msecs: 985.715389251709 relativeCreated: 12884.846448898315 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903📌 Teardown phase
duration:
0.0004756636917591095outcome:
passed
-
-
📄 test_utils_shortcut.py
↳ Function: TestShortcutInitialization
-
✅ Test 425
📌 Setup phase
duration:
0.0004632938653230667outcome:
passed📌 Call phase
duration:
0.00025933515280485153outcome:
passed📌 Teardown phase
duration:
0.0001607593148946762outcome:
passed -
✅ Test 426
📌 Setup phase
duration:
0.00022446783259510994outcome:
passed📌 Call phase
duration:
0.00024002371355891228outcome:
passed📌 Teardown phase
duration:
0.00016877474263310432outcome:
passed
↳ Function: test_run_method
-
✅ Test 427
📌 Setup phase
duration:
0.0004383227787911892outcome:
passed📌 Call phase
duration:
0.0007149511948227882outcome:
passed📌 Teardown phase
duration:
0.00021408265456557274outcome:
passed
↳ Function: test_repr_output
-
✅ Test 428
📌 Setup phase
duration:
0.00030673621222376823outcome:
passed📌 Call phase
duration:
0.00026515405625104904outcome:
passed📌 Teardown phase
duration:
0.00019876006990671158outcome:
passed
↳ Function: test_source_with_regular_function
-
✅ Test 429
📌 Setup phase
duration:
0.0002853921614587307outcome:
passed📌 Call phase
duration:
0.0007257550023496151outcome:
passed📌 Teardown phase
duration:
0.00015014596283435822outcome:
passed
↳ Function: test_source_error_handling
-
✅ Test 430
📌 Setup phase
duration:
0.0001873290166258812outcome:
passed📌 Call phase
duration:
0.0009588482789695263outcome:
passed📌 Teardown phase
duration:
0.00016996683552861214outcome:
passed
↳ Function: test_as_shortcut_basic
-
✅ Test 431
📌 Setup phase
duration:
0.00021665683016180992outcome:
passed📌 Call phase
duration:
0.00016097398474812508outcome:
passed📌 Teardown phase
duration:
0.00034887203946709633outcome:
passed
↳ Function: test_as_shortcut_with_name
-
✅ Test 432
📌 Setup phase
duration:
0.00019673118367791176outcome:
passed📌 Call phase
duration:
0.00015580886974930763outcome:
passed📌 Teardown phase
duration:
0.00014247605577111244outcome:
passed
↳ Function: test_as_shortcut_factory_pattern
-
✅ Test 433
📌 Setup phase
duration:
0.0002811010926961899outcome:
passed📌 Call phase
duration:
0.0002303258515894413outcome:
passed📌 Teardown phase
duration:
0.0002006920985877514outcome:
passed
↳ Function: TestShortcutsSingleton
-
✅ Test 434
📌 Setup phase
duration:
0.00040472205728292465outcome:
passed📌 Call phase
duration:
0.00025555724278092384outcome:
passed📌 Teardown phase
duration:
0.000273960642516613outcome:
passed -
✅ Test 435
📌 Setup phase
duration:
0.0004386422224342823outcome:
passed📌 Call phase
duration:
0.0004110410809516907outcome:
passed📌 Teardown phase
duration:
0.0002626138739287853outcome:
passed -
✅ Test 436
📌 Setup phase
duration:
0.00044563086703419685outcome:
passed📌 Call phase
duration:
0.0003402126021683216outcome:
passed📌 Teardown phase
duration:
0.0002610012888908386outcome:
passed -
✅ Test 437
📌 Setup phase
duration:
0.00040378887206315994outcome:
passed📌 Call phase
duration:
0.0003105322830379009outcome:
passed📌 Teardown phase
duration:
0.00015925196930766106outcome:
passed -
✅ Test 438
📌 Setup phase
duration:
0.0002622706815600395outcome:
passed📌 Call phase
duration:
0.00026495521888136864outcome:
passed📌 Teardown phase
duration:
0.00015759514644742012outcome:
passed
↳ Function: TestFullIntegration
-
✅ Test 439
📌 Setup phase
duration:
0.0004763011820614338outcome:
passed📌 Call phase
duration:
0.0008355849422514439outcome:
passed📌 Teardown phase
duration:
0.00028342800214886665outcome:
passed -
✅ Test 440
📌 Setup phase
duration:
0.0003685830160975456outcome:
passed📌 Call phase
duration:
0.00033025629818439484outcome:
passed📌 Teardown phase
duration:
0.00022585177794098854outcome:
passed
↳ Function: test_registry_inheritance
-
✅ Test 441
📌 Setup phase
duration:
0.00020526302978396416outcome:
passed📌 Call phase
duration:
0.0001363116316497326outcome:
passed📌 Teardown phase
duration:
0.0001443088985979557outcome:
passed
-
-
📄 test_utils_snapshot.py
↳ Function: test_snapshot
-
✅ Test 442
params: test_input="v1", "Visible", false], ["h1", "Hidden", true, expected=["Visible"], kwargs={}📌 Runtime Parameters
params: test_input: - - v1 - Visible - (vide) - - h1 - Hidden - True expected: - Visible kwargs: {} id: exclude_internals📌 Setup phase
duration:
0.0003124740906059742outcome:
passed📌 Call phase
duration:
0.000705118291079998outcome:
passed📌 Teardown phase
duration:
0.00017750216647982597outcome:
passed -
✅ Test 443
params: test_input="v1", "Visible", false], ["h1", "Hidden", true, expected=["Visible", "Hidden"], kwargs={"include_internal": true}📌 Runtime Parameters
params: test_input: - - v1 - Visible - (vide) - - h1 - Hidden - True expected: - Visible - Hidden kwargs: include_internal: True id: include_internals📌 Setup phase
duration:
0.00028812000527977943outcome:
passed📌 Call phase
duration:
0.0004962258972227573outcome:
passed📌 Teardown phase
duration:
0.00047189416363835335outcome:
passed -
✅ Test 444
params: test_input=[], expected=[], kwargs={}📌 Runtime Parameters
params: test_input: [] expected: [] kwargs: {} id: empty_case📌 Setup phase
duration:
0.0004102769307792187outcome:
passed📌 Call phase
duration:
0.0001990562304854393outcome:
passed📌 Teardown phase
duration:
0.0002414393238723278outcome:
passed -
✅ Test 445
params: test_input="3", "Charlie"], ["1", "Alpha"], ["2", "Beta", expected=["Alpha", "Beta", "Charlie"], kwargs="{'sort_key': }"📌 Runtime Parameters
params: test_input: - - 3 - Charlie - - 1 - Alpha - - 2 - Beta expected: - Alpha - Beta - Charlie kwargs: {'sort_key': <class 'str'>} id: sort_str📌 Setup phase
duration:
0.000315976794809103outcome:
passed📌 Call phase
duration:
0.0007097180932760239outcome:
passed📌 Teardown phase
duration:
0.0001928289420902729outcome:
passed -
✅ Test 446
params: test_input="z3", "C"], ["a1", "A"], ["m2", "B", expected=["A", "B", "C"], kwargs="{'sort_key': at 0x7f0de3a35550>}"📌 Runtime Parameters
params: test_input: - - z3 - C - - a1 - A - - m2 - B expected: - A - B - C kwargs: {'sort_key': <function <lambda> at 0x7f0de3a35550>} id: sort_id📌 Setup phase
duration:
0.00030038366094231606outcome:
passed📌 Call phase
duration:
0.0006236252374947071outcome:
passed📌 Teardown phase
duration:
0.00019202614203095436outcome:
passed -
✅ Test 447
params: test_input="3", "Charlie"], ["1", "alpha"], ["2", "Beta", expected=["alpha", "Beta", "Charlie"], kwargs="{'sort_key': at 0x7f0de3a355e0>}"📌 Runtime Parameters
params: test_input: - - 3 - Charlie - - 1 - alpha - - 2 - Beta expected: - alpha - Beta - Charlie kwargs: {'sort_key': <function <lambda> at 0x7f0de3a355e0>} id: sort_case_insensitive📌 Setup phase
duration:
0.0002889488823711872outcome:
passed📌 Call phase
duration:
0.0007460573688149452outcome:
passed📌 Teardown phase
duration:
0.00019065523520112038outcome:
passed -
✅ Test 448
params: test_input="1", "A"], ["2", "BB"], ["3", "CCC", expected=["A", "BB", "CCC"], kwargs="{'sort_key': at 0x7f0de3a35670>}"📌 Runtime Parameters
params: test_input: - - 1 - A - - 2 - BB - - 3 - CCC expected: - A - BB - CCC kwargs: {'sort_key': <function <lambda> at 0x7f0de3a35670>} id: sort_length📌 Setup phase
duration:
0.00028490694239735603outcome:
passed📌 Call phase
duration:
0.0005693030543625355outcome:
passed📌 Teardown phase
duration:
0.00020240293815732002outcome:
passed -
✅ Test 449
params: test_input="1", "A"], ["2", "B"], ["3", "C", expected=["C", "B", "A"], kwargs="{'sort_key': at 0x7f0de3a35700>}"📌 Runtime Parameters
params: test_input: - - 1 - A - - 2 - B - - 3 - C expected: - C - B - A kwargs: {'sort_key': <function <lambda> at 0x7f0de3a35700>} id: sort_reverse📌 Setup phase
duration:
0.00027948664501309395outcome:
passed📌 Call phase
duration:
0.0005860147066414356outcome:
passed📌 Teardown phase
duration:
0.00017438409850001335outcome:
passed
-
-
📄 test_utils_termtitle.py
↳ Function: test_terminal_title_with_tmux
-
✅ Test 450
📌 Setup phase
duration:
0.0001421850174665451outcome:
passed📌 Call phase
duration:
0.019499448128044605outcome:
passed📌 Teardown phase
duration:
0.0002573160454630852outcome:
passed
-
-
📄 test_utils_tqdm_mod.py
↳ Function: test_complete_progress_bar
-
✅ Test 451
📌 Setup phase
duration:
0.0001760348677635193outcome:
passed📌 Call phase
duration:
0.004176003858447075outcome:
passed📌 Teardown phase
duration:
0.00013829395174980164outcome:
passed
↳ Function: test_set_progress_multiple_points
-
✅ Test 452
📌 Setup phase
duration:
0.00012782402336597443outcome:
passed📌 Call phase
duration:
0.0017978157848119736outcome:
passed📌 Teardown phase
duration:
0.00013515865430235863outcome:
passed
↳ Function: test_format_sizeof_alignment
-
✅ Test 453
📌 Setup phase
duration:
0.00013889092952013016outcome:
passed📌 Call phase
duration:
0.0001622210256755352outcome:
passed📌 Teardown phase
duration:
0.00010324409231543541outcome:
passed
↳ Function: test_custom_unit
-
✅ Test 455
📌 Setup phase
duration:
0.0001306328922510147outcome:
passed📌 Call phase
duration:
0.005049322731792927outcome:
passed📌 Teardown phase
duration:
0.00014377199113368988outcome:
passed
↳ Function: test_clamp_above_total
-
✅ Test 456
📌 Setup phase
duration:
0.00012210430577397346outcome:
passed📌 Call phase
duration:
0.0005151247605681419outcome:
passed📌 Teardown phase
duration:
0.00011891406029462814outcome:
passed
↳ Function: test_clamp_below_zero
-
✅ Test 457
📌 Setup phase
duration:
0.00011602416634559631outcome:
passed📌 Call phase
duration:
0.0006482400931417942outcome:
passed📌 Teardown phase
duration:
0.00012484705075621605outcome:
passed
-
-
📄 test_utils_trinary.py
↳ Function: test_check_trinary_valid_values
-
✅ Test 458
📌 Setup phase
duration:
0.00012729410082101822outcome:
passed📌 Call phase
duration:
0.00018018577247858047outcome:
passed📌 Teardown phase
duration:
0.00010517612099647522outcome:
passed
↳ Function: test_check_trinary_invalid_value
-
✅ Test 459
📌 Setup phase
duration:
0.00011344486847519875outcome:
passed📌 Call phase
duration:
0.00039721326902508736outcome:
passed📌 Teardown phase
duration:
0.0001100967638194561outcome:
passed
↳ Function: test_check_trinary_with_custom_allowed_values
-
✅ Test 460
📌 Setup phase
duration:
0.0001108311116695404outcome:
passed📌 Call phase
duration:
0.00017676223069429398outcome:
passed📌 Teardown phase
duration:
0.00010484829545021057outcome:
passed
-
-
📄 test_utils_typecast.py
↳ Function: test_downcast_success
-
✅ Test 461
📌 Setup phase
duration:
0.0001452593132853508outcome:
passed📌 Call phase
duration:
0.00018921587616205215outcome:
passed📌 Teardown phase
duration:
0.00011798273772001266outcome:
passed
↳ Function: test_upcast_success
-
✅ Test 462
📌 Setup phase
duration:
0.00011232960969209671outcome:
passed📌 Call phase
duration:
0.00015904195606708527outcome:
passed📌 Teardown phase
duration:
0.00010648369789123535outcome:
passed
↳ Function: test_downcast_invalid
-
✅ Test 463
📌 Setup phase
duration:
0.00011012889444828033outcome:
passed📌 Call phase
duration:
0.0003472818061709404outcome:
passed📌 Teardown phase
duration:
0.0001211739145219326outcome:
passed
↳ Function: test_upcast_invalid
-
✅ Test 464
📌 Setup phase
duration:
0.00011469097808003426outcome:
passed📌 Call phase
duration:
0.0002233819104731083outcome:
passed📌 Teardown phase
duration:
0.00011937879025936127outcome:
passed
↳ Function: test_object_identity_preserved
-
✅ Test 465
📌 Setup phase
duration:
0.0001341579481959343outcome:
passed📌 Call phase
duration:
0.00014653708785772324outcome:
passed📌 Teardown phase
duration:
0.00010953797027468681outcome:
passed
↳ Function: test_ensure_subclass_valid
-
✅ Test 466
📌 Setup phase
duration:
0.00011017080396413803outcome:
passed📌 Call phase
duration:
0.00019967975094914436outcome:
passed📌 Teardown phase
duration:
0.00011803070083260536outcome:
passed
↳ Function: test_ensure_subclass_invalid
-
✅ Test 467
📌 Setup phase
duration:
0.00012174481526017189outcome:
passed📌 Call phase
duration:
0.00017518596723675728outcome:
passed📌 Teardown phase
duration:
0.00012037670239806175outcome:
passed
↳ Function: test_cast_changes_class
-
✅ Test 468
📌 Setup phase
duration:
0.00010833423584699631outcome:
passed📌 Call phase
duration:
0.00015997886657714844outcome:
passed📌 Teardown phase
duration:
0.00012066401541233063outcome:
passed
↳ Function: test_cast_preserves_identity
-
✅ Test 469
📌 Setup phase
duration:
0.00011331681162118912outcome:
passed📌 Call phase
duration:
0.0001424141228199005outcome:
passed📌 Teardown phase
duration:
0.00010989606380462646outcome:
passed
-
-
📄 test_utils_utils.py
↳ Function: test_singleton_instance
-
✅ Test 470
📌 Setup phase
duration:
0.00012856582179665565outcome:
passed📌 Call phase
duration:
0.00015260232612490654outcome:
passed📌 Teardown phase
duration:
0.00010331207886338234outcome:
passed
↳ Function: test_singleton_identity
-
✅ Test 471
📌 Setup phase
duration:
0.00011440692469477654outcome:
passed📌 Call phase
duration:
0.0001368238590657711outcome:
passed📌 Teardown phase
duration:
0.00010293722152709961outcome:
passed
↳ Function: test_typename
-
✅ Test 472
params: obj=null, expected="NoneType"📌 Runtime Parameters
params: obj: None expected: NoneType id: None-NoneType📌 Setup phase
duration:
0.0003356738016009331outcome:
passed📌 Call phase
duration:
0.00015108799561858177outcome:
passed📌 Teardown phase
duration:
0.0001657288521528244outcome:
passed -
✅ Test 473
params: obj=true, expected="bool"📌 Runtime Parameters
params: obj: True expected: bool id: True-bool📌 Setup phase
duration:
0.0002453550696372986outcome:
passed📌 Call phase
duration:
0.00013777520507574081outcome:
passed📌 Teardown phase
duration:
0.00014118803665041924outcome:
passed -
✅ Test 474
params: obj=42, expected="int"📌 Runtime Parameters
params: obj: 42 expected: int id: 42-int📌 Setup phase
duration:
0.0002270587719976902outcome:
passed📌 Call phase
duration:
0.00014997180551290512outcome:
passed📌 Teardown phase
duration:
0.00014301808550953865outcome:
passed -
✅ Test 475
params: obj=3.14, expected="float"📌 Runtime Parameters
params: obj: 3.14 expected: float id: 3.14-float📌 Setup phase
duration:
0.00021718209609389305outcome:
passed📌 Call phase
duration:
0.00015297811478376389outcome:
passed📌 Teardown phase
duration:
0.00015442585572600365outcome:
passed -
✅ Test 476
params: obj="text", expected="str"📌 Runtime Parameters
params: obj: text expected: str id: text-str📌 Setup phase
duration:
0.00023304205387830734outcome:
passed📌 Call phase
duration:
0.00014890916645526886outcome:
passed📌 Teardown phase
duration:
0.0001432141289114952outcome:
passed -
✅ Test 477
params: obj="{1, 2, 3}", expected="set"📌 Runtime Parameters
params: obj: {1, 2, 3} expected: set id: obj5-set📌 Setup phase
duration:
0.0003093588165938854outcome:
passed📌 Call phase
duration:
0.00016070716083049774outcome:
passed📌 Teardown phase
duration:
0.00014877412468194962outcome:
passed -
✅ Test 478
params: obj=1], [2, 3, expected="list"📌 Runtime Parameters
params: obj: - - 1 - - 2 - 3 expected: list id: obj6-list📌 Setup phase
duration:
0.0002402961254119873outcome:
passed📌 Call phase
duration:
0.0001477389596402645outcome:
passed📌 Teardown phase
duration:
0.00015622517094016075outcome:
passed -
✅ Test 479
params: obj=[{"a": [1, 2]}, {"b": [3, 4]}], expected="list"📌 Runtime Parameters
params: obj: - a: - 1 - 2 - b: - 3 - 4 expected: list id: obj7-list📌 Setup phase
duration:
0.00023099686950445175outcome:
passed📌 Call phase
duration:
0.00013866601511836052outcome:
passed📌 Teardown phase
duration:
0.00017060432583093643outcome:
passed -
✅ Test 480
params: obj={"key": [{"nested": 1}, [2, 3]]}, expected="dict"📌 Runtime Parameters
params: obj: key: - nested: 1 - - 2 - 3 expected: dict id: obj8-dict📌 Setup phase
duration:
0.0002467939630150795outcome:
passed📌 Call phase
duration:
0.00014100223779678345outcome:
passed📌 Teardown phase
duration:
0.0001460588537156582outcome:
passed -
✅ Test 481
params: obj=" at 0x7f0de3a40e50>", expected="function"📌 Runtime Parameters
params: obj: <function <lambda> at 0x7f0de3a40e50> expected: function id: <lambda>-function📌 Setup phase
duration:
0.0003322688862681389outcome:
passed📌 Call phase
duration:
0.0001530032604932785outcome:
passed📌 Teardown phase
duration:
0.00014760484918951988outcome:
passed -
✅ Test 482
params: obj="", expected="function"📌 Runtime Parameters
params: obj: <function sample_function at 0x7f0de3a40dc0> expected: function id: sample_function-function📌 Setup phase
duration:
0.0002334602177143097outcome:
passed📌 Call phase
duration:
0.00013868696987628937outcome:
passed📌 Teardown phase
duration:
0.0001498986966907978outcome:
passed -
✅ Test 483
params: obj=".nested at 0x7f0de3a40ee0>", expected="function"📌 Runtime Parameters
params: obj: <function sample_function.<locals>.nested at 0x7f0de3a40ee0> expected: function id: nested-function📌 Setup phase
duration:
0.00022926414385437965outcome:
passed📌 Call phase
duration:
0.0001373286359012127outcome:
passed📌 Teardown phase
duration:
0.0001425999216735363outcome:
passed -
✅ Test 484
params: obj="", expected="builtin_function_or_method"📌 Runtime Parameters
params: obj: <built-in function len> expected: builtin_function_or_method id: len-builtin_function_or_method📌 Setup phase
duration:
0.00023624300956726074outcome:
passed📌 Call phase
duration:
0.00014912383630871773outcome:
passed📌 Teardown phase
duration:
0.0001418180763721466outcome:
passed -
✅ Test 485
params: obj="", expected="builtin_function_or_method"📌 Runtime Parameters
params: obj: <built-in function sum> expected: builtin_function_or_method id: sum-builtin_function_or_method📌 Setup phase
duration:
0.00021389592438936234outcome:
passed📌 Call phase
duration:
0.00015377812087535858outcome:
passed📌 Teardown phase
duration:
0.0001689121127128601outcome:
passed -
✅ Test 486
params: obj="", expected="module"📌 Runtime Parameters
params: obj: <module 'math' from '/workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/lib-dynload/math.cpython-38-x86_64-linux-gnu.so'> expected: module id: math-module📌 Setup phase
duration:
0.00027621909976005554outcome:
passed📌 Call phase
duration:
0.00016484130173921585outcome:
passed📌 Teardown phase
duration:
0.00015838397666811943outcome:
passed -
✅ Test 487
params: obj="", expected="module"📌 Runtime Parameters
params: obj: <module 'sys' (built-in)> expected: module id: sys-module📌 Setup phase
duration:
0.00023249583318829536outcome:
passed📌 Call phase
duration:
0.00015611294656991959outcome:
passed📌 Teardown phase
duration:
0.0001678289845585823outcome:
passed -
✅ Test 488
params: obj="", expected="type"📌 Runtime Parameters
params: obj: <class 'function'> expected: type id: function-type📌 Setup phase
duration:
0.00023384299129247665outcome:
passed📌 Call phase
duration:
0.00014109071344137192outcome:
passed📌 Teardown phase
duration:
0.00014190981164574623outcome:
passed -
✅ Test 489
params: obj=" at 0x7f0de3a063c0>", expected="generator"📌 Runtime Parameters
params: obj: <generator object <genexpr> at 0x7f0de3a063c0> expected: generator id: <genexpr>-generator📌 Setup phase
duration:
0.00023647816851735115outcome:
passed📌 Call phase
duration:
0.00013414304703474045outcome:
passed📌 Teardown phase
duration:
0.00014432892203330994outcome:
passed -
✅ Test 490
params: obj="", expected="list_iterator"📌 Runtime Parameters
params: obj: <list_iterator object at 0x7f0de37c50d0> expected: list_iterator id: obj18-list_iterator📌 Setup phase
duration:
0.00022311881184577942outcome:
passed📌 Call phase
duration:
0.0001345970667898655outcome:
passed📌 Teardown phase
duration:
0.00016592442989349365outcome:
passed
↳ Function: test_next_int
-
✅ Test 491
params: nums=[1, 2, 3], expected=4📌 Runtime Parameters
params: nums: - 1 - 2 - 3 expected: 4 id: nums0-4📌 Setup phase
duration:
0.00024057598784565926outcome:
passed📌 Call phase
duration:
0.000146504957228899outcome:
passed📌 Teardown phase
duration:
0.00014988193288445473outcome:
passed -
✅ Test 492
params: nums=[10, 20], expected=21📌 Runtime Parameters
params: nums: - 10 - 20 expected: 21 id: nums1-21📌 Setup phase
duration:
0.0002263193018734455outcome:
passed📌 Call phase
duration:
0.00013659056276082993outcome:
passed📌 Teardown phase
duration:
0.00015249522402882576outcome:
passed -
✅ Test 493
params: nums=[], expected=0📌 Runtime Parameters
params: nums: [] expected: 0 id: nums2-0📌 Setup phase
duration:
0.00022532092407345772outcome:
passed📌 Call phase
duration:
0.00019787810742855072outcome:
passed📌 Teardown phase
duration:
0.00016044406220316887outcome:
passed
↳ Function: test_zero_pad
-
✅ Test 494
params: i=7, n=3, expected="007"📌 Runtime Parameters
params: i: 7 n: 3 expected: 007 id: 7-3-007📌 Setup phase
duration:
0.0002924082800745964outcome:
passed📌 Call phase
duration:
0.0001454586163163185outcome:
passed📌 Teardown phase
duration:
0.0001527019776403904outcome:
passed -
✅ Test 495
params: i=123, n=5, expected="00123"📌 Runtime Parameters
params: i: 123 n: 5 expected: 00123 id: 123-5-00123📌 Setup phase
duration:
0.00029576802626252174outcome:
passed📌 Call phase
duration:
0.00014525186270475388outcome:
passed📌 Teardown phase
duration:
0.00018227985128760338outcome:
passed -
✅ Test 496
params: i=0, n=2, expected="00"📌 Runtime Parameters
params: i: 0 n: 2 expected: 00 id: 0-2-00📌 Setup phase
duration:
0.00026177335530519485outcome:
passed📌 Call phase
duration:
0.00014377618208527565outcome:
passed📌 Teardown phase
duration:
0.00016760407015681267outcome:
passed
↳ Function: test_iround
-
✅ Test 497
params: val=3.6, expected=4📌 Runtime Parameters
params: val: 3.6 expected: 4 id: 3.6-4📌 Setup phase
duration:
0.00023916689679026604outcome:
passed📌 Call phase
duration:
0.000158797949552536outcome:
passed📌 Teardown phase
duration:
0.0001514861360192299outcome:
passed -
✅ Test 498
params: val=2.1, expected=2📌 Runtime Parameters
params: val: 2.1 expected: 2 id: 2.1-2📌 Setup phase
duration:
0.0002381531521677971outcome:
passed📌 Call phase
duration:
0.00013957591727375984outcome:
passed📌 Teardown phase
duration:
0.0001404029317200184outcome:
passed -
✅ Test 499
params: val=-1.5, expected=-2📌 Runtime Parameters
params: val: -1.5 expected: -2 id: -1.5--2📌 Setup phase
duration:
0.00023998087272047997outcome:
passed📌 Call phase
duration:
0.00015276717022061348outcome:
passed📌 Teardown phase
duration:
0.00014654779806733131outcome:
passed -
✅ Test 500
params: val=-1.4, expected=-1📌 Runtime Parameters
params: val: -1.4 expected: -1 id: -1.4--1📌 Setup phase
duration:
0.00022133998572826385outcome:
passed📌 Call phase
duration:
0.00015369011089205742outcome:
passed📌 Teardown phase
duration:
0.00015610409900546074outcome:
passed
↳ Function: test_sorted_naturally
-
✅ Test 501
params: items=["file1", "file10", "file2"], expected=["file1", "file2", "file10"]📌 Runtime Parameters
params: items: - file1 - file10 - file2 expected: - file1 - file2 - file10 id: items0-expected0📌 Setup phase
duration:
0.0002473369240760803outcome:
passed📌 Call phase
duration:
0.0001884237863123417outcome:
passed📌 Teardown phase
duration:
0.00015640584751963615outcome:
passed -
✅ Test 502
params: items=["z9", "z10", "z2", "z1"], expected=["z1", "z2", "z9", "z10"]📌 Runtime Parameters
params: items: - z9 - z10 - z2 - z1 expected: - z1 - z2 - z9 - z10 id: items1-expected1📌 Setup phase
duration:
0.0002277572639286518outcome:
passed📌 Call phase
duration:
0.0001648678444325924outcome:
passed📌 Teardown phase
duration:
0.00015334505587816238outcome:
passed
↳ Function: test_sorted_naturally_reverse
-
✅ Test 503
params: items=["file1", "file10", "file2"], expected=["file10", "file2", "file1"]📌 Runtime Parameters
params: items: - file1 - file10 - file2 expected: - file10 - file2 - file1 id: items0-expected0📌 Setup phase
duration:
0.0002378402277827263outcome:
passed📌 Call phase
duration:
0.0001647421158850193outcome:
passed📌 Teardown phase
duration:
0.00015148892998695374outcome:
passed
-
-
📄 test_utils_xrange.py
↳ Function: test_xrange_finite
-
✅ Test 504
params: args=[10], kwargs={}, expected=[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]📌 Runtime Parameters
params: args: - 10 kwargs: {} expected: - (vide) - 1 - 2 - 3 - 4 - 5 - 6 - 7 - 8 - 9 id: args0-kwargs0-expected0📌 Setup phase
duration:
0.00030716322362422943outcome:
passed📌 Call phase
duration:
0.00017002690583467484outcome:
passed📌 Teardown phase
duration:
0.0001723659224808216outcome:
passed -
✅ Test 505
params: args=[0, 10], kwargs={}, expected=[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]📌 Runtime Parameters
params: args: - (vide) - 10 kwargs: {} expected: - (vide) - 1 - 2 - 3 - 4 - 5 - 6 - 7 - 8 - 9 id: args1-kwargs1-expected1📌 Setup phase
duration:
0.00026318710297346115outcome:
passed📌 Call phase
duration:
0.0002593738026916981outcome:
passed📌 Teardown phase
duration:
0.00017026904970407486outcome:
passed -
✅ Test 506
params: args=[0, 10, 2], kwargs={}, expected=[0, 2, 4, 6, 8]📌 Runtime Parameters
params: args: - (vide) - 10 - 2 kwargs: {} expected: - (vide) - 2 - 4 - 6 - 8 id: args2-kwargs2-expected2📌 Setup phase
duration:
0.00028631463646888733outcome:
passed📌 Call phase
duration:
0.00014465395361185074outcome:
passed📌 Teardown phase
duration:
0.00015930505469441414outcome:
passed -
✅ Test 507
params: args=[10], kwargs={"step": 2}, expected=[0, 2, 4, 6, 8]📌 Runtime Parameters
params: args: - 10 kwargs: step: 2 expected: - (vide) - 2 - 4 - 6 - 8 id: args3-kwargs3-expected3📌 Setup phase
duration:
0.00027632806450128555outcome:
passed📌 Call phase
duration:
0.00014000432565808296outcome:
passed📌 Teardown phase
duration:
0.00015749502927064896outcome:
passed
↳ Function: test_xrange_infinite
-
✅ Test 508
params: args=[], kwargs={}, expected_repr="count(0)"📌 Runtime Parameters
params: args: [] kwargs: {} expected_repr: count(0) id: args0-kwargs0-count(0)📌 Setup phase
duration:
0.00027929432690143585outcome:
passed📌 Call phase
duration:
0.00015770364552736282outcome:
passed📌 Teardown phase
duration:
0.00016269832849502563outcome:
passed -
✅ Test 509
params: args=[], kwargs={"step": 2}, expected_repr="count(0, 2)"📌 Runtime Parameters
params: args: [] kwargs: step: 2 expected_repr: count(0, 2) id: args1-kwargs1-count(0, 2)📌 Setup phase
duration:
0.000282839871942997outcome:
passed📌 Call phase
duration:
0.00015250826254487038outcome:
passed📌 Teardown phase
duration:
0.0001573720946907997outcome:
passed
↳ Function: test_xrange_too_many_args
-
✅ Test 510
params: args=[1, 2, 3, 4]📌 Runtime Parameters
params: args: - 1 - 2 - 3 - 4 id: args0📌 Setup phase
duration:
0.00018476694822311401outcome:
passed📌 Call phase
duration:
0.0005244524218142033outcome:
passed📌 Teardown phase
duration:
0.0006734910421073437outcome:
passed
-
❌ Failed (34)
-
📄 test_utils_debug.py
↳ Function: test_short_repr
-
❌ Test 134
params: value="aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa", cutoff=10, expected="'aaaaaaaaaa..."📌 Runtime Parameters
params: value: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa cutoff: 10 expected: 'aaaaaaaaaa... id: aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa-10-'aaaaaaaaaa...📌 Setup phase
duration:
0.00026144832372665405outcome:
passed📌 Call phase
duration:
0.0011280979961156845outcome:
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.00036751292645931244outcome:
passed -
❌ Test 138
params: value="Obj(xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx)", cutoff=20, expected="Obj(xxxxxxxxxxxxxxxxx..."📌 Runtime Parameters
params: value: Obj(xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx) cutoff: 20 expected: Obj(xxxxxxxxxxxxxxxxx... id: value5-20-Obj(xxxxxxxxxxxxxxxxx...📌 Setup phase
duration:
0.0003346479497849941outcome:
passed📌 Call phase
duration:
0.0006899330765008926outcome:
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.00022837193682789803outcome:
passed
-
-
📄 test_utils_elog.py
↳ Function: test_post_local
-
❌ Test 159
📌 Setup phase
duration:
0.0001369146630167961outcome:
passed📌 Call phase
duration:
0.01021020533517003outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/elog/logbook.py lineno: 315 message: elog.logbook_exceptions.LogbookInvalidMessageID: Invalid message ID: None returnedtraceback:
- path: tests/test_utils_elog.py lineno: 46 message: None - path: .pixi/envs/default/lib/python3.8/site-packages/elog/logbook.py lineno: 315 message: LogbookInvalidMessageIDlongrepr:
def test_post_local(): logbook = elog.open( hostname="http://localhost", port=8080, user="robot", password="testpassword", use_ssl=False, logbook="demo" ) attributes = { "Author": "robot", "Subject": "Test simple", "Category": "General", "Type": "Note" } message = "Hello from local test" > msg_id = logbook.post(message, attributes=attributes, encoding="HTML") tests/test_utils_elog.py:46: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <elog.logbook.Logbook object at 0x7f0de37288e0> message = 'Hello from local test', msg_id = None, reply = False attributes = {'Author': 'robot', 'Category': 'General', 'Encoding': 'HTML', 'Subject': 'Test simple', ...} attachments = [], suppress_email_notification = False, encoding = 'HTML' timeout = None, kwargs = {} new_attachment_list = [('Text', ('', b'Hello from local test'))] objects_to_close = [] attributes_to_edit = {'Author': b'robot', 'Category': b'General', 'Encoding': b'HTML', 'Subject': b'Test simple', ...} def post(self, message, msg_id=None, reply=False, attributes=None, attachments=None, suppress_email_notification=False, encoding=None, timeout=None, **kwargs): """ Posts message to the logbook. If msg_id is not specified new message will be created, otherwise existing message will be edited, or a reply (if reply=True) to it will be created. This method returns the msg_id of the newly created message. :param message: string with message text :param msg_id: ID number of message to edit or reply. If not specified new message is created. :param reply: If 'True' reply to existing message is created instead of editing it :param attributes: Dictionary of attributes. Following attributes are used internally by the elog and will be ignored: Text, Date, Encoding, Reply to, In reply to, Locked by, Attachment :param attachments: list of: - file like objects which read() will return bytes (if file_like_object.name is not defined, default name "attachment<i>" will be used. - paths to the files All items will be appended as attachment to the elog entry. In case of unknown attachment an exception LogbookInvalidAttachment will be raised. :param suppress_email_notification: If set to True or 1, E-Mail notification will be suppressed, defaults to False. :param encoding: Defines encoding of the message. Can be: 'plain' -> plain text, 'html'->html-text, 'ELCode' --> elog formatting syntax :param timeout: Define the timeout to be used by the post request. Its value is directly passed to the requests post. Use None to disable the request timeout. :param kwargs: Anything in the kwargs will be interpreted as attribute. e.g.: logbook.post('Test text', Author='Rok Vintar), "Author" will be sent as an attribute. If named same as one of the attributes defined in "attributes", kwargs will have priority. :return: msg_id """ attributes = attributes or {} attributes = {**attributes, **kwargs} # kwargs as attributes with higher priority attachments = attachments or [] if encoding is not None: if encoding not in ['plain', 'HTML', 'ELCode']: raise LogbookMessageRejected('Invalid message encoding. Valid options: plain, HTML, ELCode.') attributes['Encoding'] = encoding if suppress_email_notification: attributes["suppress"] = 1 # THE ATTACHMENT STRATEGY WHEN DEALING WITH POST MODIFICATION # # 1. Does the message on the server have already attachments? # 1.1 - We read the message getting the existing attachment list. # 1.2 - Add to the attributes dictionary one line for each attachment like this: # attributes['attachmentN'] = timestamped_filename_name # # 2. Do we have new attachments? # 2.1 - Those are in the new_attachment_list. This is a list of this type: # [ ('attfileN', ('filename', fileobject)) ] # 2.2 - We need to loop over all the new attachments: # 2.2.1 - Does a file already on the server with the same name exist? # 2.2.1.1 - No: OK. Then we go ahead with the next attachment. # 2.2.1.2 - Yes: # 2.2.1.2.1 - Are the two files identical? # 2.2.1.2.1.1 - Yes: then we remove this current entry from the new_attachment_list and we leave the one # already on server. # 2.2.1.2.1.2 - No: # 2.2.1.2.1.2.1 - Then the file has been update. # 2.2.1.2.1.2.2 - We need to remove the file on server first (using special post) # 2.2.1.2.1.2.3 - We have to remove the old attachment from the attributes dictionary. # if attachments: # here we accomplish point 2.1. # new_attachment_list is something like [ ('attfileN', ('filename', fileobject)) ] new_attachment_list, objects_to_close = self._prepare_attachments(attachments) else: objects_to_close = list() new_attachment_list = list() attributes_to_edit = dict() if msg_id: # Message exists, we can continue if reply: # Verify that there is a message on the server, otherwise do not reply to it! self._check_if_message_on_server(msg_id) # raises exception in case of none existing message attributes['reply_to'] = str(msg_id) else: # Edit existing attributes['edit_id'] = str(msg_id) attributes['skiplock'] = '1' # here we accomplish point 1.1. # existing_attachments_list is something like: # [ 'https://elog.url.com/logbook/timestamped_filename' ] msg_to_edit, attributes_to_edit, existing_attachments_list = self.read(msg_id) for attribute, data in attributes.items(): new_data = attributes.get(attribute) if new_data is not None: attributes_to_edit[attribute] = new_data i = 0 existing_attachments_filename_list = list() for attachment in existing_attachments_list: # here we accomplish point 1.2. We strip the timestamped_filename from the whole URL. attributes_to_edit[f'attachment{i}'] = os.path.basename(attachment) existing_attachments_filename_list.append(os.path.basename(attachment)[14:]) i += 1 # let's accomplish 2.2. Loop over all new attachment duplicate_attachment_list = list() for new_attachment in new_attachment_list: # the new_attachment_list is something like: # [ ('attfileN', ('filename', fileobject)) ] new_attachment_filename = new_attachment[1][0] if new_attachment_filename in existing_attachments_filename_list: # a file with the same name existing already on the server. # we need to check if the two files are the same. # read the content of the new file new_attachment_content = new_attachment[1][1].read() # don't forget to reset the fileobj to the beginning of the file new_attachment[1][1].seek(0) # get the existing attachment content attachment_index = existing_attachments_filename_list.index(new_attachment_filename) existing_attachment_content = self.download_attachment( url=existing_attachments_list[attachment_index], timeout=timeout ) # check if the two contents are the same if new_attachment_content == existing_attachment_content: # yes. then we don't upload a second copy. we remove the current entry from the list duplicate_attachment_list.append(new_attachment) else: # no. they are not the same file. we will replace the existing file with the new one # first: we need to remove the attachment from the server using the dedicated method self.delete_attachment(msg_id, attributes=attributes_to_edit, attachment_id=attachment_index, timeout=timeout, text=msg_to_edit) # now we can remove this attachment from the auxiliary lists. existing_attachments_filename_list.pop(attachment_index) existing_attachments_list.pop(attachment_index) # now we need to rebuild the attributes dictionary for the part concerning the attachments. # we remove all of them first keys_to_be_removed = list() for key in attributes_to_edit.keys(): if key.startswith('attachment'): keys_to_be_removed.append(key) if key.startswith('delatt'): keys_to_be_removed.append(key) for key in keys_to_be_removed: del attributes_to_edit[key] # now we rebuild it for i, attachment in enumerate(existing_attachments_list): attributes_to_edit[f'attachment{i}'] = os.path.basename(attachment) # remove all duplicate attachments from the new_attachment_list for attach in duplicate_attachment_list: new_attachment_list.remove(attach) else: # As we create a new message, specify creation time if not already specified in attributes if 'When' not in attributes: attributes['When'] = int(datetime.now().timestamp()) if not attributes_to_edit: attributes_to_edit = attributes # Remove any attributes that should not be sent _remove_reserved_attributes(attributes_to_edit) # Make requests module think that Text is a "file". This is the only way to force requests to send data as # multipart/form-data even if there are no attachments. Elog understands only multipart/form-data new_attachment_list.append(('Text', ('', message.encode('iso-8859-1')))) # Base attributes are common to all messages self._add_base_msg_attributes(attributes_to_edit) # Keys in attributes cannot have certain characters like whitespaces or dashes for the http request attributes_to_edit = _replace_special_characters_in_attribute_keys(attributes_to_edit) # All string values in the attributes must be encoded in latin1 attributes_to_edit = _encode_values(attributes_to_edit) try: response = requests.post(self._url, data=attributes_to_edit, files=new_attachment_list, allow_redirects=False, verify=False, timeout=timeout) # Validate response. Any problems will raise an Exception. resp_message, resp_headers, resp_msg_id = _validate_response(response) # Close file like objects that were opened by the elog (if path for file_like_object in objects_to_close: if hasattr(file_like_object, 'close'): file_like_object.close() except requests.Timeout as e: # Catch here a timeout o the post request. # Raise the logbook excetion and let the user handle it raise LogbookServerTimeout('{0} method cannot be completed because of a network timeout:\n' + '{1}'.format(sys._getframe().f_code.co_name, e)) except requests.RequestException as e: # Check if message on server. self._check_if_message_on_server(msg_id) # raises exceptions if no message or no response from server # If here: message is on server but cannot be downloaded (should never happen) raise LogbookServerProblem('Cannot access logbook server to post a message, ' + 'because of:\n' + '{0}'.format(e)) # Any error before here should raise an exception, but check again for nay case. if not resp_msg_id or resp_msg_id < 1: > raise LogbookInvalidMessageID('Invalid message ID: ' + str(resp_msg_id) + ' returned') E elog.logbook_exceptions.LogbookInvalidMessageID: Invalid message ID: None returned .pixi/envs/default/lib/python3.8/site-packages/elog/logbook.py:315: LogbookInvalidMessageID📌 Teardown phase
duration:
0.0002090930938720703outcome:
passed
↳ Function: test_post
-
❌ Test 163
📌 Setup phase
duration:
0.00012417137622833252outcome:
passed📌 Call phase
duration:
0.00578102795407176outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/elog/logbook.py lineno: 315 message: elog.logbook_exceptions.LogbookInvalidMessageID: Invalid message ID: None returnedtraceback:
- path: tests/test_utils_elog.py lineno: 123 message: None - path: slic/utils/elog.py lineno: 29 message: in post - path: .pixi/envs/default/lib/python3.8/site-packages/elog/logbook.py lineno: 315 message: LogbookInvalidMessageIDlongrepr:
def test_post(): elog = get_test_elog() title = "AUTHOR_OVERRIDE_TEST" text = "This is a message" author = "robot" > elog.post(text, Author=author) tests/test_utils_elog.py:123: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ slic/utils/elog.py:29: in post return self._log.post(*args, **kwargs) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <elog.logbook.Logbook object at 0x7f0de368d5e0> message = 'This is a message', msg_id = None, reply = False attributes = {'Author': 'robot', 'When': 1754565318, 'cmd': 'Submit', 'exp': 'demo', ...} attachments = [], suppress_email_notification = False, encoding = None timeout = None, kwargs = {'Author': 'robot'} new_attachment_list = [('Text', ('', b'This is a message'))] objects_to_close = [] attributes_to_edit = {'Author': b'robot', 'When': 1754565318, 'cmd': b'Submit', 'exp': b'demo', ...} def post(self, message, msg_id=None, reply=False, attributes=None, attachments=None, suppress_email_notification=False, encoding=None, timeout=None, **kwargs): """ Posts message to the logbook. If msg_id is not specified new message will be created, otherwise existing message will be edited, or a reply (if reply=True) to it will be created. This method returns the msg_id of the newly created message. :param message: string with message text :param msg_id: ID number of message to edit or reply. If not specified new message is created. :param reply: If 'True' reply to existing message is created instead of editing it :param attributes: Dictionary of attributes. Following attributes are used internally by the elog and will be ignored: Text, Date, Encoding, Reply to, In reply to, Locked by, Attachment :param attachments: list of: - file like objects which read() will return bytes (if file_like_object.name is not defined, default name "attachment<i>" will be used. - paths to the files All items will be appended as attachment to the elog entry. In case of unknown attachment an exception LogbookInvalidAttachment will be raised. :param suppress_email_notification: If set to True or 1, E-Mail notification will be suppressed, defaults to False. :param encoding: Defines encoding of the message. Can be: 'plain' -> plain text, 'html'->html-text, 'ELCode' --> elog formatting syntax :param timeout: Define the timeout to be used by the post request. Its value is directly passed to the requests post. Use None to disable the request timeout. :param kwargs: Anything in the kwargs will be interpreted as attribute. e.g.: logbook.post('Test text', Author='Rok Vintar), "Author" will be sent as an attribute. If named same as one of the attributes defined in "attributes", kwargs will have priority. :return: msg_id """ attributes = attributes or {} attributes = {**attributes, **kwargs} # kwargs as attributes with higher priority attachments = attachments or [] if encoding is not None: if encoding not in ['plain', 'HTML', 'ELCode']: raise LogbookMessageRejected('Invalid message encoding. Valid options: plain, HTML, ELCode.') attributes['Encoding'] = encoding if suppress_email_notification: attributes["suppress"] = 1 # THE ATTACHMENT STRATEGY WHEN DEALING WITH POST MODIFICATION # # 1. Does the message on the server have already attachments? # 1.1 - We read the message getting the existing attachment list. # 1.2 - Add to the attributes dictionary one line for each attachment like this: # attributes['attachmentN'] = timestamped_filename_name # # 2. Do we have new attachments? # 2.1 - Those are in the new_attachment_list. This is a list of this type: # [ ('attfileN', ('filename', fileobject)) ] # 2.2 - We need to loop over all the new attachments: # 2.2.1 - Does a file already on the server with the same name exist? # 2.2.1.1 - No: OK. Then we go ahead with the next attachment. # 2.2.1.2 - Yes: # 2.2.1.2.1 - Are the two files identical? # 2.2.1.2.1.1 - Yes: then we remove this current entry from the new_attachment_list and we leave the one # already on server. # 2.2.1.2.1.2 - No: # 2.2.1.2.1.2.1 - Then the file has been update. # 2.2.1.2.1.2.2 - We need to remove the file on server first (using special post) # 2.2.1.2.1.2.3 - We have to remove the old attachment from the attributes dictionary. # if attachments: # here we accomplish point 2.1. # new_attachment_list is something like [ ('attfileN', ('filename', fileobject)) ] new_attachment_list, objects_to_close = self._prepare_attachments(attachments) else: objects_to_close = list() new_attachment_list = list() attributes_to_edit = dict() if msg_id: # Message exists, we can continue if reply: # Verify that there is a message on the server, otherwise do not reply to it! self._check_if_message_on_server(msg_id) # raises exception in case of none existing message attributes['reply_to'] = str(msg_id) else: # Edit existing attributes['edit_id'] = str(msg_id) attributes['skiplock'] = '1' # here we accomplish point 1.1. # existing_attachments_list is something like: # [ 'https://elog.url.com/logbook/timestamped_filename' ] msg_to_edit, attributes_to_edit, existing_attachments_list = self.read(msg_id) for attribute, data in attributes.items(): new_data = attributes.get(attribute) if new_data is not None: attributes_to_edit[attribute] = new_data i = 0 existing_attachments_filename_list = list() for attachment in existing_attachments_list: # here we accomplish point 1.2. We strip the timestamped_filename from the whole URL. attributes_to_edit[f'attachment{i}'] = os.path.basename(attachment) existing_attachments_filename_list.append(os.path.basename(attachment)[14:]) i += 1 # let's accomplish 2.2. Loop over all new attachment duplicate_attachment_list = list() for new_attachment in new_attachment_list: # the new_attachment_list is something like: # [ ('attfileN', ('filename', fileobject)) ] new_attachment_filename = new_attachment[1][0] if new_attachment_filename in existing_attachments_filename_list: # a file with the same name existing already on the server. # we need to check if the two files are the same. # read the content of the new file new_attachment_content = new_attachment[1][1].read() # don't forget to reset the fileobj to the beginning of the file new_attachment[1][1].seek(0) # get the existing attachment content attachment_index = existing_attachments_filename_list.index(new_attachment_filename) existing_attachment_content = self.download_attachment( url=existing_attachments_list[attachment_index], timeout=timeout ) # check if the two contents are the same if new_attachment_content == existing_attachment_content: # yes. then we don't upload a second copy. we remove the current entry from the list duplicate_attachment_list.append(new_attachment) else: # no. they are not the same file. we will replace the existing file with the new one # first: we need to remove the attachment from the server using the dedicated method self.delete_attachment(msg_id, attributes=attributes_to_edit, attachment_id=attachment_index, timeout=timeout, text=msg_to_edit) # now we can remove this attachment from the auxiliary lists. existing_attachments_filename_list.pop(attachment_index) existing_attachments_list.pop(attachment_index) # now we need to rebuild the attributes dictionary for the part concerning the attachments. # we remove all of them first keys_to_be_removed = list() for key in attributes_to_edit.keys(): if key.startswith('attachment'): keys_to_be_removed.append(key) if key.startswith('delatt'): keys_to_be_removed.append(key) for key in keys_to_be_removed: del attributes_to_edit[key] # now we rebuild it for i, attachment in enumerate(existing_attachments_list): attributes_to_edit[f'attachment{i}'] = os.path.basename(attachment) # remove all duplicate attachments from the new_attachment_list for attach in duplicate_attachment_list: new_attachment_list.remove(attach) else: # As we create a new message, specify creation time if not already specified in attributes if 'When' not in attributes: attributes['When'] = int(datetime.now().timestamp()) if not attributes_to_edit: attributes_to_edit = attributes # Remove any attributes that should not be sent _remove_reserved_attributes(attributes_to_edit) # Make requests module think that Text is a "file". This is the only way to force requests to send data as # multipart/form-data even if there are no attachments. Elog understands only multipart/form-data new_attachment_list.append(('Text', ('', message.encode('iso-8859-1')))) # Base attributes are common to all messages self._add_base_msg_attributes(attributes_to_edit) # Keys in attributes cannot have certain characters like whitespaces or dashes for the http request attributes_to_edit = _replace_special_characters_in_attribute_keys(attributes_to_edit) # All string values in the attributes must be encoded in latin1 attributes_to_edit = _encode_values(attributes_to_edit) try: response = requests.post(self._url, data=attributes_to_edit, files=new_attachment_list, allow_redirects=False, verify=False, timeout=timeout) # Validate response. Any problems will raise an Exception. resp_message, resp_headers, resp_msg_id = _validate_response(response) # Close file like objects that were opened by the elog (if path for file_like_object in objects_to_close: if hasattr(file_like_object, 'close'): file_like_object.close() except requests.Timeout as e: # Catch here a timeout o the post request. # Raise the logbook excetion and let the user handle it raise LogbookServerTimeout('{0} method cannot be completed because of a network timeout:\n' + '{1}'.format(sys._getframe().f_code.co_name, e)) except requests.RequestException as e: # Check if message on server. self._check_if_message_on_server(msg_id) # raises exceptions if no message or no response from server # If here: message is on server but cannot be downloaded (should never happen) raise LogbookServerProblem('Cannot access logbook server to post a message, ' + 'because of:\n' + '{0}'.format(e)) # Any error before here should raise an exception, but check again for nay case. if not resp_msg_id or resp_msg_id < 1: > raise LogbookInvalidMessageID('Invalid message ID: ' + str(resp_msg_id) + ' returned') E elog.logbook_exceptions.LogbookInvalidMessageID: Invalid message ID: None returned .pixi/envs/default/lib/python3.8/site-packages/elog/logbook.py:315: LogbookInvalidMessageID📌 Teardown phase
duration:
0.00017645396292209625outcome:
passed
↳ Function: test_screenshot
-
❌ Test 164
📌 Setup phase
duration:
0.0001319441944360733outcome:
passed📌 Call phase
duration:
0.007404252886772156outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/elog/logbook.py lineno: 315 message: elog.logbook_exceptions.LogbookInvalidMessageID: Invalid message ID: None returnedtraceback:
- path: tests/test_utils_elog.py lineno: 144 message: None - path: slic/utils/elog.py lineno: 37 message: in screenshot - path: slic/utils/elog.py lineno: 29 message: in post - path: .pixi/envs/default/lib/python3.8/site-packages/elog/logbook.py lineno: 315 message: LogbookInvalidMessageIDlongrepr:
mock_screenshot_class = <MagicMock name='Screenshot' id='139697626694368'> @patch("slic.utils.elog.Screenshot") def test_screenshot(mock_screenshot_class): with tempfile.NamedTemporaryFile(delete=False, suffix=".png") as tmp: fake_path = tmp.name tmp.write(b"fake image data") mock_instance = mock_screenshot_class.return_value mock_instance.shoot.return_value = [fake_path] elog = get_test_elog() test_msg = "SCREENSHOT_INTEGRATION_TEST_MSG_456" > entry_id = elog.screenshot(message=test_msg) tests/test_utils_elog.py:144: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ slic/utils/elog.py:37: in screenshot self.post(message, **kwargs) slic/utils/elog.py:29: in post return self._log.post(*args, **kwargs) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <elog.logbook.Logbook object at 0x7f0de370a130> message = 'SCREENSHOT_INTEGRATION_TEST_MSG_456', msg_id = None, reply = False attributes = {'Author': 'robot', 'When': 1754565318, 'cmd': 'Submit', 'exp': 'demo', ...} attachments = ['/tmp/tmp7cuaqjht.png'], suppress_email_notification = False encoding = None, timeout = None, kwargs = {'Author': 'robot'} new_attachment_list = [('attfile0', ('tmp7cuaqjht.png', <_io.BufferedReader name='/tmp/tmp7cuaqjht.png'>)), ('Text', ('', b'SCREENSHOT_INTEGRATION_TEST_MSG_456'))] objects_to_close = [<_io.BufferedReader name='/tmp/tmp7cuaqjht.png'>] attributes_to_edit = {'Author': b'robot', 'When': 1754565318, 'cmd': b'Submit', 'exp': b'demo', ...} def post(self, message, msg_id=None, reply=False, attributes=None, attachments=None, suppress_email_notification=False, encoding=None, timeout=None, **kwargs): """ Posts message to the logbook. If msg_id is not specified new message will be created, otherwise existing message will be edited, or a reply (if reply=True) to it will be created. This method returns the msg_id of the newly created message. :param message: string with message text :param msg_id: ID number of message to edit or reply. If not specified new message is created. :param reply: If 'True' reply to existing message is created instead of editing it :param attributes: Dictionary of attributes. Following attributes are used internally by the elog and will be ignored: Text, Date, Encoding, Reply to, In reply to, Locked by, Attachment :param attachments: list of: - file like objects which read() will return bytes (if file_like_object.name is not defined, default name "attachment<i>" will be used. - paths to the files All items will be appended as attachment to the elog entry. In case of unknown attachment an exception LogbookInvalidAttachment will be raised. :param suppress_email_notification: If set to True or 1, E-Mail notification will be suppressed, defaults to False. :param encoding: Defines encoding of the message. Can be: 'plain' -> plain text, 'html'->html-text, 'ELCode' --> elog formatting syntax :param timeout: Define the timeout to be used by the post request. Its value is directly passed to the requests post. Use None to disable the request timeout. :param kwargs: Anything in the kwargs will be interpreted as attribute. e.g.: logbook.post('Test text', Author='Rok Vintar), "Author" will be sent as an attribute. If named same as one of the attributes defined in "attributes", kwargs will have priority. :return: msg_id """ attributes = attributes or {} attributes = {**attributes, **kwargs} # kwargs as attributes with higher priority attachments = attachments or [] if encoding is not None: if encoding not in ['plain', 'HTML', 'ELCode']: raise LogbookMessageRejected('Invalid message encoding. Valid options: plain, HTML, ELCode.') attributes['Encoding'] = encoding if suppress_email_notification: attributes["suppress"] = 1 # THE ATTACHMENT STRATEGY WHEN DEALING WITH POST MODIFICATION # # 1. Does the message on the server have already attachments? # 1.1 - We read the message getting the existing attachment list. # 1.2 - Add to the attributes dictionary one line for each attachment like this: # attributes['attachmentN'] = timestamped_filename_name # # 2. Do we have new attachments? # 2.1 - Those are in the new_attachment_list. This is a list of this type: # [ ('attfileN', ('filename', fileobject)) ] # 2.2 - We need to loop over all the new attachments: # 2.2.1 - Does a file already on the server with the same name exist? # 2.2.1.1 - No: OK. Then we go ahead with the next attachment. # 2.2.1.2 - Yes: # 2.2.1.2.1 - Are the two files identical? # 2.2.1.2.1.1 - Yes: then we remove this current entry from the new_attachment_list and we leave the one # already on server. # 2.2.1.2.1.2 - No: # 2.2.1.2.1.2.1 - Then the file has been update. # 2.2.1.2.1.2.2 - We need to remove the file on server first (using special post) # 2.2.1.2.1.2.3 - We have to remove the old attachment from the attributes dictionary. # if attachments: # here we accomplish point 2.1. # new_attachment_list is something like [ ('attfileN', ('filename', fileobject)) ] new_attachment_list, objects_to_close = self._prepare_attachments(attachments) else: objects_to_close = list() new_attachment_list = list() attributes_to_edit = dict() if msg_id: # Message exists, we can continue if reply: # Verify that there is a message on the server, otherwise do not reply to it! self._check_if_message_on_server(msg_id) # raises exception in case of none existing message attributes['reply_to'] = str(msg_id) else: # Edit existing attributes['edit_id'] = str(msg_id) attributes['skiplock'] = '1' # here we accomplish point 1.1. # existing_attachments_list is something like: # [ 'https://elog.url.com/logbook/timestamped_filename' ] msg_to_edit, attributes_to_edit, existing_attachments_list = self.read(msg_id) for attribute, data in attributes.items(): new_data = attributes.get(attribute) if new_data is not None: attributes_to_edit[attribute] = new_data i = 0 existing_attachments_filename_list = list() for attachment in existing_attachments_list: # here we accomplish point 1.2. We strip the timestamped_filename from the whole URL. attributes_to_edit[f'attachment{i}'] = os.path.basename(attachment) existing_attachments_filename_list.append(os.path.basename(attachment)[14:]) i += 1 # let's accomplish 2.2. Loop over all new attachment duplicate_attachment_list = list() for new_attachment in new_attachment_list: # the new_attachment_list is something like: # [ ('attfileN', ('filename', fileobject)) ] new_attachment_filename = new_attachment[1][0] if new_attachment_filename in existing_attachments_filename_list: # a file with the same name existing already on the server. # we need to check if the two files are the same. # read the content of the new file new_attachment_content = new_attachment[1][1].read() # don't forget to reset the fileobj to the beginning of the file new_attachment[1][1].seek(0) # get the existing attachment content attachment_index = existing_attachments_filename_list.index(new_attachment_filename) existing_attachment_content = self.download_attachment( url=existing_attachments_list[attachment_index], timeout=timeout ) # check if the two contents are the same if new_attachment_content == existing_attachment_content: # yes. then we don't upload a second copy. we remove the current entry from the list duplicate_attachment_list.append(new_attachment) else: # no. they are not the same file. we will replace the existing file with the new one # first: we need to remove the attachment from the server using the dedicated method self.delete_attachment(msg_id, attributes=attributes_to_edit, attachment_id=attachment_index, timeout=timeout, text=msg_to_edit) # now we can remove this attachment from the auxiliary lists. existing_attachments_filename_list.pop(attachment_index) existing_attachments_list.pop(attachment_index) # now we need to rebuild the attributes dictionary for the part concerning the attachments. # we remove all of them first keys_to_be_removed = list() for key in attributes_to_edit.keys(): if key.startswith('attachment'): keys_to_be_removed.append(key) if key.startswith('delatt'): keys_to_be_removed.append(key) for key in keys_to_be_removed: del attributes_to_edit[key] # now we rebuild it for i, attachment in enumerate(existing_attachments_list): attributes_to_edit[f'attachment{i}'] = os.path.basename(attachment) # remove all duplicate attachments from the new_attachment_list for attach in duplicate_attachment_list: new_attachment_list.remove(attach) else: # As we create a new message, specify creation time if not already specified in attributes if 'When' not in attributes: attributes['When'] = int(datetime.now().timestamp()) if not attributes_to_edit: attributes_to_edit = attributes # Remove any attributes that should not be sent _remove_reserved_attributes(attributes_to_edit) # Make requests module think that Text is a "file". This is the only way to force requests to send data as # multipart/form-data even if there are no attachments. Elog understands only multipart/form-data new_attachment_list.append(('Text', ('', message.encode('iso-8859-1')))) # Base attributes are common to all messages self._add_base_msg_attributes(attributes_to_edit) # Keys in attributes cannot have certain characters like whitespaces or dashes for the http request attributes_to_edit = _replace_special_characters_in_attribute_keys(attributes_to_edit) # All string values in the attributes must be encoded in latin1 attributes_to_edit = _encode_values(attributes_to_edit) try: response = requests.post(self._url, data=attributes_to_edit, files=new_attachment_list, allow_redirects=False, verify=False, timeout=timeout) # Validate response. Any problems will raise an Exception. resp_message, resp_headers, resp_msg_id = _validate_response(response) # Close file like objects that were opened by the elog (if path for file_like_object in objects_to_close: if hasattr(file_like_object, 'close'): file_like_object.close() except requests.Timeout as e: # Catch here a timeout o the post request. # Raise the logbook excetion and let the user handle it raise LogbookServerTimeout('{0} method cannot be completed because of a network timeout:\n' + '{1}'.format(sys._getframe().f_code.co_name, e)) except requests.RequestException as e: # Check if message on server. self._check_if_message_on_server(msg_id) # raises exceptions if no message or no response from server # If here: message is on server but cannot be downloaded (should never happen) raise LogbookServerProblem('Cannot access logbook server to post a message, ' + 'because of:\n' + '{0}'.format(e)) # Any error before here should raise an exception, but check again for nay case. if not resp_msg_id or resp_msg_id < 1: > raise LogbookInvalidMessageID('Invalid message ID: ' + str(resp_msg_id) + ' returned') E elog.logbook_exceptions.LogbookInvalidMessageID: Invalid message ID: None returned .pixi/envs/default/lib/python3.8/site-packages/elog/logbook.py:315: LogbookInvalidMessageID📌 Teardown phase
duration:
0.00019628601148724556outcome:
passed
-
-
📄 test_utils_hastyepics.py
↳ Function: test_motor_instantiation_fast_vs_epics
-
❌ Test 217
📌 Setup phase
duration:
0.00012141000479459763outcome:
passed📌 Call phase
duration:
0.106364281848073outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_hastyepics.py lineno: 37 message: AssertionError: Fast version (0.010151s) should be faster than EPICS (0.000268s) assert 0.010151366470381618 < 0.0002676277421414852traceback:
- path: tests/test_utils_hastyepics.py lineno: 37 message: AssertionErrorlongrepr:
def test_motor_instantiation_fast_vs_epics(): fast_times = [] slow_times = [] # Mock to simulate a real EPICS moteur with patch('epics.Motor.get') as mock_get: mock_get.return_value = 'motor' # Mean of 10 runs for _ in range(10): t0 = time.perf_counter() m_fast = Motor("TEST:MOTOR_t1") t1 = time.perf_counter() t2 = time.perf_counter() m_slow = epics.Motor("TEST:MOTOR_t2") t3 = time.perf_counter() fast_times.append(t1 - t0) slow_times.append(t3 - t2) avg_fast = sum(fast_times) / len(fast_times) avg_slow = sum(slow_times) / len(slow_times) > assert avg_fast < avg_slow, f"Fast version ({avg_fast:.6f}s) should be faster than EPICS ({avg_slow:.6f}s)" E AssertionError: Fast version (0.010151s) should be faster than EPICS (0.000268s) E assert 0.010151366470381618 < 0.0002676277421414852 tests/test_utils_hastyepics.py:37: AssertionError📌 Teardown phase
duration:
0.0004616798833012581outcome:
passed
↳ Function: test_motor_without_suffix_and_dot
-
❌ Test 218
📌 Setup phase
duration:
0.0002361796796321869outcome:
passed📌 Call phase
duration:
0.0018592197448015213outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_hastyepics.py lineno: 42 message: AssertionError: assert 'TEST:MOTOR_1.' == 'TEST:MOTOR_1' - TEST:MOTOR_1 + TEST:MOTOR_1. ? +traceback:
- path: tests/test_utils_hastyepics.py lineno: 42 message: AssertionErrorlongrepr:
def test_motor_without_suffix_and_dot(): # Suffix .VAL ... dot should be stripped from name m1 = Motor("TEST:MOTOR_1.VAL") > assert m1._prefix == "TEST:MOTOR_1" E AssertionError: assert 'TEST:MOTOR_1.' == 'TEST:MOTOR_1' E E - TEST:MOTOR_1 E + TEST:MOTOR_1. E ? + tests/test_utils_hastyepics.py:42: AssertionError📌 Teardown phase
duration:
0.00018388405442237854outcome:
passed
↳ Function: test_motor_initializes_device_attrs
-
❌ Test 221
📌 Setup phase
duration:
0.00010933401063084602outcome:
passed📌 Call phase
duration:
0.0015153707936406136outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_hastyepics.py lineno: 79 message: AssertionError: VAL is not a valid PV object assert False + where False = isinstance(None, <class 'epics.pv.PV'>) + where <class 'epics.pv.PV'> = <module 'epics.pv' from '/workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pyepics-3.4.3-py3.9.egg/epics/pv.py'>.PV + where <module 'epics.pv' from '/workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pyepics-3.4.3-py3.9.egg/epics/pv.py'> = epics.pvtraceback:
- path: tests/test_utils_hastyepics.py lineno: 79 message: AssertionErrorlongrepr:
def test_motor_initializes_device_attrs(): # Check that Motor correctly initializes all Device PVs from _init_list m = Motor("TEST:MOTOR") print("_init_list contents:", m._init_list) print("All attributes on motor:", dir(m)) for attr in m._init_list: print(f"\nChecking attribute: {attr}") assert hasattr(m, attr), f"Motor is missing attribute: {attr}" pv = getattr(m, attr) print(f"PV object: {pv}") print("Type:", type(pv)) if pv is not None: print(f"PV name: {pv.pvname}") print(f"PV connected: {pv.connected}") > assert isinstance(pv, epics.pv.PV), f"{attr} is not a valid PV object" E AssertionError: VAL is not a valid PV object E assert False E + where False = isinstance(None, <class 'epics.pv.PV'>) E + where <class 'epics.pv.PV'> = <module 'epics.pv' from '/workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pyepics-3.4.3-py3.9.egg/epics/pv.py'>.PV E + where <module 'epics.pv' from '/workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pyepics-3.4.3-py3.9.egg/epics/pv.py'> = epics.pv tests/test_utils_hastyepics.py:79: AssertionError📌 Teardown phase
duration:
0.0001540076918900013outcome:
passed
-
-
📄 test_utils_logcfg.py
↳ Function: test_import_logging_once_per_module
-
❌ Test 237
📌 Setup phase
duration:
0.00013499334454536438outcome:
passed📌 Call phase
duration:
1.7891154941171408outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_logcfg.py lineno: 78 message: AssertionError: Expected 1 import log for 'math', found 0 assert 0 == 1traceback:
- path: tests/test_utils_logcfg.py lineno: 78 message: AssertionErrorlongrepr:
def test_import_logging_once_per_module(): code = textwrap.dedent(""" from slic.utils.logcfg import * import math import io import random """) with tempfile.NamedTemporaryFile("w", suffix=".py", delete=False) as tmp: tmp.write(code) tmp_path = tmp.name env = os.environ.copy() root_path = os.path.abspath(os.path.join(os.path.dirname(__file__), '..')) env["PYTHONPATH"] = root_path + os.pathsep + env.get("PYTHONPATH", "") result = subprocess.run([sys.executable, tmp_path], capture_output=True, text=True, env=env) os.remove(tmp_path) assert result.returncode == 0, f"Script failed:\n{result.stderr}" stderr = result.stderr print(stderr) lines = stderr.splitlines() for mod in ["math", "io", "random"]: count = sum(1 for line in lines if f"importing: {mod}" in line) > assert count == 1, f"Expected 1 import log for '{mod}', found {count}" E AssertionError: Expected 1 import log for 'math', found 0 E assert 0 == 1 tests/test_utils_logcfg.py:78: AssertionError📌 Teardown phase
duration:
0.0005183550529181957outcome:
passed
-
-
📄 test_utils_npy.py
↳ Function: test_nice_arange
-
❌ Test 247
params: start=5, stop=0, step=-1, expected="[5. 4. 3. 2. 1. 0.]"📌 Runtime Parameters
params: start: 5 stop: 0 step: -1 expected: [5. 4. 3. 2. 1. 0.] id: 5-0--1-expected1📌 Setup phase
duration:
0.00040553417056798935outcome:
passed📌 Call phase
duration:
0.0010469132103025913outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-06, atol=0 Mismatched elements: 6 / 6 (100%) Max absolute difference: 5. Max relative difference: 3. x: array([0., 1., 2., 3., 4., 5.]) y: array([5., 4., 3., 2., 1., 0.])traceback:
- path: tests/test_utils_npy.py lineno: 16 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = 5, stop = 0, step = -1, expected = array([5., 4., 3., 2., 1., 0.]) @pytest.mark.parametrize("start, stop, step, expected", [ (0, 5, 1, np.linspace(0, 5, 6)), # regular integer step (5, 0, -1, np.linspace(5, 0, 6)), # reversed with negative step (1, 2, 0.3, np.linspace(1, 2, 4)), # step doesn't divide evenly (-2, 2, 1.5, np.linspace(-2, 2, 3)), # centered range (2.5, 0.5, -0.4, np.linspace(2.5, 0.5, 6)), # reversed float ]) def test_nice_arange(start, stop, step, expected): > np.testing.assert_allclose(nice_arange(start, stop, step), expected, rtol=1e-6) tests/test_utils_npy.py:16: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0d903bab80>, array([0., 1., 2., 3., 4., 5.]), array([5., 4., 3., 2., 1., 0.])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-06, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-06, atol=0 E E Mismatched elements: 6 / 6 (100%) E Max absolute difference: 5. E Max relative difference: 3. E x: array([0., 1., 2., 3., 4., 5.]) E y: array([5., 4., 3., 2., 1., 0.]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.00023727165535092354outcome:
passed -
❌ Test 249
params: start=-2, stop=2, step=1.5, expected="[-2. 0. 2.]"📌 Runtime Parameters
params: start: -2 stop: 2 step: 1.5 expected: [-2. 0. 2.] id: -2-2-1.5-expected3📌 Setup phase
duration:
0.00035989610478281975outcome:
passed📌 Call phase
duration:
0.000559165608137846outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-06, atol=0 (shapes (4,), (3,) mismatch) x: array([-2. , -0.666667, 0.666667, 2. ]) y: array([-2., 0., 2.])traceback:
- path: tests/test_utils_npy.py lineno: 16 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = -2, stop = 2, step = 1.5, expected = array([-2., 0., 2.]) @pytest.mark.parametrize("start, stop, step, expected", [ (0, 5, 1, np.linspace(0, 5, 6)), # regular integer step (5, 0, -1, np.linspace(5, 0, 6)), # reversed with negative step (1, 2, 0.3, np.linspace(1, 2, 4)), # step doesn't divide evenly (-2, 2, 1.5, np.linspace(-2, 2, 3)), # centered range (2.5, 0.5, -0.4, np.linspace(2.5, 0.5, 6)), # reversed float ]) def test_nice_arange(start, stop, step, expected): > np.testing.assert_allclose(nice_arange(start, stop, step), expected, rtol=1e-6) tests/test_utils_npy.py:16: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0d90337dc0>, array([-2. , -0.66666667, 0.66666667, 2. ]), array([-2., 0., 2.])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-06, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-06, atol=0 E E (shapes (4,), (3,) mismatch) E x: array([-2. , -0.666667, 0.666667, 2. ]) E y: array([-2., 0., 2.]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.00024340907111763954outcome:
passed -
❌ Test 250
params: start=2.5, stop=0.5, step=-0.4, expected="[2.5 2.1 1.7 1.3 0.9 0.5]"📌 Runtime Parameters
params: start: 2.5 stop: 0.5 step: -0.4 expected: [2.5 2.1 1.7 1.3 0.9 0.5] id: 2.5-0.5--0.4-expected4📌 Setup phase
duration:
0.00037662778049707413outcome:
passed📌 Call phase
duration:
0.0009543891064822674outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-06, atol=0 Mismatched elements: 6 / 6 (100%) Max absolute difference: 2. Max relative difference: 4. x: array([0.5, 0.9, 1.3, 1.7, 2.1, 2.5]) y: array([2.5, 2.1, 1.7, 1.3, 0.9, 0.5])traceback:
- path: tests/test_utils_npy.py lineno: 16 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = 2.5, stop = 0.5, step = -0.4 expected = array([2.5, 2.1, 1.7, 1.3, 0.9, 0.5]) @pytest.mark.parametrize("start, stop, step, expected", [ (0, 5, 1, np.linspace(0, 5, 6)), # regular integer step (5, 0, -1, np.linspace(5, 0, 6)), # reversed with negative step (1, 2, 0.3, np.linspace(1, 2, 4)), # step doesn't divide evenly (-2, 2, 1.5, np.linspace(-2, 2, 3)), # centered range (2.5, 0.5, -0.4, np.linspace(2.5, 0.5, 6)), # reversed float ]) def test_nice_arange(start, stop, step, expected): > np.testing.assert_allclose(nice_arange(start, stop, step), expected, rtol=1e-6) tests/test_utils_npy.py:16: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0d8f2175e0>, array([0.5, 0.9, 1.3, 1.7, 2.1, 2.5]), array([2.5, 2.1, 1.7, 1.3, 0.9, 0.5])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-06, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-06, atol=0 E E Mismatched elements: 6 / 6 (100%) E Max absolute difference: 2. E Max relative difference: 4. E x: array([0.5, 0.9, 1.3, 1.7, 2.1, 2.5]) E y: array([2.5, 2.1, 1.7, 1.3, 0.9, 0.5]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.00027506519109010696outcome:
passed
↳ Function: test_nice_steps_left_aligned
-
❌ Test 262
params: start=0, stop=5, step=2, endpoint=true, expected="[0. 2. 4. 6.]"📌 Runtime Parameters
params: start: 0 stop: 5 step: 2 endpoint: True expected: [0. 2. 4. 6.] id: 0-5-2-True-expected0📌 Setup phase
duration:
0.00037953397259116173outcome:
passed📌 Call phase
duration:
0.0005188989453017712outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-07, atol=0 (shapes (3,), (4,) mismatch) x: array([0, 2, 4]) y: array([0., 2., 4., 6.])traceback:
- path: tests/test_utils_npy.py lineno: 53 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = 0, stop = 5, step = 2, endpoint = True expected = array([0., 2., 4., 6.]) @pytest.mark.parametrize("start, stop, step, endpoint, expected", [ (0, 5, 2, True, np.array([0., 2., 4., 6.])), # Normal case with endpoint overshooting (0, 5, 2, False, np.array([0., 2., 4.])), # No endpoint (-1, 2, 1.5, True, np.array([-1., 0.5, 2.])), # Needs fractional alignment to include stop (-1, 2, 1.5, False, np.array([-1., 0.5])), # Same range but no endpoint (-2, 1, 1.2, True, np.array([-2., -0.8, 0.4, 1.6])), # Step overshoots (5, 0, -2, True, np.array([5., 3., 1., -1.])), # Backward steps with overshoot (5, 0, -2, False, np.array([5., 3., 1.])), # No endpoint, backward ]) def test_nice_steps_left_aligned(start, stop, step, endpoint, expected): > np.testing.assert_allclose(nice_steps_left_aligned(start, stop, step, endpoint), expected) tests/test_utils_npy.py:53: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0d8f217b80>, array([0, 2, 4]), array([0., 2., 4., 6.])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-07, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-07, atol=0 E E (shapes (3,), (4,) mismatch) E x: array([0, 2, 4]) E y: array([0., 2., 4., 6.]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.0002788933925330639outcome:
passed -
❌ Test 263
params: start=0, stop=5, step=2, endpoint=false, expected="[0. 2. 4.]"📌 Runtime Parameters
params: start: 0 stop: 5 step: 2 endpoint: False expected: [0. 2. 4.] id: 0-5-2-False-expected1📌 Setup phase
duration:
0.00038513028994202614outcome:
passed📌 Call phase
duration:
0.000533238984644413outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-07, atol=0 (shapes (2,), (3,) mismatch) x: array([0, 2]) y: array([0., 2., 4.])traceback:
- path: tests/test_utils_npy.py lineno: 53 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = 0, stop = 5, step = 2, endpoint = False, expected = array([0., 2., 4.]) @pytest.mark.parametrize("start, stop, step, endpoint, expected", [ (0, 5, 2, True, np.array([0., 2., 4., 6.])), # Normal case with endpoint overshooting (0, 5, 2, False, np.array([0., 2., 4.])), # No endpoint (-1, 2, 1.5, True, np.array([-1., 0.5, 2.])), # Needs fractional alignment to include stop (-1, 2, 1.5, False, np.array([-1., 0.5])), # Same range but no endpoint (-2, 1, 1.2, True, np.array([-2., -0.8, 0.4, 1.6])), # Step overshoots (5, 0, -2, True, np.array([5., 3., 1., -1.])), # Backward steps with overshoot (5, 0, -2, False, np.array([5., 3., 1.])), # No endpoint, backward ]) def test_nice_steps_left_aligned(start, stop, step, endpoint, expected): > np.testing.assert_allclose(nice_steps_left_aligned(start, stop, step, endpoint), expected) tests/test_utils_npy.py:53: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0d8f217af0>, array([0, 2]), array([0., 2., 4.])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-07, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-07, atol=0 E E (shapes (2,), (3,) mismatch) E x: array([0, 2]) E y: array([0., 2., 4.]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.000302294734865427outcome:
passed -
❌ Test 266
params: start=-2, stop=1, step=1.2, endpoint=true, expected="[-2. -0.8 0.4 1.6]"📌 Runtime Parameters
params: start: -2 stop: 1 step: 1.2 endpoint: True expected: [-2. -0.8 0.4 1.6] id: -2-1-1.2-True-expected4📌 Setup phase
duration:
0.0004002908244729042outcome:
passed📌 Call phase
duration:
0.0005279281176626682outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-07, atol=0 (shapes (3,), (4,) mismatch) x: array([-2. , -0.8, 0.4]) y: array([-2. , -0.8, 0.4, 1.6])traceback:
- path: tests/test_utils_npy.py lineno: 53 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = -2, stop = 1, step = 1.2, endpoint = True expected = array([-2. , -0.8, 0.4, 1.6]) @pytest.mark.parametrize("start, stop, step, endpoint, expected", [ (0, 5, 2, True, np.array([0., 2., 4., 6.])), # Normal case with endpoint overshooting (0, 5, 2, False, np.array([0., 2., 4.])), # No endpoint (-1, 2, 1.5, True, np.array([-1., 0.5, 2.])), # Needs fractional alignment to include stop (-1, 2, 1.5, False, np.array([-1., 0.5])), # Same range but no endpoint (-2, 1, 1.2, True, np.array([-2., -0.8, 0.4, 1.6])), # Step overshoots (5, 0, -2, True, np.array([5., 3., 1., -1.])), # Backward steps with overshoot (5, 0, -2, False, np.array([5., 3., 1.])), # No endpoint, backward ]) def test_nice_steps_left_aligned(start, stop, step, endpoint, expected): > np.testing.assert_allclose(nice_steps_left_aligned(start, stop, step, endpoint), expected) tests/test_utils_npy.py:53: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0d8f2174c0>, array([-2. , -0.8, 0.4]), array([-2. , -0.8, 0.4, 1.6])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-07, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-07, atol=0 E E (shapes (3,), (4,) mismatch) E x: array([-2. , -0.8, 0.4]) E y: array([-2. , -0.8, 0.4, 1.6]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.00023943185806274414outcome:
passed -
❌ Test 267
params: start=5, stop=0, step=-2, endpoint=true, expected="[ 5. 3. 1. -1.]"📌 Runtime Parameters
params: start: 5 stop: 0 step: -2 endpoint: True expected: [ 5. 3. 1. -1.] id: 5-0--2-True-expected5📌 Setup phase
duration:
0.00039111776277422905outcome:
passed📌 Call phase
duration:
0.0005030101165175438outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-07, atol=0 (shapes (3,), (4,) mismatch) x: array([0, 2, 4]) y: array([ 5., 3., 1., -1.])traceback:
- path: tests/test_utils_npy.py lineno: 53 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = 5, stop = 0, step = -2, endpoint = True expected = array([ 5., 3., 1., -1.]) @pytest.mark.parametrize("start, stop, step, endpoint, expected", [ (0, 5, 2, True, np.array([0., 2., 4., 6.])), # Normal case with endpoint overshooting (0, 5, 2, False, np.array([0., 2., 4.])), # No endpoint (-1, 2, 1.5, True, np.array([-1., 0.5, 2.])), # Needs fractional alignment to include stop (-1, 2, 1.5, False, np.array([-1., 0.5])), # Same range but no endpoint (-2, 1, 1.2, True, np.array([-2., -0.8, 0.4, 1.6])), # Step overshoots (5, 0, -2, True, np.array([5., 3., 1., -1.])), # Backward steps with overshoot (5, 0, -2, False, np.array([5., 3., 1.])), # No endpoint, backward ]) def test_nice_steps_left_aligned(start, stop, step, endpoint, expected): > np.testing.assert_allclose(nice_steps_left_aligned(start, stop, step, endpoint), expected) tests/test_utils_npy.py:53: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0d8f23eee0>, array([0, 2, 4]), array([ 5., 3., 1., -1.])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-07, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-07, atol=0 E E (shapes (3,), (4,) mismatch) E x: array([0, 2, 4]) E y: array([ 5., 3., 1., -1.]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.00023348070681095123outcome:
passed -
❌ Test 268
params: start=5, stop=0, step=-2, endpoint=false, expected="[5. 3. 1.]"📌 Runtime Parameters
params: start: 5 stop: 0 step: -2 endpoint: False expected: [5. 3. 1.] id: 5-0--2-False-expected6📌 Setup phase
duration:
0.00038596102967858315outcome:
passed📌 Call phase
duration:
0.00048609403893351555outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-07, atol=0 (shapes (2,), (3,) mismatch) x: array([0, 2]) y: array([5., 3., 1.])traceback:
- path: tests/test_utils_npy.py lineno: 53 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = 5, stop = 0, step = -2, endpoint = False, expected = array([5., 3., 1.]) @pytest.mark.parametrize("start, stop, step, endpoint, expected", [ (0, 5, 2, True, np.array([0., 2., 4., 6.])), # Normal case with endpoint overshooting (0, 5, 2, False, np.array([0., 2., 4.])), # No endpoint (-1, 2, 1.5, True, np.array([-1., 0.5, 2.])), # Needs fractional alignment to include stop (-1, 2, 1.5, False, np.array([-1., 0.5])), # Same range but no endpoint (-2, 1, 1.2, True, np.array([-2., -0.8, 0.4, 1.6])), # Step overshoots (5, 0, -2, True, np.array([5., 3., 1., -1.])), # Backward steps with overshoot (5, 0, -2, False, np.array([5., 3., 1.])), # No endpoint, backward ]) def test_nice_steps_left_aligned(start, stop, step, endpoint, expected): > np.testing.assert_allclose(nice_steps_left_aligned(start, stop, step, endpoint), expected) tests/test_utils_npy.py:53: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0d8f23e9d0>, array([0, 2]), array([5., 3., 1.])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-07, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-07, atol=0 E E (shapes (2,), (3,) mismatch) E x: array([0, 2]) E y: array([5., 3., 1.]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.00023899320513010025outcome:
passed
↳ Function: test_nice_steps_right_aligned
-
❌ Test 269
params: start=0, stop=5, step=2, endpoint=true, expected="[6. 4. 2. 0.]"📌 Runtime Parameters
params: start: 0 stop: 5 step: 2 endpoint: True expected: [6. 4. 2. 0.] id: 0-5-2-True-expected0📌 Setup phase
duration:
0.00039496785029768944outcome:
passed📌 Call phase
duration:
0.0004952591843903065outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-07, atol=0 (shapes (3,), (4,) mismatch) x: array([1, 3, 5]) y: array([6., 4., 2., 0.])traceback:
- path: tests/test_utils_npy.py lineno: 67 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = 0, stop = 5, step = 2, endpoint = True expected = array([6., 4., 2., 0.]) @pytest.mark.parametrize("start, stop, step, endpoint, expected", [ (0, 5, 2, True, np.array([6., 4., 2., 0.])), # Right-aligned, overshoots left (0, 5, 2, False, np.array([4., 2., 0.])), # Right-aligned, no endpoint (-1, 2, 1.5, True, np.array([2., 0.5, -1.])), # Step doesn t divide evenly, reverse it (-1, 2, 1.5, False, np.array([0.5, -1.])), # Without endpoint (5, 0, -2, True, np.array([5., 3., 1., -1.])), # Negative step, includes endpoint overshoot (5, 0, -2, False, np.array([3., 1., -1.])), # No endpoint, skips last one (-3, 3, 2, True, np.array([5., 3., 1., -1., -3.])), # Large symmetric range, reverse ]) def test_nice_steps_right_aligned(start, stop, step, endpoint, expected): > np.testing.assert_allclose(nice_steps_right_aligned(start, stop, step, endpoint), expected) tests/test_utils_npy.py:67: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0d8f23ea60>, array([1, 3, 5]), array([6., 4., 2., 0.])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-07, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-07, atol=0 E E (shapes (3,), (4,) mismatch) E x: array([1, 3, 5]) E y: array([6., 4., 2., 0.]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.00023984629660844803outcome:
passed -
❌ Test 270
params: start=0, stop=5, step=2, endpoint=false, expected="[4. 2. 0.]"📌 Runtime Parameters
params: start: 0 stop: 5 step: 2 endpoint: False expected: [4. 2. 0.] id: 0-5-2-False-expected1📌 Setup phase
duration:
0.0003753090277314186outcome:
passed📌 Call phase
duration:
0.00047777825966477394outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-07, atol=0 (shapes (2,), (3,) mismatch) x: array([3, 5]) y: array([4., 2., 0.])traceback:
- path: tests/test_utils_npy.py lineno: 67 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = 0, stop = 5, step = 2, endpoint = False, expected = array([4., 2., 0.]) @pytest.mark.parametrize("start, stop, step, endpoint, expected", [ (0, 5, 2, True, np.array([6., 4., 2., 0.])), # Right-aligned, overshoots left (0, 5, 2, False, np.array([4., 2., 0.])), # Right-aligned, no endpoint (-1, 2, 1.5, True, np.array([2., 0.5, -1.])), # Step doesn t divide evenly, reverse it (-1, 2, 1.5, False, np.array([0.5, -1.])), # Without endpoint (5, 0, -2, True, np.array([5., 3., 1., -1.])), # Negative step, includes endpoint overshoot (5, 0, -2, False, np.array([3., 1., -1.])), # No endpoint, skips last one (-3, 3, 2, True, np.array([5., 3., 1., -1., -3.])), # Large symmetric range, reverse ]) def test_nice_steps_right_aligned(start, stop, step, endpoint, expected): > np.testing.assert_allclose(nice_steps_right_aligned(start, stop, step, endpoint), expected) tests/test_utils_npy.py:67: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0d8f23c280>, array([3, 5]), array([4., 2., 0.])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-07, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-07, atol=0 E E (shapes (2,), (3,) mismatch) E x: array([3, 5]) E y: array([4., 2., 0.]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.00022857403382658958outcome:
passed -
❌ Test 271
params: start=-1, stop=2, step=1.5, endpoint=true, expected="[ 2. 0.5 -1. ]"📌 Runtime Parameters
params: start: -1 stop: 2 step: 1.5 endpoint: True expected: [ 2. 0.5 -1. ] id: -1-2-1.5-True-expected2📌 Setup phase
duration:
0.00040649157017469406outcome:
passed📌 Call phase
duration:
0.0008418988436460495outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-07, atol=0 Mismatched elements: 2 / 3 (66.7%) Max absolute difference: 3. Max relative difference: 3. x: array([-1. , 0.5, 2. ]) y: array([ 2. , 0.5, -1. ])traceback:
- path: tests/test_utils_npy.py lineno: 67 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = -1, stop = 2, step = 1.5, endpoint = True expected = array([ 2. , 0.5, -1. ]) @pytest.mark.parametrize("start, stop, step, endpoint, expected", [ (0, 5, 2, True, np.array([6., 4., 2., 0.])), # Right-aligned, overshoots left (0, 5, 2, False, np.array([4., 2., 0.])), # Right-aligned, no endpoint (-1, 2, 1.5, True, np.array([2., 0.5, -1.])), # Step doesn t divide evenly, reverse it (-1, 2, 1.5, False, np.array([0.5, -1.])), # Without endpoint (5, 0, -2, True, np.array([5., 3., 1., -1.])), # Negative step, includes endpoint overshoot (5, 0, -2, False, np.array([3., 1., -1.])), # No endpoint, skips last one (-3, 3, 2, True, np.array([5., 3., 1., -1., -3.])), # Large symmetric range, reverse ]) def test_nice_steps_right_aligned(start, stop, step, endpoint, expected): > np.testing.assert_allclose(nice_steps_right_aligned(start, stop, step, endpoint), expected) tests/test_utils_npy.py:67: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0d8f23c9d0>, array([-1. , 0.5, 2. ]), array([ 2. , 0.5, -1. ])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-07, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-07, atol=0 E E Mismatched elements: 2 / 3 (66.7%) E Max absolute difference: 3. E Max relative difference: 3. E x: array([-1. , 0.5, 2. ]) E y: array([ 2. , 0.5, -1. ]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.0003527808003127575outcome:
passed -
❌ Test 272
params: start=-1, stop=2, step=1.5, endpoint=false, expected="[ 0.5 -1. ]"📌 Runtime Parameters
params: start: -1 stop: 2 step: 1.5 endpoint: False expected: [ 0.5 -1. ] id: -1-2-1.5-False-expected3📌 Setup phase
duration:
0.0005229548551142216outcome:
passed📌 Call phase
duration:
0.0009726588614284992outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-07, atol=0 Mismatched elements: 1 / 2 (50%) Max absolute difference: 3. Max relative difference: 3. x: array([0.5, 2. ]) y: array([ 0.5, -1. ])traceback:
- path: tests/test_utils_npy.py lineno: 67 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = -1, stop = 2, step = 1.5, endpoint = False expected = array([ 0.5, -1. ]) @pytest.mark.parametrize("start, stop, step, endpoint, expected", [ (0, 5, 2, True, np.array([6., 4., 2., 0.])), # Right-aligned, overshoots left (0, 5, 2, False, np.array([4., 2., 0.])), # Right-aligned, no endpoint (-1, 2, 1.5, True, np.array([2., 0.5, -1.])), # Step doesn t divide evenly, reverse it (-1, 2, 1.5, False, np.array([0.5, -1.])), # Without endpoint (5, 0, -2, True, np.array([5., 3., 1., -1.])), # Negative step, includes endpoint overshoot (5, 0, -2, False, np.array([3., 1., -1.])), # No endpoint, skips last one (-3, 3, 2, True, np.array([5., 3., 1., -1., -3.])), # Large symmetric range, reverse ]) def test_nice_steps_right_aligned(start, stop, step, endpoint, expected): > np.testing.assert_allclose(nice_steps_right_aligned(start, stop, step, endpoint), expected) tests/test_utils_npy.py:67: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0de3a3bdc0>, array([0.5, 2. ]), array([ 0.5, -1. ])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-07, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-07, atol=0 E E Mismatched elements: 1 / 2 (50%) E Max absolute difference: 3. E Max relative difference: 3. E x: array([0.5, 2. ]) E y: array([ 0.5, -1. ]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.0002504042349755764outcome:
passed -
❌ Test 273
params: start=5, stop=0, step=-2, endpoint=true, expected="[ 5. 3. 1. -1.]"📌 Runtime Parameters
params: start: 5 stop: 0 step: -2 endpoint: True expected: [ 5. 3. 1. -1.] id: 5-0--2-True-expected4📌 Setup phase
duration:
0.0004138159565627575outcome:
passed📌 Call phase
duration:
0.0005450421012938023outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-07, atol=0 (shapes (3,), (4,) mismatch) x: array([1, 3, 5]) y: array([ 5., 3., 1., -1.])traceback:
- path: tests/test_utils_npy.py lineno: 67 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = 5, stop = 0, step = -2, endpoint = True expected = array([ 5., 3., 1., -1.]) @pytest.mark.parametrize("start, stop, step, endpoint, expected", [ (0, 5, 2, True, np.array([6., 4., 2., 0.])), # Right-aligned, overshoots left (0, 5, 2, False, np.array([4., 2., 0.])), # Right-aligned, no endpoint (-1, 2, 1.5, True, np.array([2., 0.5, -1.])), # Step doesn t divide evenly, reverse it (-1, 2, 1.5, False, np.array([0.5, -1.])), # Without endpoint (5, 0, -2, True, np.array([5., 3., 1., -1.])), # Negative step, includes endpoint overshoot (5, 0, -2, False, np.array([3., 1., -1.])), # No endpoint, skips last one (-3, 3, 2, True, np.array([5., 3., 1., -1., -3.])), # Large symmetric range, reverse ]) def test_nice_steps_right_aligned(start, stop, step, endpoint, expected): > np.testing.assert_allclose(nice_steps_right_aligned(start, stop, step, endpoint), expected) tests/test_utils_npy.py:67: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0d8f23c280>, array([1, 3, 5]), array([ 5., 3., 1., -1.])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-07, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-07, atol=0 E E (shapes (3,), (4,) mismatch) E x: array([1, 3, 5]) E y: array([ 5., 3., 1., -1.]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.0002441350370645523outcome:
passed -
❌ Test 274
params: start=5, stop=0, step=-2, endpoint=false, expected="[ 3. 1. -1.]"📌 Runtime Parameters
params: start: 5 stop: 0 step: -2 endpoint: False expected: [ 3. 1. -1.] id: 5-0--2-False-expected5📌 Setup phase
duration:
0.0003972211852669716outcome:
passed📌 Call phase
duration:
0.000520824920386076outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-07, atol=0 (shapes (2,), (3,) mismatch) x: array([3, 5]) y: array([ 3., 1., -1.])traceback:
- path: tests/test_utils_npy.py lineno: 67 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = 5, stop = 0, step = -2, endpoint = False expected = array([ 3., 1., -1.]) @pytest.mark.parametrize("start, stop, step, endpoint, expected", [ (0, 5, 2, True, np.array([6., 4., 2., 0.])), # Right-aligned, overshoots left (0, 5, 2, False, np.array([4., 2., 0.])), # Right-aligned, no endpoint (-1, 2, 1.5, True, np.array([2., 0.5, -1.])), # Step doesn t divide evenly, reverse it (-1, 2, 1.5, False, np.array([0.5, -1.])), # Without endpoint (5, 0, -2, True, np.array([5., 3., 1., -1.])), # Negative step, includes endpoint overshoot (5, 0, -2, False, np.array([3., 1., -1.])), # No endpoint, skips last one (-3, 3, 2, True, np.array([5., 3., 1., -1., -3.])), # Large symmetric range, reverse ]) def test_nice_steps_right_aligned(start, stop, step, endpoint, expected): > np.testing.assert_allclose(nice_steps_right_aligned(start, stop, step, endpoint), expected) tests/test_utils_npy.py:67: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0d8f23e790>, array([3, 5]), array([ 3., 1., -1.])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-07, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-07, atol=0 E E (shapes (2,), (3,) mismatch) E x: array([3, 5]) E y: array([ 3., 1., -1.]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.00024710968136787415outcome:
passed -
❌ Test 275
params: start=-3, stop=3, step=2, endpoint=true, expected="[ 5. 3. 1. -1. -3.]"📌 Runtime Parameters
params: start: -3 stop: 3 step: 2 endpoint: True expected: [ 5. 3. 1. -1. -3.] id: -3-3-2-True-expected6📌 Setup phase
duration:
0.00037591857835650444outcome:
passed📌 Call phase
duration:
0.0004994389601051807outcome:
failedcrash:
path: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionError: Not equal to tolerance rtol=1e-07, atol=0 (shapes (4,), (5,) mismatch) x: array([-3, -1, 1, 3]) y: array([ 5., 3., 1., -1., -3.])traceback:
- path: tests/test_utils_npy.py lineno: 67 message: None - path: .pixi/envs/default/lib/python3.8/contextlib.py lineno: 75 message: AssertionErrorlongrepr:
start = -3, stop = 3, step = 2, endpoint = True expected = array([ 5., 3., 1., -1., -3.]) @pytest.mark.parametrize("start, stop, step, endpoint, expected", [ (0, 5, 2, True, np.array([6., 4., 2., 0.])), # Right-aligned, overshoots left (0, 5, 2, False, np.array([4., 2., 0.])), # Right-aligned, no endpoint (-1, 2, 1.5, True, np.array([2., 0.5, -1.])), # Step doesn t divide evenly, reverse it (-1, 2, 1.5, False, np.array([0.5, -1.])), # Without endpoint (5, 0, -2, True, np.array([5., 3., 1., -1.])), # Negative step, includes endpoint overshoot (5, 0, -2, False, np.array([3., 1., -1.])), # No endpoint, skips last one (-3, 3, 2, True, np.array([5., 3., 1., -1., -3.])), # Large symmetric range, reverse ]) def test_nice_steps_right_aligned(start, stop, step, endpoint, expected): > np.testing.assert_allclose(nice_steps_right_aligned(start, stop, step, endpoint), expected) tests/test_utils_npy.py:67: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = (<function assert_allclose.<locals>.compare at 0x7f0de3a3bb80>, array([-3, -1, 1, 3]), array([ 5., 3., 1., -1., -3.])) kwds = {'equal_nan': True, 'err_msg': '', 'header': 'Not equal to tolerance rtol=1e-07, atol=0', 'verbose': True} @wraps(func) def inner(*args, **kwds): with self._recreate_cm(): > return func(*args, **kwds) E AssertionError: E Not equal to tolerance rtol=1e-07, atol=0 E E (shapes (4,), (5,) mismatch) E x: array([-3, -1, 1, 3]) E y: array([ 5., 3., 1., -1., -3.]) .pixi/envs/default/lib/python3.8/contextlib.py:75: AssertionError📌 Teardown phase
duration:
0.00023724883794784546outcome:
passed
-
-
📄 test_utils_pv.py
↳ Function: test_put_with_progress_and_repr
-
❌ Test 348
params: value=0.0, expected_bar=" ", expected_color="\u001b[32m"📌 Runtime Parameters
params: value: 0.0 expected_bar: expected_color: [32m id: 0.0- -\x1b[32m📌 Setup phase
duration:
1.0023644980974495outcome:
passedlog:
- name: pcaspy.Driver.setParam msg: START_TIME: value=2025-08-07 11:15:20.833915 alarm=NO_ALARM severity=NO_ALARM flag=True mask=7 time=1123413320.833951313 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565320.8340487 msecs: 834.0487480163574 relativeCreated: 8733.179807662964 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=4 time=1123413320.834616989 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565320.8346436 msecs: 834.6436023712158 relativeCreated: 8733.774662017822 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413320.935085902 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565320.9351594 msecs: 935.15944480896 relativeCreated: 8834.290504455566 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.35793895 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.0358717 msecs: 35.87174415588379 relativeCreated: 8935.00280380249 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.136420528 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.1364918 msecs: 136.4917755126953 relativeCreated: 9035.622835159302 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.237060783 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.237136 msecs: 237.1358871459961 relativeCreated: 9136.266946792603 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.337663944 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.3377655 msecs: 337.7654552459717 relativeCreated: 9236.896514892578 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.438326330 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.4384005 msecs: 438.4005069732666 relativeCreated: 9337.531566619873 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.538927594 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.5389993 msecs: 538.9993190765381 relativeCreated: 9438.130378723145 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.639531005 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.6395931 msecs: 639.5931243896484 relativeCreated: 9538.724184036255 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.740122877 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.7401986 msecs: 740.1986122131348 relativeCreated: 9639.329671859741 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903📌 Call phase
duration:
0.015116883907467127outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_pv.py lineno: 81 message: AssertionError: Expected bar ' ' not found in: [DEBUG] PUT start = 0.0, stop = 0.0 [ 0 |[32m██████████████████████████████[39m| 0 ] [1m0[0m assert []traceback:
- path: tests/test_utils_pv.py lineno: 81 message: AssertionErrorlog:
- name: pcaspy.Driver.setParam msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.841041272 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.8411262 msecs: 841.1262035369873 relativeCreated: 9740.257263183594 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.getValue msg: VAL: Read value 0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.8436208 msecs: 843.620777130127 relativeCreated: 9742.751836776733 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.writeValue msg: VAL: 0808d44cd37f root old=0 new=0.0 args: None levelname: INFO levelno: 20 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 549 funcName: writeValue created: 1754565321.8439796 msecs: 843.9795970916748 relativeCreated: 9743.110656738281 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.844083357 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.8441079 msecs: 844.1078662872314 relativeCreated: 9743.238925933838 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.getValue msg: VAL: Read value 0.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.8455179 msecs: 845.5178737640381 relativeCreated: 9744.648933410645 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.writeValue msg: VAL: 0808d44cd37f root old=0.0 new=0.0 args: None levelname: INFO levelno: 20 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 549 funcName: writeValue created: 1754565321.8461082 msecs: 846.1081981658936 relativeCreated: 9745.2392578125 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.846264889 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.846292 msecs: 846.2920188903809 relativeCreated: 9745.423078536987 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903longrepr:
value = 0.0, expected_bar = ' ', expected_color = '\x1b[32m' @pytest.mark.parametrize("value, expected_bar, expected_color", [ (0.0, " ", colorama.Fore.GREEN), (25.0, "██▌ ", colorama.Fore.GREEN), (50.0, "█████ ", colorama.Fore.GREEN), (75.0, "███████▌ ", colorama.Fore.GREEN), (100.0, "██████████", colorama.Fore.GREEN), (150.0, ">>>>>>>>>>", colorama.Fore.RED), (-50.0, "<<<<<<<<<<", colorama.Fore.RED) ]) def test_put_with_progress_and_repr(value, expected_bar, expected_color): pv = PV("TEST:VAL", connection_timeout=2.0) assert pv.wait_for_connection(timeout=2.0), "PV not connected" pv.put(0.0, wait=True) assert pv.get() == pytest.approx(0.0) # Capture tous les prints dans une liste printed_lines = [] def fake_print(*args, **kwargs): line = " ".join(str(a) for a in args) printed_lines.append(line) # Monkeypatch print uniquement dans ce contexte original_print = builtins.print builtins.print = fake_print try: pv.put(value, show_progress=True) finally: builtins.print = original_print # Vérifie que la bonne barre a été affichée au moins une fois matches = [line for line in printed_lines if f"|{expected_bar}|" in line] > assert matches, f"Expected bar '{expected_bar}' not found in:\n" + "\n".join(printed_lines) E AssertionError: Expected bar ' ' not found in: E [DEBUG] PUT start = 0.0, stop = 0.0 E [ 0 |[32m██████████████████████████████[39m| 0 ] [1m0[0m E E assert [] tests/test_utils_pv.py:81: AssertionError📌 Teardown phase
duration:
0.00032362714409828186outcome:
passed -
❌ Test 349
params: value=25.0, expected_bar="██▌ ", expected_color="\u001b[32m"📌 Runtime Parameters
params: value: 25.0 expected_bar: ██▌ expected_color: [32m id: 25.0-\u2588\u2588\u258c -\x1b[32m📌 Setup phase
duration:
0.00039674481377005577outcome:
passed📌 Call phase
duration:
0.0028555262833833694outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_pv.py lineno: 81 message: AssertionError: Expected bar '██▌ ' not found in: [DEBUG] PUT start = 0.0, stop = 25.0 [ 0 |[32m [39m| 25 ] [1m0[0m assert []traceback:
- path: tests/test_utils_pv.py lineno: 81 message: AssertionErrorlog:
- name: pcaspy.SimplePV.getValue msg: VAL: Read value 0.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.8545945 msecs: 854.5944690704346 relativeCreated: 9753.725528717041 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.writeValue msg: VAL: 0808d44cd37f root old=0.0 new=0.0 args: None levelname: INFO levelno: 20 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 549 funcName: writeValue created: 1754565321.8549716 msecs: 854.9716472625732 relativeCreated: 9754.10270690918 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.855080884 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.8551059 msecs: 855.1058769226074 relativeCreated: 9754.236936569214 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.getValue msg: VAL: Read value 0.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.8557086 msecs: 855.7085990905762 relativeCreated: 9754.839658737183 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.writeValue msg: VAL: 0808d44cd37f root old=0.0 new=25.0 args: None levelname: INFO levelno: 20 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 549 funcName: writeValue created: 1754565321.8560514 msecs: 856.0514450073242 relativeCreated: 9755.18250465393 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=25.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123413321.856139005 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.856156 msecs: 856.1561107635498 relativeCreated: 9755.287170410156 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903longrepr:
value = 25.0, expected_bar = '██▌ ', expected_color = '\x1b[32m' @pytest.mark.parametrize("value, expected_bar, expected_color", [ (0.0, " ", colorama.Fore.GREEN), (25.0, "██▌ ", colorama.Fore.GREEN), (50.0, "█████ ", colorama.Fore.GREEN), (75.0, "███████▌ ", colorama.Fore.GREEN), (100.0, "██████████", colorama.Fore.GREEN), (150.0, ">>>>>>>>>>", colorama.Fore.RED), (-50.0, "<<<<<<<<<<", colorama.Fore.RED) ]) def test_put_with_progress_and_repr(value, expected_bar, expected_color): pv = PV("TEST:VAL", connection_timeout=2.0) assert pv.wait_for_connection(timeout=2.0), "PV not connected" pv.put(0.0, wait=True) assert pv.get() == pytest.approx(0.0) # Capture tous les prints dans une liste printed_lines = [] def fake_print(*args, **kwargs): line = " ".join(str(a) for a in args) printed_lines.append(line) # Monkeypatch print uniquement dans ce contexte original_print = builtins.print builtins.print = fake_print try: pv.put(value, show_progress=True) finally: builtins.print = original_print # Vérifie que la bonne barre a été affichée au moins une fois matches = [line for line in printed_lines if f"|{expected_bar}|" in line] > assert matches, f"Expected bar '{expected_bar}' not found in:\n" + "\n".join(printed_lines) E AssertionError: Expected bar '██▌ ' not found in: E [DEBUG] PUT start = 0.0, stop = 25.0 E [ 0 |[32m [39m| 25 ] [1m0[0m E E assert [] tests/test_utils_pv.py:81: AssertionError📌 Teardown phase
duration:
0.0002991398796439171outcome:
passed -
❌ Test 350
params: value=50.0, expected_bar="█████ ", expected_color="\u001b[32m"📌 Runtime Parameters
params: value: 50.0 expected_bar: █████ expected_color: [32m id: 50.0-\u2588\u2588\u2588\u2588\u2588 -\x1b[32m📌 Setup phase
duration:
0.0003916020505130291outcome:
passed📌 Call phase
duration:
0.00299764983355999outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_pv.py lineno: 81 message: AssertionError: Expected bar '█████ ' not found in: [DEBUG] PUT start = 0.0, stop = 50.0 [ 0 |[32m [39m| 50 ] [1m0[0m assert []traceback:
- path: tests/test_utils_pv.py lineno: 81 message: AssertionErrorlog:
- name: pcaspy.SimplePV.getValue msg: VAL: Read value 25.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.863541 msecs: 863.5408878326416 relativeCreated: 9762.671947479248 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.writeValue msg: VAL: 0808d44cd37f root old=25.0 new=0.0 args: None levelname: INFO levelno: 20 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 549 funcName: writeValue created: 1754565321.8638725 msecs: 863.8725280761719 relativeCreated: 9763.003587722778 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123413321.863976390 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.8640141 msecs: 864.0141487121582 relativeCreated: 9763.145208358765 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.getValue msg: VAL: Read value 0.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.8647828 msecs: 864.7828102111816 relativeCreated: 9763.913869857788 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.writeValue msg: VAL: 0808d44cd37f root old=0.0 new=50.0 args: None levelname: INFO levelno: 20 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 549 funcName: writeValue created: 1754565321.8651161 msecs: 865.1161193847656 relativeCreated: 9764.247179031372 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=50.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123413321.865199972 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.8652172 msecs: 865.2172088623047 relativeCreated: 9764.348268508911 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903longrepr:
value = 50.0, expected_bar = '█████ ', expected_color = '\x1b[32m' @pytest.mark.parametrize("value, expected_bar, expected_color", [ (0.0, " ", colorama.Fore.GREEN), (25.0, "██▌ ", colorama.Fore.GREEN), (50.0, "█████ ", colorama.Fore.GREEN), (75.0, "███████▌ ", colorama.Fore.GREEN), (100.0, "██████████", colorama.Fore.GREEN), (150.0, ">>>>>>>>>>", colorama.Fore.RED), (-50.0, "<<<<<<<<<<", colorama.Fore.RED) ]) def test_put_with_progress_and_repr(value, expected_bar, expected_color): pv = PV("TEST:VAL", connection_timeout=2.0) assert pv.wait_for_connection(timeout=2.0), "PV not connected" pv.put(0.0, wait=True) assert pv.get() == pytest.approx(0.0) # Capture tous les prints dans une liste printed_lines = [] def fake_print(*args, **kwargs): line = " ".join(str(a) for a in args) printed_lines.append(line) # Monkeypatch print uniquement dans ce contexte original_print = builtins.print builtins.print = fake_print try: pv.put(value, show_progress=True) finally: builtins.print = original_print # Vérifie que la bonne barre a été affichée au moins une fois matches = [line for line in printed_lines if f"|{expected_bar}|" in line] > assert matches, f"Expected bar '{expected_bar}' not found in:\n" + "\n".join(printed_lines) E AssertionError: Expected bar '█████ ' not found in: E [DEBUG] PUT start = 0.0, stop = 50.0 E [ 0 |[32m [39m| 50 ] [1m0[0m E E assert [] tests/test_utils_pv.py:81: AssertionError📌 Teardown phase
duration:
0.0003552841953933239outcome:
passed -
❌ Test 351
params: value=75.0, expected_bar="███████▌ ", expected_color="\u001b[32m"📌 Runtime Parameters
params: value: 75.0 expected_bar: ███████▌ expected_color: [32m id: 75.0-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u258c -\x1b[32m📌 Setup phase
duration:
0.0004092059098184109outcome:
passed📌 Call phase
duration:
0.002896666992455721outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_pv.py lineno: 62 message: assert 50.0 == 0.0 ± 1.0e-12 comparison failed Obtained: 50.0 Expected: 0.0 ± 1.0e-12traceback:
- path: tests/test_utils_pv.py lineno: 62 message: AssertionErrorlog:
- name: pcaspy.SimplePV.getValue msg: VAL: Read value 50.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.8732932 msecs: 873.2931613922119 relativeCreated: 9772.424221038818 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.writeValue msg: VAL: 0808d44cd37f root old=50.0 new=0.0 args: None levelname: INFO levelno: 20 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 549 funcName: writeValue created: 1754565321.8735332 msecs: 873.5332489013672 relativeCreated: 9772.664308547974 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123413321.873775080 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.8738015 msecs: 873.8014698028564 relativeCreated: 9772.932529449463 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.getValue msg: VAL: Read value 0.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.8748927 msecs: 874.8927116394043 relativeCreated: 9774.02377128601 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903longrepr:
value = 75.0, expected_bar = '███████▌ ', expected_color = '\x1b[32m' @pytest.mark.parametrize("value, expected_bar, expected_color", [ (0.0, " ", colorama.Fore.GREEN), (25.0, "██▌ ", colorama.Fore.GREEN), (50.0, "█████ ", colorama.Fore.GREEN), (75.0, "███████▌ ", colorama.Fore.GREEN), (100.0, "██████████", colorama.Fore.GREEN), (150.0, ">>>>>>>>>>", colorama.Fore.RED), (-50.0, "<<<<<<<<<<", colorama.Fore.RED) ]) def test_put_with_progress_and_repr(value, expected_bar, expected_color): pv = PV("TEST:VAL", connection_timeout=2.0) assert pv.wait_for_connection(timeout=2.0), "PV not connected" pv.put(0.0, wait=True) > assert pv.get() == pytest.approx(0.0) E assert 50.0 == 0.0 ± 1.0e-12 E E comparison failed E Obtained: 50.0 E Expected: 0.0 ± 1.0e-12 tests/test_utils_pv.py:62: AssertionError📌 Teardown phase
duration:
0.00029301270842552185outcome:
passed -
❌ Test 352
params: value=100.0, expected_bar="██████████", expected_color="\u001b[32m"📌 Runtime Parameters
params: value: 100.0 expected_bar: ██████████ expected_color: [32m id: 100.0-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588-\x1b[32m📌 Setup phase
duration:
0.0003893100656569004outcome:
passed📌 Call phase
duration:
0.0026348731480538845outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_pv.py lineno: 81 message: AssertionError: Expected bar '██████████' not found in: [DEBUG] PUT start = 0.0, stop = 100.0 [ 0 |[32m [39m| 100 ] [1m0[0m assert []traceback:
- path: tests/test_utils_pv.py lineno: 81 message: AssertionErrorlog:
- name: pcaspy.SimplePV.getValue msg: VAL: Read value 0.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.8821485 msecs: 882.1485042572021 relativeCreated: 9781.279563903809 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.writeValue msg: VAL: 0808d44cd37f root old=0.0 new=0.0 args: None levelname: INFO levelno: 20 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 549 funcName: writeValue created: 1754565321.8823254 msecs: 882.3254108428955 relativeCreated: 9781.456470489502 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.882522945 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.8825612 msecs: 882.561206817627 relativeCreated: 9781.692266464233 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.getValue msg: VAL: Read value 0.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.8831248 msecs: 883.124828338623 relativeCreated: 9782.25588798523 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.writeValue msg: VAL: 0808d44cd37f root old=0.0 new=100.0 args: None levelname: INFO levelno: 20 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 549 funcName: writeValue created: 1754565321.883433 msecs: 883.4331035614014 relativeCreated: 9782.564163208008 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=100.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123413321.883513769 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.8835301 msecs: 883.5301399230957 relativeCreated: 9782.661199569702 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903longrepr:
value = 100.0, expected_bar = '██████████', expected_color = '\x1b[32m' @pytest.mark.parametrize("value, expected_bar, expected_color", [ (0.0, " ", colorama.Fore.GREEN), (25.0, "██▌ ", colorama.Fore.GREEN), (50.0, "█████ ", colorama.Fore.GREEN), (75.0, "███████▌ ", colorama.Fore.GREEN), (100.0, "██████████", colorama.Fore.GREEN), (150.0, ">>>>>>>>>>", colorama.Fore.RED), (-50.0, "<<<<<<<<<<", colorama.Fore.RED) ]) def test_put_with_progress_and_repr(value, expected_bar, expected_color): pv = PV("TEST:VAL", connection_timeout=2.0) assert pv.wait_for_connection(timeout=2.0), "PV not connected" pv.put(0.0, wait=True) assert pv.get() == pytest.approx(0.0) # Capture tous les prints dans une liste printed_lines = [] def fake_print(*args, **kwargs): line = " ".join(str(a) for a in args) printed_lines.append(line) # Monkeypatch print uniquement dans ce contexte original_print = builtins.print builtins.print = fake_print try: pv.put(value, show_progress=True) finally: builtins.print = original_print # Vérifie que la bonne barre a été affichée au moins une fois matches = [line for line in printed_lines if f"|{expected_bar}|" in line] > assert matches, f"Expected bar '{expected_bar}' not found in:\n" + "\n".join(printed_lines) E AssertionError: Expected bar '██████████' not found in: E [DEBUG] PUT start = 0.0, stop = 100.0 E [ 0 |[32m [39m| 100 ] [1m0[0m E E assert [] tests/test_utils_pv.py:81: AssertionError📌 Teardown phase
duration:
0.0002872273325920105outcome:
passed -
❌ Test 353
params: value=150.0, expected_bar=">>>>>>>>>>", expected_color="\u001b[31m"📌 Runtime Parameters
params: value: 150.0 expected_bar: >>>>>>>>>> expected_color: [31m id: 150.0->>>>>>>>>>-\x1b[31m📌 Setup phase
duration:
0.00038520386442542076outcome:
passed📌 Call phase
duration:
0.0029014218598604202outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_pv.py lineno: 62 message: assert 100.0 == 0.0 ± 1.0e-12 comparison failed Obtained: 100.0 Expected: 0.0 ± 1.0e-12traceback:
- path: tests/test_utils_pv.py lineno: 62 message: AssertionErrorlog:
- name: pcaspy.SimplePV.getValue msg: VAL: Read value 100.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.8910937 msecs: 891.0937309265137 relativeCreated: 9790.22479057312 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.writeValue msg: VAL: 0808d44cd37f root old=100.0 new=0.0 args: None levelname: INFO levelno: 20 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 549 funcName: writeValue created: 1754565321.8914726 msecs: 891.472578048706 relativeCreated: 9790.603637695312 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123413321.891570748 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.891591 msecs: 891.5910720825195 relativeCreated: 9790.722131729126 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.getValue msg: VAL: Read value 0.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.8927205 msecs: 892.7204608917236 relativeCreated: 9791.85152053833 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903longrepr:
value = 150.0, expected_bar = '>>>>>>>>>>', expected_color = '\x1b[31m' @pytest.mark.parametrize("value, expected_bar, expected_color", [ (0.0, " ", colorama.Fore.GREEN), (25.0, "██▌ ", colorama.Fore.GREEN), (50.0, "█████ ", colorama.Fore.GREEN), (75.0, "███████▌ ", colorama.Fore.GREEN), (100.0, "██████████", colorama.Fore.GREEN), (150.0, ">>>>>>>>>>", colorama.Fore.RED), (-50.0, "<<<<<<<<<<", colorama.Fore.RED) ]) def test_put_with_progress_and_repr(value, expected_bar, expected_color): pv = PV("TEST:VAL", connection_timeout=2.0) assert pv.wait_for_connection(timeout=2.0), "PV not connected" pv.put(0.0, wait=True) > assert pv.get() == pytest.approx(0.0) E assert 100.0 == 0.0 ± 1.0e-12 E E comparison failed E Obtained: 100.0 E Expected: 0.0 ± 1.0e-12 tests/test_utils_pv.py:62: AssertionError📌 Teardown phase
duration:
0.0002702423371374607outcome:
passed -
❌ Test 354
params: value=-50.0, expected_bar="<<<<<<<<<<", expected_color="\u001b[31m"📌 Runtime Parameters
params: value: -50.0 expected_bar: <<<<<<<<<< expected_color: [31m id: -50.0-<<<<<<<<<<-\x1b[31m📌 Setup phase
duration:
0.00040804315358400345outcome:
passed📌 Call phase
duration:
0.0028922902420163155outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_pv.py lineno: 81 message: AssertionError: Expected bar '<<<<<<<<<<' not found in: [DEBUG] PUT start = 0.0, stop = -50.0 [ 0 |[32m [39m| -50 ] [1m0[0m assert []traceback:
- path: tests/test_utils_pv.py lineno: 81 message: AssertionErrorlog:
- name: pcaspy.SimplePV.getValue msg: VAL: Read value 0.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.9000869 msecs: 900.0868797302246 relativeCreated: 9799.217939376831 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.writeValue msg: VAL: 0808d44cd37f root old=0.0 new=0.0 args: None levelname: INFO levelno: 20 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 549 funcName: writeValue created: 1754565321.9003105 msecs: 900.3105163574219 relativeCreated: 9799.441576004028 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413321.900431731 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.9005206 msecs: 900.5205631256104 relativeCreated: 9799.651622772217 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.getValue msg: VAL: Read value 0.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.9013226 msecs: 901.322603225708 relativeCreated: 9800.453662872314 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.writeValue msg: VAL: 0808d44cd37f root old=0.0 new=-50.0 args: None levelname: INFO levelno: 20 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 549 funcName: writeValue created: 1754565321.9016771 msecs: 901.677131652832 relativeCreated: 9800.808191299438 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=-50.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123413321.901758265 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.9017751 msecs: 901.7751216888428 relativeCreated: 9800.90618133545 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903longrepr:
value = -50.0, expected_bar = '<<<<<<<<<<', expected_color = '\x1b[31m' @pytest.mark.parametrize("value, expected_bar, expected_color", [ (0.0, " ", colorama.Fore.GREEN), (25.0, "██▌ ", colorama.Fore.GREEN), (50.0, "█████ ", colorama.Fore.GREEN), (75.0, "███████▌ ", colorama.Fore.GREEN), (100.0, "██████████", colorama.Fore.GREEN), (150.0, ">>>>>>>>>>", colorama.Fore.RED), (-50.0, "<<<<<<<<<<", colorama.Fore.RED) ]) def test_put_with_progress_and_repr(value, expected_bar, expected_color): pv = PV("TEST:VAL", connection_timeout=2.0) assert pv.wait_for_connection(timeout=2.0), "PV not connected" pv.put(0.0, wait=True) assert pv.get() == pytest.approx(0.0) # Capture tous les prints dans une liste printed_lines = [] def fake_print(*args, **kwargs): line = " ".join(str(a) for a in args) printed_lines.append(line) # Monkeypatch print uniquement dans ce contexte original_print = builtins.print builtins.print = fake_print try: pv.put(value, show_progress=True) finally: builtins.print = original_print # Vérifie que la bonne barre a été affichée au moins une fois matches = [line for line in printed_lines if f"|{expected_bar}|" in line] > assert matches, f"Expected bar '{expected_bar}' not found in:\n" + "\n".join(printed_lines) E AssertionError: Expected bar '<<<<<<<<<<' not found in: E [DEBUG] PUT start = 0.0, stop = -50.0 E [ 0 |[32m [39m| -50 ] [1m0[0m E E assert [] tests/test_utils_pv.py:81: AssertionError📌 Teardown phase
duration:
0.00025898776948451996outcome:
passed
↳ Function: test_use_callback_context_manager
-
❌ Test 355
📌 Setup phase
duration:
0.00019025709480047226outcome:
passed📌 Call phase
duration:
0.0018029860220849514outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_pv.py lineno: 105 message: AttributeError: 'PV' object has no attribute '_callbacks'traceback:
- path: tests/test_utils_pv.py lineno: 105 message: AttributeErrorlog:
- name: pcaspy.SimplePV.getValue msg: VAL: Read value -50.0 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 649 funcName: getValue created: 1754565321.9095871 msecs: 909.5871448516846 relativeCreated: 9808.718204498291 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.SimplePV.writeValue msg: VAL: 0808d44cd37f root old=-50.0 new=0.0 args: None levelname: INFO levelno: 20 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 549 funcName: writeValue created: 1754565321.9098809 msecs: 909.8808765411377 relativeCreated: 9809.011936187744 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123413321.909984380 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565321.9100068 msecs: 910.0067615509033 relativeCreated: 9809.13782119751 thread: 139696193087168 threadName: Thread-4 processName: MainProcess process: 1903longrepr:
def test_use_callback_context_manager(): pv = PV("TEST:VAL", connection_timeout=2.0) assert pv.wait_for_connection(timeout=2.0), "PV not connected" pv.put(0.0, wait=True) seen_values = [] def callback(value=None, **kwargs): seen_values.append(value) > initial_count = len(pv._callbacks) E AttributeError: 'PV' object has no attribute '_callbacks' tests/test_utils_pv.py:105: AttributeError📌 Teardown phase
duration:
0.00046734604984521866outcome:
passed
-
-
📄 test_utils_run_later.py
↳ Function: test_run_at_tqdm_multiple_updates
-
❌ Test 417
📌 Setup phase
duration:
0.00036987289786338806outcome:
passed📌 Call phase
duration:
0.20357779506593943outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_run_later.py lineno: 128 message: AssertionError: assert '50%|█████ |' in '\r 0%| | 0/ 0.2 [00:00<?, ? Hz]\r 51%|█████ | 0.1/ 0.2 [00:00<00:00, 1.0 Hz]\r100%|██████████| 0.2/ 0.2 [00:00<00:00, 1.0s/@]\n' + where '\r 0%| | 0/ 0.2 [00:00<?, ? Hz]\r 51%|█████ | 0.1/ 0.2 [00:00<00:00, 1.0 Hz]\r100%|██████████| 0.2/ 0.2 [00:00<00:00, 1.0s/@]\n' = CaptureResult(out='it is currently 2025-08-07 11:15:22.736771\nwill run at 2025-08-07 11:15:22.936745\nthis ..., ? Hz]\r 51%|█████ | 0.1/ 0.2 [00:00<00:00, 1.0 Hz]\r100%|██████████| 0.2/ 0.2 [00:00<00:00, 1.0s/@]\n').errtraceback:
- path: tests/test_utils_run_later.py lineno: 128 message: AssertionErrorlog:
- name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413322.768568194 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565322.7687433 msecs: 768.7432765960693 relativeCreated: 10667.874336242676 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903 - name: pcaspy.Driver.setParam msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123413322.869343669 args: None levelname: DEBUG levelno: 10 pathname: /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/pcaspy/driver.py filename: driver.py module: driver exc_info: None exc_text: None stack_info: None lineno: 175 funcName: setParam created: 1754565322.869535 msecs: 869.534969329834 relativeCreated: 10768.66602897644 thread: 139696184694464 threadName: Thread-3 processName: MainProcess process: 1903longrepr:
monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7f0de36f4c70> capsys = <_pytest.capture.CaptureFixture object at 0x7f0de415d130> def test_run_at_tqdm_multiple_updates(monkeypatch, capsys): def fexample(): print("Function done!") when = datetime.now() + timedelta(seconds=0.2) run_at(when, fexample) captured = capsys.readouterr() assert "0%| |" in captured.err > assert "50%|█████ |" in captured.err E AssertionError: assert '50%|█████ |' in '\r 0%| | 0/ 0.2 [00:00<?, ? Hz]\r 51%|█████ | 0.1/ 0.2 [00:00<00:00, 1.0 Hz]\r100%|██████████| 0.2/ 0.2 [00:00<00:00, 1.0s/@]\n' E + where '\r 0%| | 0/ 0.2 [00:00<?, ? Hz]\r 51%|█████ | 0.1/ 0.2 [00:00<00:00, 1.0 Hz]\r100%|██████████| 0.2/ 0.2 [00:00<00:00, 1.0s/@]\n' = CaptureResult(out='it is currently 2025-08-07 11:15:22.736771\nwill run at 2025-08-07 11:15:22.936745\nthis ..., ? Hz]\r 51%|█████ | 0.1/ 0.2 [00:00<00:00, 1.0 Hz]\r100%|██████████| 0.2/ 0.2 [00:00<00:00, 1.0s/@]\n').err tests/test_utils_run_later.py:128: AssertionError📌 Teardown phase
duration:
0.0004695742391049862outcome:
passed
-
-
📄 test_utils_tqdm_mod.py
↳ Function: test_float_alignment_in_bar
-
❌ Test 454
📌 Setup phase
duration:
0.00011406000703573227outcome:
passed📌 Call phase
duration:
0.0016572470776736736outcome:
failedcrash:
path: /workspace/tligui_y/slic/tests/test_utils_tqdm_mod.py lineno: 130 message: assert 3 == 1 + where 3 = len({50, 64, 65}) + where {50, 64, 65} = set([50, 64, 64, 65, 65])traceback:
- path: tests/test_utils_tqdm_mod.py lineno: 130 message: AssertionErrorlongrepr:
def test_float_alignment_in_bar(): # Capture the tqdm output into a string buffer f = io.StringIO() with redirect_stdout(f): bar = tqdm_mod(total=100.12, desc="AlignBar", file=f, miniters=1, mininterval=0) bar.set(1.3333) bar.set(12.5) bar.set(99.89) bar.set(100.12) bar.close() # Extract lines containing the label lines = extract_lines(f.getvalue(), "AlignBar") # Expected formatted values using format_sizeof expected_values = [ "1.3/100.1", "12.5/100.1", "99.9/100.1", "100.1/100.1", ] # Extract the actual padded float/total strings from the full lines values = [] for line in lines: match = re.search(r"(\d{1,3}\.\d)/100\.1", line) if match: values.append(match.group(0)) # Ensure raw 100.12 never appears : format_sizeof must have truncated it assert all("100.12" not in line for line in lines), "Unrounded value '100.12' found in output!" # Check all expected values appear rounded as expected by format_sizeof for expected in expected_values: assert expected in values, f"Missing expected value: {expected}" # Check that all values are visually aligned, output with same length, to ensure that format_sizeof add the good number avec spaces print("\n") bar_segments = [] for line in lines: match = re.search(r".*?\]", line) if match: bar_segments.append(match.group(0)) print(match.group(0)) lengths = [len(seg) for seg in bar_segments] > assert len(set(lengths)) == 1 E assert 3 == 1 E + where 3 = len({50, 64, 65}) E + where {50, 64, 65} = set([50, 64, 64, 65, 65]) tests/test_utils_tqdm_mod.py:130: AssertionError📌 Teardown phase
duration:
0.0001606023870408535outcome:
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:
✅ elog-2.7.1 (16 tests)
-
✅ elog-2.7.1
- Outcome:
passed - result:
- nodeid: elog-2.7.1/contrib type: Dir - nodeid: elog-2.7.1/doc type: Dir - nodeid: elog-2.7.1/logbooks type: Dir - nodeid: elog-2.7.1/man type: Dir - nodeid: elog-2.7.1/resources type: Dir - nodeid: elog-2.7.1/scripts type: Dir - nodeid: elog-2.7.1/src type: Dir - nodeid: elog-2.7.1/themes type: Dir-
✅ elog-2.7.1/contrib
- Outcome:
passed - result:
[] - Outcome:
-
✅ elog-2.7.1/doc
- Outcome:
passed - result:
[] - Outcome:
-
✅ elog-2.7.1/logbooks
- Outcome:
passed - result:
- nodeid: elog-2.7.1/logbooks/demo type: Dir - Outcome:
-
✅ elog-2.7.1/logbooks/demo
- Outcome:
passed - result:
[] - Outcome:
-
✅ elog-2.7.1/man
- Outcome:
passed - result:
[] - Outcome:
-
✅ elog-2.7.1/resources
- Outcome:
passed - result:
[] - Outcome:
-
✅ elog-2.7.1/scripts
- Outcome:
passed - result:
- nodeid: elog-2.7.1/scripts/fckeditor type: Dir - Outcome:
-
✅ elog-2.7.1/scripts/fckeditor
- Outcome:
passed - result:
- nodeid: elog-2.7.1/scripts/fckeditor/editor type: Dir - Outcome:
-
✅ elog-2.7.1/scripts/fckeditor/editor
- Outcome:
passed - result:
- nodeid: elog-2.7.1/scripts/fckeditor/editor/plugins type: Dir - Outcome:
-
✅ elog-2.7.1/scripts/fckeditor/editor/plugins
- Outcome:
passed - result:
- nodeid: elog-2.7.1/scripts/fckeditor/editor/plugins/elog type: Dir - Outcome:
-
✅ elog-2.7.1/scripts/fckeditor/editor/plugins/elog
- Outcome:
passed - result:
[] - Outcome:
-
✅ elog-2.7.1/src
- Outcome:
passed - result:
[] - Outcome:
-
✅ elog-2.7.1/themes
- Outcome:
passed - result:
- nodeid: elog-2.7.1/themes/default type: Dir - Outcome:
-
✅ elog-2.7.1/themes/default
- Outcome:
passed - result:
- nodeid: elog-2.7.1/themes/default/icons type: Dir - Outcome:
-
✅ elog-2.7.1/themes/default/icons
- Outcome:
passed - result:
[] - Outcome:
- Outcome:
✅ elog_instance (3 tests)
-
✅ elog_instance
- Outcome:
passed - result:
- nodeid: elog_instance/logbooks type: Dir-
✅ elog_instance/logbooks
- Outcome:
passed - result:
- nodeid: elog_instance/logbooks/demo type: Dir - Outcome:
-
✅ elog_instance/logbooks/demo
- Outcome:
passed - result:
[] - Outcome:
- Outcome:
✅ morbidissimo (6 tests)
-
✅ morbidissimo
- Outcome:
passed - result:
- nodeid: morbidissimo/morbidissimo type: Package-
✅ morbidissimo/morbidissimo
- Outcome:
passed - result:
- nodeid: morbidissimo/morbidissimo/modman type: Package - nodeid: morbidissimo/morbidissimo/morioc type: Package - Outcome:
-
✅ morbidissimo/morbidissimo/modman
- Outcome:
passed - result:
- nodeid: morbidissimo/morbidissimo/modman/scripts type: Dir - Outcome:
-
✅ morbidissimo/morbidissimo/modman/scripts
- Outcome:
passed - result:
[] - Outcome:
-
✅ morbidissimo/morbidissimo/morioc
- Outcome:
passed - result:
- nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py type: Module - Outcome:
-
✅ morbidissimo/morbidissimo/morioc/test_infer_type.py
- Outcome:
passed - result:
- nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_type_str type: Function lineno: 14 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_type_float type: Function lineno: 17 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_type_int type: Function lineno: 20 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_value_str type: Function lineno: 24 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_value_long_str type: Function lineno: 27 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_value_float type: Function lineno: 32 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_value_int type: Function lineno: 35 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_empty_value_str type: Function lineno: 39 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_empty_value_float type: Function lineno: 42 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_empty_value_int type: Function lineno: 45 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_pstrue_str type: Function lineno: 49 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_pstrue_float type: Function lineno: 52 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_pstrue_int type: Function lineno: 55 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_psfalse_str type: Function lineno: 59 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_psfalse_float type: Function lineno: 62 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_psfalse_int type: Function lineno: 65 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_None type: Function lineno: 69 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_True type: Function lineno: 72 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_False type: Function lineno: 75 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_nan type: Function lineno: 78 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_np_nan type: Function lineno: 81 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_np1D_int type: Function lineno: 85 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_np2D_int type: Function lineno: 91 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_np1D_float type: Function lineno: 99 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_np2D_float type: Function lineno: 105 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_np1D_bool type: Function lineno: 114 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_np1D_object type: Function lineno: 119 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_np_scalar_int type: Function lineno: 126 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_np_scalar_float type: Function lineno: 131 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_np_scalar_bool type: Function lineno: 136 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_list type: Function lineno: 145 - nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py::test_it_tuple type: Function lineno: 150 - Outcome:
- Outcome:
✅ mxml (1 tests)
-
✅ mxml
- Outcome:
passed - result:
[] - 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 (43 tests)
-
✅ tests
- Outcome:
passed - result:
- nodeid: tests/test_utils_argfwd.py type: Module - nodeid: tests/test_utils_ask_yes_no.py type: Module - nodeid: tests/test_utils_channels.py type: Module - nodeid: tests/test_utils_config.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_elog.py type: Module - nodeid: tests/test_utils_eval.py type: Module - nodeid: tests/test_utils_exceptions.py type: Module - nodeid: tests/test_utils_get_adj.py type: Module - nodeid: tests/test_utils_hastyepics.py type: Module - nodeid: tests/test_utils_ipy.py type: Module - nodeid: tests/test_utils_jsonext.py type: Module - nodeid: tests/test_utils_lazypv.py type: Module - nodeid: tests/test_utils_logcfg.py type: Module - nodeid: tests/test_utils_logign.py type: Module - nodeid: tests/test_utils_metaclasses.py type: Module - nodeid: tests/test_utils_namespace.py type: Module - nodeid: tests/test_utils_npy.py type: Module - nodeid: tests/test_utils_path.py type: Module - nodeid: tests/test_utils_picklio.py type: Module - nodeid: tests/test_utils_printing.py type: Module - nodeid: tests/test_utils_pv.py type: Module - nodeid: tests/test_utils_rangebar.py type: Module - nodeid: tests/test_utils_readable.py type: Module - nodeid: tests/test_utils_registry.py type: Module - nodeid: tests/test_utils_richcfg.py type: Module - nodeid: tests/test_utils_run_later.py type: Module - nodeid: tests/test_utils_sendmail.py type: Module - nodeid: tests/test_utils_shortcut.py type: Module - nodeid: tests/test_utils_snapshot.py type: Module - nodeid: tests/test_utils_termtitle.py type: Module - nodeid: tests/test_utils_tqdm_mod.py type: Module - nodeid: tests/test_utils_trinary.py type: Module - nodeid: tests/test_utils_typecast.py type: Module - nodeid: tests/test_utils_utils.py type: Module - nodeid: tests/test_utils_xrange.py type: Module-
✅ tests/test_utils_argfwd.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_argfwd.py::test_split_at[lst0-2-expected0] type: Function lineno: 8 - nodeid: tests/test_utils_argfwd.py::test_split_at[lst1-1-expected1] type: Function lineno: 8 - nodeid: tests/test_utils_argfwd.py::test_split_at[lst2-0-expected2] type: Function lineno: 8 - nodeid: tests/test_utils_argfwd.py::test_merge_lists_unique[a0-b0-expected0] type: Function lineno: 17 - nodeid: tests/test_utils_argfwd.py::test_merge_lists_unique[a1-b1-expected1] type: Function lineno: 17 - nodeid: tests/test_utils_argfwd.py::test_merge_lists_unique[a2-b2-expected2] type: Function lineno: 17 - nodeid: tests/test_utils_argfwd.py::test_merge_dicts_unique[a0-b0-expected0] type: Function lineno: 26 - nodeid: tests/test_utils_argfwd.py::test_merge_dicts_unique[a1-b1-expected1] type: Function lineno: 26 - nodeid: tests/test_utils_argfwd.py::test_merge_dicts_unique[a2-b2-expected2] type: Function lineno: 26 - nodeid: tests/test_utils_argfwd.py::test_make_params_pos_basic[pos0-expected_names0] type: Function lineno: 35 - nodeid: tests/test_utils_argfwd.py::test_make_params_pos_basic[pos1-expected_names1] type: Function lineno: 35 - nodeid: tests/test_utils_argfwd.py::test_make_params_pos_basic[pos2-expected_names2] type: Function lineno: 35 - nodeid: tests/test_utils_argfwd.py::test_make_params_kw_basic[kw0-expected_keys0-expected_defaults0] type: Function lineno: 48 - nodeid: tests/test_utils_argfwd.py::test_make_params_kw_basic[kw1-expected_keys1-expected_defaults1] type: Function lineno: 48 - nodeid: tests/test_utils_argfwd.py::test_make_params_kw_basic[kw2-expected_keys2-expected_defaults2] type: Function lineno: 48 - nodeid: tests/test_utils_argfwd.py::test_make_signature_parametrized[pos0-kw0-(x, y, z=3)] type: Function lineno: 60 - nodeid: tests/test_utils_argfwd.py::test_make_signature_parametrized[pos1-kw1-(a, b=1, c=2)] type: Function lineno: 60 - nodeid: tests/test_utils_argfwd.py::test_make_signature_parametrized[pos2-kw2-(flag=False)] type: Function lineno: 60 - nodeid: tests/test_utils_argfwd.py::test_get_args_parametrized[<lambda>-expected_pos0-expected_kw0] type: Function lineno: 71 - nodeid: tests/test_utils_argfwd.py::test_get_args_parametrized[<lambda>-expected_pos1-expected_kw1] type: Function lineno: 71 - nodeid: tests/test_utils_argfwd.py::test_get_args_parametrized[<lambda>-expected_pos2-expected_kw2] type: Function lineno: 71 - nodeid: tests/test_utils_argfwd.py::test_signature_visible[wrap_all-(a, b, d=30, c=10)] type: Function lineno: 104 - nodeid: tests/test_utils_argfwd.py::test_signature_visible[wrap_skip-(a, b, c=10, d=20)] type: Function lineno: 104 - nodeid: tests/test_utils_argfwd.py::test_signature_visible[wrap_ignore_all-(x, y, c=10, d=20)] type: Function lineno: 104 - nodeid: tests/test_utils_argfwd.py::test_wrapper_behavior[wrap_all-args0-kwargs0-36] type: Function lineno: 112 - nodeid: tests/test_utils_argfwd.py::test_wrapper_behavior[wrap_all-args1-kwargs1-11] type: Function lineno: 112 - nodeid: tests/test_utils_argfwd.py::test_wrapper_behavior[wrap_skip-args2-kwargs2-10] type: Function lineno: 112 - nodeid: tests/test_utils_argfwd.py::test_wrapper_behavior[wrap_ignore_all-args3-kwargs3-10] type: Function lineno: 112 - Outcome:
-
✅ 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_config.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_config.py::test_config_with_nested_and_list_data type: Function lineno: 15 - nodeid: tests/test_utils_config.py::test_config_with_strange_and_edge_keys type: Function lineno: 73 - 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_elog.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_elog.py::test_post_local type: Function lineno: 29 - nodeid: tests/test_utils_elog.py::test_get_default_elog_instance_with_direct_password_and_real_check type: Function lineno: 53 - nodeid: tests/test_utils_elog.py::test_get_default_elog_instance_asks_password_and_opens type: Function lineno: 66 - nodeid: tests/test_utils_elog.py::test_get_default_elog_with_path_home type: Function lineno: 84 - nodeid: tests/test_utils_elog.py::test_post type: Function lineno: 115 - nodeid: tests/test_utils_elog.py::test_screenshot type: Function lineno: 131 - Outcome:
-
✅ tests/test_utils_eval.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[1 + 2-3] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[4 - 2-2] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[3 * 5-15] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[10 / 2-5.0] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[10 % 3-1] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[-5--5] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[+7-7] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[1 + 2 * 3-7] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[(1 + 2) * 3-9] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[-(-3)-3] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[-2 + 4 * 2-6] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[(4 + 5) * (6 - 1)-45] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[(((3)))-3] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[-(-(-2))--2] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[3 + +4-7] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[3 + -4--1] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[True + 1-2] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid['string'-string] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid[1e1000 * 1e1000-inf] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_valid['a' + 'b'-ab] type: Function lineno: 7 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_raises_with_message[2 ** 3-Unsupported BinOp Pow] type: Function lineno: 33 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_raises_with_message[3 << 1-Unsupported BinOp LShift] type: Function lineno: 33 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_raises_with_message[1 < 2-Unsupported node type Compare] type: Function lineno: 33 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_raises_with_message[abs(3)-Unsupported node type Call] type: Function lineno: 33 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_raises_with_message[a + 2-Unsupported node type Name] type: Function lineno: 33 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_raises_with_message[string-Unsupported node type Name] type: Function lineno: 33 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_raises_with_message[[1, 2] + [3]-Unsupported node type List] type: Function lineno: 33 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_raises_with_message[{1: 2}-Unsupported node type Dict] type: Function lineno: 33 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_runtime_errors[1 / 0-ZeroDivisionError] type: Function lineno: 52 - nodeid: tests/test_utils_eval.py::test_arithmetic_eval_runtime_errors[10 % 0-ZeroDivisionError] type: Function lineno: 52 - nodeid: tests/test_utils_eval.py::test_forgiving_eval[1 + 2-3] type: Function lineno: 61 - nodeid: tests/test_utils_eval.py::test_forgiving_eval[bad + 2-bad + 2] type: Function lineno: 61 - nodeid: tests/test_utils_eval.py::test_forgiving_eval[1 / 0-1 / 0] type: Function lineno: 61 - nodeid: tests/test_utils_eval.py::test_forgiving_eval[2 ** 10-2 ** 10] type: Function lineno: 61 - nodeid: tests/test_utils_eval.py::test_defaulting_eval[3 * 4-0-12] type: Function lineno: 71 - nodeid: tests/test_utils_eval.py::test_defaulting_eval[invalid + 1-99-99] type: Function lineno: 71 - nodeid: tests/test_utils_eval.py::test_defaulting_eval[1 / 0--1--1] type: Function lineno: 71 - nodeid: tests/test_utils_eval.py::test_defaulting_eval[2 ** 10-42-42] type: Function lineno: 71 - Outcome:
-
✅ tests/test_utils_exceptions.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_exceptions.py::test_chained_exception_various[cause_key_error-High-level task failed\ncaused by KeyError: 'missing'] type: Function lineno: 28 - nodeid: tests/test_utils_exceptions.py::test_chained_exception_various[cause_index_error-High-level task failed\ncaused by IndexError: list index out of range] type: Function lineno: 28 - nodeid: tests/test_utils_exceptions.py::test_chained_exception_various[cause_zero_division-High-level task failed\ncaused by ZeroDivisionError: division by zero] type: Function lineno: 28 - nodeid: tests/test_utils_exceptions.py::test_chained_exception_various[cause_value_error-High-level task failed\ncaused by ValueError: invalid literal for int() with base 10: 'not_a_number'] type: Function lineno: 28 - nodeid: tests/test_utils_exceptions.py::test_chained_exception_various[cause_type_error-High-level task failed\ncaused by TypeError: can only concatenate str (not "int") to str] type: Function lineno: 28 - nodeid: tests/test_utils_exceptions.py::test_printed_exception[cause_key_error-KeyError: 'missing'] type: Function lineno: 60 - nodeid: tests/test_utils_exceptions.py::test_printed_exception[cause_index_error-IndexError: list index out of range] type: Function lineno: 60 - nodeid: tests/test_utils_exceptions.py::test_printed_exception[cause_zero_division-ZeroDivisionError: division by zero] type: Function lineno: 60 - nodeid: tests/test_utils_exceptions.py::test_printed_exception[cause_value_error-ValueError: invalid literal for int() with base 10: 'not_a_number'] type: Function lineno: 60 - nodeid: tests/test_utils_exceptions.py::test_printed_exception[cause_type_error-TypeError: can only concatenate str (not "int") to str] type: Function lineno: 60 - Outcome:
-
✅ tests/test_utils_get_adj.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_get_adj.py::test_get_adj_success type: Function lineno: 23 - nodeid: tests/test_utils_get_adj.py::test_get_adj_not_found type: Function lineno: 27 - nodeid: tests/test_utils_get_adj.py::test_ensure_adjs_mixed type: Function lineno: 31 - nodeid: tests/test_utils_get_adj.py::test_get_adjs_filter type: Function lineno: 37 - Outcome:
-
✅ tests/test_utils_hastyepics.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_hastyepics.py::test_motor_instantiation_fast_vs_epics type: Function lineno: 11 - nodeid: tests/test_utils_hastyepics.py::test_motor_without_suffix_and_dot type: Function lineno: 38 - nodeid: tests/test_utils_hastyepics.py::test_motor_invalid_name_raises type: Function lineno: 50 - nodeid: tests/test_utils_hastyepics.py::test_motor_init_list_has_no_disabled type: Function lineno: 55 - nodeid: tests/test_utils_hastyepics.py::test_motor_initializes_device_attrs type: Function lineno: 59 - nodeid: tests/test_utils_hastyepics.py::test_motor_pv_connection_skipped_by_default type: Function lineno: 82 - nodeid: tests/test_utils_hastyepics.py::test_motor_adds_all_extras_pvs type: Function lineno: 90 - nodeid: tests/test_utils_hastyepics.py::test_motor_PV_method_exists_and_works type: Function lineno: 109 - Outcome:
-
✅ tests/test_utils_ipy.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_ipy.py::test_devices_repr_fallback_and_ignore type: Function lineno: 19 - 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: 7 - Outcome:
-
✅ tests/test_utils_logcfg.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_logcfg.py::test_custom_log_outputs[LONG-<lambda>-This is a LONG message] type: Function lineno: 21 - nodeid: tests/test_utils_logcfg.py::test_custom_log_outputs[ENLARGE-<lambda>-Please ENLARGE this!] type: Function lineno: 21 - nodeid: tests/test_utils_logcfg.py::test_import_logging_once_per_module type: Function lineno: 51 - Outcome:
-
✅ tests/test_utils_logign.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_logign.py::test_ignore_log_msg_behavior[WARNING-This should be ignored-This should appear] type: Function lineno: 9 - nodeid: tests/test_utils_logign.py::test_ignore_log_msg_behavior[ENLARGE-ENLARGE this-Keep this ENLARGE] type: Function lineno: 9 - nodeid: tests/test_utils_logign.py::test_ignore_only_by_level type: Function lineno: 42 - nodeid: tests/test_utils_logign.py::test_ignore_only_by_msg type: Function lineno: 64 - nodeid: tests/test_utils_logign.py::test_filter_removed_after_context type: Function lineno: 86 - Outcome:
-
✅ tests/test_utils_metaclasses.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_metaclasses.py::test_combine_classes_combines_methods type: Function lineno: 14 - nodeid: tests/test_utils_metaclasses.py::test_registryabc_combines_registrymeta_and_abcmeta type: Function lineno: 25 - Outcome:
-
✅ tests/test_utils_namespace.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_namespace.py::test_namespace_pretty_repr_mixed_and_nested type: Function lineno: 4 - Outcome:
-
✅ tests/test_utils_npy.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_npy.py::test_nice_arange[0-5-1-expected0] type: Function lineno: 7 - nodeid: tests/test_utils_npy.py::test_nice_arange[5-0--1-expected1] type: Function lineno: 7 - nodeid: tests/test_utils_npy.py::test_nice_arange[1-2-0.3-expected2] type: Function lineno: 7 - nodeid: tests/test_utils_npy.py::test_nice_arange[-2-2-1.5-expected3] type: Function lineno: 7 - nodeid: tests/test_utils_npy.py::test_nice_arange[2.5-0.5--0.4-expected4] type: Function lineno: 7 - nodeid: tests/test_utils_npy.py::test_nice_linspace[0-10-4-expected0] type: Function lineno: 18 - nodeid: tests/test_utils_npy.py::test_nice_linspace[5-15-2-expected1] type: Function lineno: 18 - nodeid: tests/test_utils_npy.py::test_nice_linspace[-5-5-4-expected2] type: Function lineno: 18 - nodeid: tests/test_utils_npy.py::test_nice_linspace[0-1-3-expected3] type: Function lineno: 18 - nodeid: tests/test_utils_npy.py::test_nice_linspace[2-2-3-expected4] type: Function lineno: 18 - nodeid: tests/test_utils_npy.py::test_nice_linspace[3-0-3-expected5] type: Function lineno: 18 - nodeid: tests/test_utils_npy.py::test_nice_linspace[0-1-0-expected6] type: Function lineno: 18 - nodeid: tests/test_utils_npy.py::test_nice_steps_centered[-2-2-2-True-expected0] type: Function lineno: 32 - nodeid: tests/test_utils_npy.py::test_nice_steps_centered[0-5-2-True-expected1] type: Function lineno: 32 - nodeid: tests/test_utils_npy.py::test_nice_steps_centered[0-5-2-False-expected2] type: Function lineno: 32 - nodeid: tests/test_utils_npy.py::test_nice_steps_centered[-1-2-1.5-True-expected3] type: Function lineno: 32 - nodeid: tests/test_utils_npy.py::test_nice_steps_left_aligned[0-5-2-True-expected0] type: Function lineno: 42 - nodeid: tests/test_utils_npy.py::test_nice_steps_left_aligned[0-5-2-False-expected1] type: Function lineno: 42 - nodeid: tests/test_utils_npy.py::test_nice_steps_left_aligned[-1-2-1.5-True-expected2] type: Function lineno: 42 - nodeid: tests/test_utils_npy.py::test_nice_steps_left_aligned[-1-2-1.5-False-expected3] type: Function lineno: 42 - nodeid: tests/test_utils_npy.py::test_nice_steps_left_aligned[-2-1-1.2-True-expected4] type: Function lineno: 42 - nodeid: tests/test_utils_npy.py::test_nice_steps_left_aligned[5-0--2-True-expected5] type: Function lineno: 42 - nodeid: tests/test_utils_npy.py::test_nice_steps_left_aligned[5-0--2-False-expected6] type: Function lineno: 42 - nodeid: tests/test_utils_npy.py::test_nice_steps_right_aligned[0-5-2-True-expected0] type: Function lineno: 56 - nodeid: tests/test_utils_npy.py::test_nice_steps_right_aligned[0-5-2-False-expected1] type: Function lineno: 56 - nodeid: tests/test_utils_npy.py::test_nice_steps_right_aligned[-1-2-1.5-True-expected2] type: Function lineno: 56 - nodeid: tests/test_utils_npy.py::test_nice_steps_right_aligned[-1-2-1.5-False-expected3] type: Function lineno: 56 - nodeid: tests/test_utils_npy.py::test_nice_steps_right_aligned[5-0--2-True-expected4] type: Function lineno: 56 - nodeid: tests/test_utils_npy.py::test_nice_steps_right_aligned[5-0--2-False-expected5] type: Function lineno: 56 - nodeid: tests/test_utils_npy.py::test_nice_steps_right_aligned[-3-3-2-True-expected6] type: Function lineno: 56 - nodeid: tests/test_utils_npy.py::test_within_scalar[5-0-10-True] type: Function lineno: 70 - nodeid: tests/test_utils_npy.py::test_within_scalar[5-6-10-False] type: Function lineno: 70 - nodeid: tests/test_utils_npy.py::test_within_scalar[5-None-10-True] type: Function lineno: 70 - nodeid: tests/test_utils_npy.py::test_within_scalar[5-0-None-True] type: Function lineno: 70 - nodeid: tests/test_utils_npy.py::test_within_scalar[5-None-None-True] type: Function lineno: 70 - nodeid: tests/test_utils_npy.py::test_within_fraction[data0-2-5-0.6] type: Function lineno: 81 - nodeid: tests/test_utils_npy.py::test_within_fraction[data1-5-25-0.6666666666666666] type: Function lineno: 81 - nodeid: tests/test_utils_npy.py::test_within_fraction[data2-None-2-0.3333333333333333] type: Function lineno: 81 - nodeid: tests/test_utils_npy.py::test_within_fraction[data3-0-1-0] type: Function lineno: 81 - nodeid: tests/test_utils_npy.py::test_fraction_to_percentage[0.456-1-45.6] type: Function lineno: 92 - nodeid: tests/test_utils_npy.py::test_fraction_to_percentage[0.12345-2-12.35] type: Function lineno: 92 - nodeid: tests/test_utils_npy.py::test_fraction_to_percentage[0.9999-0-100.0] type: Function lineno: 92 - nodeid: tests/test_utils_npy.py::test_get_dtype[val0-ndarray] type: Function lineno: 101 - nodeid: tests/test_utils_npy.py::test_get_dtype[val1-list] type: Function lineno: 101 - nodeid: tests/test_utils_npy.py::test_get_dtype[3.14-float] type: Function lineno: 101 - nodeid: tests/test_utils_npy.py::test_get_shape[val0-expected0] type: Function lineno: 114 - nodeid: tests/test_utils_npy.py::test_get_shape[val1-expected1] type: Function lineno: 114 - nodeid: tests/test_utils_npy.py::test_get_shape[42-expected2] type: Function lineno: 114 - nodeid: tests/test_utils_npy.py::test_is_array[val0-True] type: Function lineno: 123 - nodeid: tests/test_utils_npy.py::test_is_array[val1-False] type: Function lineno: 123 - nodeid: tests/test_utils_npy.py::test_is_array[42-False] type: Function lineno: 123 - Outcome:
-
✅ tests/test_utils_path.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_path.py::test_can_create_all_files_user_says_yes type: Function lineno: 10 - nodeid: tests/test_utils_path.py::test_can_create_all_files_user_says_no type: Function lineno: 36 - nodeid: tests/test_utils_path.py::test_make_missing_dir_creates_folder type: Function lineno: 54 - nodeid: tests/test_utils_path.py::test_glob_files_returns_matching_files_only type: Function lineno: 66 - nodeid: tests/test_utils_path.py::test_filter_files_excludes_directories type: Function lineno: 83 - 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:
-
✅ tests/test_utils_printing.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_printing.py::test_maxlen_valid[seq0-3] type: Function lineno: 8 - nodeid: tests/test_utils_printing.py::test_maxlen_valid[seq1-0] type: Function lineno: 8 - nodeid: tests/test_utils_printing.py::test_maxlen_valid[seq2-3] type: Function lineno: 8 - nodeid: tests/test_utils_printing.py::test_maxlen_valid[seq3-2] type: Function lineno: 8 - nodeid: tests/test_utils_printing.py::test_strlen[42-2] type: Function lineno: 17 - nodeid: tests/test_utils_printing.py::test_strlen[hello-5] type: Function lineno: 17 - nodeid: tests/test_utils_printing.py::test_strlen[False-5] type: Function lineno: 17 - nodeid: tests/test_utils_printing.py::test_strlen[None-4] type: Function lineno: 17 - nodeid: tests/test_utils_printing.py::test_strlen[value4-9] type: Function lineno: 17 - nodeid: tests/test_utils_printing.py::test_strlen[value5-8] type: Function lineno: 17 - nodeid: tests/test_utils_printing.py::test_strlen[value6-6] type: Function lineno: 17 - nodeid: tests/test_utils_printing.py::test_strlen[-0] type: Function lineno: 17 - nodeid: tests/test_utils_printing.py::test_strlen[this is a phrase-16] type: Function lineno: 17 - nodeid: tests/test_utils_printing.py::test_maxstrlen[seq0-6] type: Function lineno: 31 - nodeid: tests/test_utils_printing.py::test_maxstrlen[seq1-3] type: Function lineno: 31 - nodeid: tests/test_utils_printing.py::test_maxstrlen[seq2-9] type: Function lineno: 31 - nodeid: tests/test_utils_printing.py::test_maxstrlen[seq3-16] type: Function lineno: 31 - nodeid: tests/test_utils_printing.py::test_maxstrlen[seq4-5] type: Function lineno: 31 - nodeid: tests/test_utils_printing.py::test_transpose_matrix[data0-expected0] type: Function lineno: 41 - nodeid: tests/test_utils_printing.py::test_transpose_matrix[data1-expected1] type: Function lineno: 41 - nodeid: tests/test_utils_printing.py::test_transpose_matrix[data2-expected2] type: Function lineno: 41 - nodeid: tests/test_utils_printing.py::test_prepend[initial0-1-expected0] type: Function lineno: 50 - nodeid: tests/test_utils_printing.py::test_prepend[initial1-a-expected1] type: Function lineno: 50 - nodeid: tests/test_utils_printing.py::test_prepend[initial2-prepend2-expected2] type: Function lineno: 50 - nodeid: tests/test_utils_printing.py::test_prepend[initial3-prepend3-expected3] type: Function lineno: 50 - nodeid: tests/test_utils_printing.py::test_fmt_table_line[entries0-widths0- a bbb] type: Function lineno: 61 - nodeid: tests/test_utils_printing.py::test_fmt_table_line[entries1-widths1- 1 2] type: Function lineno: 61 - nodeid: tests/test_utils_printing.py::test_fmt_table_line[entries2-widths2- long val] type: Function lineno: 61 - nodeid: tests/test_utils_printing.py::test_fmt_table_line[entries3-widths3- True False] type: Function lineno: 61 - nodeid: tests/test_utils_printing.py::test_fmt_table_line[entries4-widths4- 123 4567] type: Function lineno: 61 - nodeid: tests/test_utils_printing.py::test_fmt_table_line[entries5-widths5- text with space end] type: Function lineno: 61 - nodeid: tests/test_utils_printing.py::test_fmt_table_line[entries6-widths6- {'a': 1} {'b': 2}] type: Function lineno: 61 - nodeid: tests/test_utils_printing.py::test_fmt_table_line[entries7-widths7- [1, 2] [3, 4]] type: Function lineno: 61 - nodeid: tests/test_utils_printing.py::test_fmt_label_sep[widths0------ ----] type: Function lineno: 74 - nodeid: tests/test_utils_printing.py::test_fmt_label_sep[widths1-=-== ===] type: Function lineno: 74 - nodeid: tests/test_utils_printing.py::test_fmt_label_sep[widths2-*-***** **] type: Function lineno: 74 - nodeid: tests/test_utils_printing.py::test_printable_dict_with_header[d0-HeaderTest-expected_lines0] type: Function lineno: 82 - nodeid: tests/test_utils_printing.py::test_printable_dict_of_dicts type: Function lineno: 101 - nodeid: tests/test_utils_printing.py::test_printable_table[data0-labels0-A: ID\nB: \u2713 Success?\nC: SuperPrecisionValue\nD: Result Metadata\n\n# A B C D\n- ------------- ----- ---------- ----------------------------\n0 X1 True 0.1234 {'meta': 'ok'}\n1 AnotherSample False 98765.4321 {'meta': [1, 2, 3]}\n2 Z None 0.0 {'meta': {'nested_key': 42}}] type: Function lineno: 128 - Outcome:
-
✅ tests/test_utils_pv.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_pv.py::test_put_with_progress_and_repr[0.0- -\x1b[32m] type: Function lineno: 47 - nodeid: tests/test_utils_pv.py::test_put_with_progress_and_repr[25.0-\u2588\u2588\u258c -\x1b[32m] type: Function lineno: 47 - nodeid: tests/test_utils_pv.py::test_put_with_progress_and_repr[50.0-\u2588\u2588\u2588\u2588\u2588 -\x1b[32m] type: Function lineno: 47 - nodeid: tests/test_utils_pv.py::test_put_with_progress_and_repr[75.0-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u258c -\x1b[32m] type: Function lineno: 47 - nodeid: tests/test_utils_pv.py::test_put_with_progress_and_repr[100.0-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588-\x1b[32m] type: Function lineno: 47 - nodeid: tests/test_utils_pv.py::test_put_with_progress_and_repr[150.0->>>>>>>>>>-\x1b[31m] type: Function lineno: 47 - nodeid: tests/test_utils_pv.py::test_put_with_progress_and_repr[-50.0-<<<<<<<<<<-\x1b[31m] type: Function lineno: 47 - nodeid: tests/test_utils_pv.py::test_use_callback_context_manager type: Function lineno: 94 - Outcome:
-
✅ tests/test_utils_rangebar.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_rangebar.py::test_full_progress_bar type: Function lineno: 14 - nodeid: tests/test_utils_rangebar.py::test_half_progress_bar type: Function lineno: 27 - nodeid: tests/test_utils_rangebar.py::test_zero_progress_bar type: Function lineno: 42 - nodeid: tests/test_utils_rangebar.py::test_overflow_bar type: Function lineno: 56 - nodeid: tests/test_utils_rangebar.py::test_underflow_bar type: Function lineno: 69 - nodeid: tests/test_utils_rangebar.py::test_repr type: Function lineno: 82 - nodeid: tests/test_utils_rangebar.py::test_each_value_separately[0- ] type: Function lineno: 89 - nodeid: tests/test_utils_rangebar.py::test_each_value_separately[10-\u2588 ] type: Function lineno: 89 - nodeid: tests/test_utils_rangebar.py::test_each_value_separately[25-\u2588\u2588\u258c ] type: Function lineno: 89 - nodeid: tests/test_utils_rangebar.py::test_each_value_separately[27-\u2588\u2588\u258a ] type: Function lineno: 89 - nodeid: tests/test_utils_rangebar.py::test_each_value_separately[49-\u2588\u2588\u2588\u2588\u2589 ] type: Function lineno: 89 - nodeid: tests/test_utils_rangebar.py::test_each_value_separately[50-\u2588\u2588\u2588\u2588\u2588 ] type: Function lineno: 89 - nodeid: tests/test_utils_rangebar.py::test_each_value_separately[51-\u2588\u2588\u2588\u2588\u2588\u258f ] type: Function lineno: 89 - nodeid: tests/test_utils_rangebar.py::test_each_value_separately[73-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u258e ] type: Function lineno: 89 - nodeid: tests/test_utils_rangebar.py::test_each_value_separately[75-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u258c ] type: Function lineno: 89 - nodeid: tests/test_utils_rangebar.py::test_each_value_separately[90-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 ] type: Function lineno: 89 - nodeid: tests/test_utils_rangebar.py::test_each_value_separately[100-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588] type: Function lineno: 89 - Outcome:
-
✅ tests/test_utils_readable.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_readable.py::test_readable_seconds[59.4-59 seconds] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[59.9-60 seconds] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[119.9-120 seconds] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[120.1-2 minutes] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[3599.9-60 minutes] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[3600.1-60 minutes] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[7199.9-120 minutes] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[7200.1-2 hours] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[90.4-90 seconds] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[90.6-91 seconds] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[121.9-2 minutes] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[1296000.0-2 weeks] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[2592000.0-4 weeks] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[2800000.0-5 weeks] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[3888000.0-6 weeks] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[5097600.0-8 weeks] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[5184000.0-9 weeks] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[5270400.0-2 months] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[23328000.0-9 months] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[31104000.0-12 months] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[33696000.0-13 months] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[59616000.0-23 months] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[62208000.0-24 months] type: Function lineno: 3 - nodeid: tests/test_utils_readable.py::test_readable_seconds[64208000.0-2 years] type: Function lineno: 3 - Outcome:
-
✅ tests/test_utils_registry.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_registry.py::test_metaclass_creates_weakset type: Function lineno: 13 - nodeid: tests/test_utils_registry.py::test_metaclass_tracks_instances type: Function lineno: 22 - nodeid: tests/test_utils_registry.py::test_registry_inheritance type: Function lineno: 32 - nodeid: tests/test_utils_registry.py::test_instance_tracking type: Function lineno: 39 - nodeid: tests/test_utils_registry.py::test_collect_instances_recursive type: Function lineno: 53 - nodeid: tests/test_utils_registry.py::test_instances_function type: Function lineno: 69 - nodeid: tests/test_utils_registry.py::test_non_registry_class_error type: Function lineno: 93 - nodeid: tests/test_utils_registry.py::test_signature_preservation type: Function lineno: 102 - Outcome:
-
✅ tests/test_utils_richcfg.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_richcfg.py::test_rich_inspector_outputs_more_than_builtin type: Function lineno: 45 - Outcome:
-
✅ tests/test_utils_run_later.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_run_later.py::test_init_and_repr type: Function lineno: 17 - nodeid: tests/test_utils_run_later.py::test_call type: Function lineno: 22 - nodeid: tests/test_utils_run_later.py::test_matmul_with_string type: Function lineno: 27 - nodeid: tests/test_utils_run_later.py::test_matmul_with_list type: Function lineno: 32 - nodeid: tests/test_utils_run_later.py::test_matmul_with_single_int type: Function lineno: 37 - nodeid: tests/test_utils_run_later.py::test_run_at_future_triggered_and_logs type: Function lineno: 49 - nodeid: tests/test_utils_run_later.py::test_run_at_already_past type: Function lineno: 61 - nodeid: tests/test_utils_run_later.py::test_run_in_future_triggered_and_logs type: Function lineno: 72 - nodeid: tests/test_utils_run_later.py::test_run_in_past type: Function lineno: 83 - nodeid: tests/test_utils_run_later.py::test_run_later_with_seconds type: Function lineno: 95 - nodeid: tests/test_utils_run_later.py::test_run_later_with_past_datetime type: Function lineno: 105 - nodeid: tests/test_utils_run_later.py::test_run_at_tqdm_multiple_updates type: Function lineno: 115 - nodeid: tests/test_utils_run_later.py::test_today_basic type: Function lineno: 137 - nodeid: tests/test_utils_run_later.py::test_tomorrow_basic type: Function lineno: 143 - nodeid: tests/test_utils_run_later.py::test_yesterday_basic type: Function lineno: 149 - nodeid: tests/test_utils_run_later.py::test_today_matmul_string type: Function lineno: 155 - nodeid: tests/test_utils_run_later.py::test_tomorrow_matmul_list type: Function lineno: 161 - nodeid: tests/test_utils_run_later.py::test_yesterday_matmul_single type: Function lineno: 167 - Outcome:
-
✅ tests/test_utils_sendmail.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_sendmail.py::test_sendmail_real_local_verbose type: Function lineno: 70 - Outcome:
-
✅ tests/test_utils_shortcut.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_shortcut.py::TestShortcutInitialization type: Class - nodeid: tests/test_utils_shortcut.py::test_run_method type: Function lineno: 31 - nodeid: tests/test_utils_shortcut.py::test_repr_output type: Function lineno: 54 - nodeid: tests/test_utils_shortcut.py::test_source_with_regular_function type: Function lineno: 62 - nodeid: tests/test_utils_shortcut.py::test_source_error_handling type: Function lineno: 76 - nodeid: tests/test_utils_shortcut.py::test_as_shortcut_basic type: Function lineno: 86 - nodeid: tests/test_utils_shortcut.py::test_as_shortcut_with_name type: Function lineno: 96 - nodeid: tests/test_utils_shortcut.py::test_as_shortcut_factory_pattern type: Function lineno: 104 - nodeid: tests/test_utils_shortcut.py::TestShortcutsSingleton type: Class - nodeid: tests/test_utils_shortcut.py::TestFullIntegration type: Class - nodeid: tests/test_utils_shortcut.py::test_registry_inheritance type: Function lineno: 204 - Outcome:
-
✅ tests/test_utils_shortcut.py::TestFullIntegration
- Outcome:
passed - result:
- nodeid: tests/test_utils_shortcut.py::TestFullIntegration::test_workflow type: Function lineno: 170 - nodeid: tests/test_utils_shortcut.py::TestFullIntegration::test_multiple_shortcuts type: Function lineno: 190 - Outcome:
-
✅ tests/test_utils_shortcut.py::TestShortcutInitialization
- Outcome:
passed - result:
- nodeid: tests/test_utils_shortcut.py::TestShortcutInitialization::test_init_with_custom_name type: Function lineno: 16 - nodeid: tests/test_utils_shortcut.py::TestShortcutInitialization::test_init_without_name type: Function lineno: 23 - Outcome:
-
✅ tests/test_utils_shortcut.py::TestShortcutsSingleton
- Outcome:
passed - result:
- nodeid: tests/test_utils_shortcut.py::TestShortcutsSingleton::test_singleton_behavior type: Function lineno: 121 - nodeid: tests/test_utils_shortcut.py::TestShortcutsSingleton::test_registration type: Function lineno: 127 - nodeid: tests/test_utils_shortcut.py::TestShortcutsSingleton::test_getitem_access type: Function lineno: 141 - nodeid: tests/test_utils_shortcut.py::TestShortcutsSingleton::test_missing_key type: Function lineno: 149 - nodeid: tests/test_utils_shortcut.py::TestShortcutsSingleton::test_repr_output type: Function lineno: 154 - Outcome:
-
✅ tests/test_utils_snapshot.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_snapshot.py::test_snapshot[exclude_internals] type: Function lineno: 83 - nodeid: tests/test_utils_snapshot.py::test_snapshot[include_internals] type: Function lineno: 83 - nodeid: tests/test_utils_snapshot.py::test_snapshot[empty_case] type: Function lineno: 83 - nodeid: tests/test_utils_snapshot.py::test_snapshot[sort_str] type: Function lineno: 83 - nodeid: tests/test_utils_snapshot.py::test_snapshot[sort_id] type: Function lineno: 83 - nodeid: tests/test_utils_snapshot.py::test_snapshot[sort_case_insensitive] type: Function lineno: 83 - nodeid: tests/test_utils_snapshot.py::test_snapshot[sort_length] type: Function lineno: 83 - nodeid: tests/test_utils_snapshot.py::test_snapshot[sort_reverse] type: Function lineno: 83 - Outcome:
-
✅ tests/test_utils_termtitle.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_termtitle.py::test_terminal_title_with_tmux type: Function lineno: 9 - Outcome:
-
✅ tests/test_utils_tqdm_mod.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_tqdm_mod.py::test_complete_progress_bar type: Function lineno: 25 - nodeid: tests/test_utils_tqdm_mod.py::test_set_progress_multiple_points type: Function lineno: 42 - nodeid: tests/test_utils_tqdm_mod.py::test_format_sizeof_alignment type: Function lineno: 65 - nodeid: tests/test_utils_tqdm_mod.py::test_float_alignment_in_bar type: Function lineno: 83 - nodeid: tests/test_utils_tqdm_mod.py::test_custom_unit type: Function lineno: 132 - nodeid: tests/test_utils_tqdm_mod.py::test_clamp_above_total type: Function lineno: 146 - nodeid: tests/test_utils_tqdm_mod.py::test_clamp_below_zero type: Function lineno: 163 - Outcome:
-
✅ tests/test_utils_trinary.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_trinary.py::test_check_trinary_valid_values type: Function lineno: 6 - nodeid: tests/test_utils_trinary.py::test_check_trinary_invalid_value type: Function lineno: 14 - nodeid: tests/test_utils_trinary.py::test_check_trinary_with_custom_allowed_values type: Function lineno: 22 - Outcome:
-
✅ tests/test_utils_typecast.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_typecast.py::test_downcast_success type: Function lineno: 24 - nodeid: tests/test_utils_typecast.py::test_upcast_success type: Function lineno: 30 - nodeid: tests/test_utils_typecast.py::test_downcast_invalid type: Function lineno: 41 - nodeid: tests/test_utils_typecast.py::test_upcast_invalid type: Function lineno: 48 - nodeid: tests/test_utils_typecast.py::test_object_identity_preserved type: Function lineno: 53 - nodeid: tests/test_utils_typecast.py::test_ensure_subclass_valid type: Function lineno: 64 - nodeid: tests/test_utils_typecast.py::test_ensure_subclass_invalid type: Function lineno: 67 - nodeid: tests/test_utils_typecast.py::test_cast_changes_class type: Function lineno: 79 - nodeid: tests/test_utils_typecast.py::test_cast_preserves_identity type: Function lineno: 86 - Outcome:
-
✅ tests/test_utils_utils.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_utils.py::test_singleton_instance type: Function lineno: 17 - nodeid: tests/test_utils_utils.py::test_singleton_identity type: Function lineno: 25 - nodeid: tests/test_utils_utils.py::test_typename[None-NoneType] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[True-bool] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[42-int] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[3.14-float] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[text-str] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[obj5-set] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[obj6-list] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[obj7-list] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[obj8-dict] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[<lambda>-function] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[sample_function-function] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[nested-function] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[len-builtin_function_or_method] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[sum-builtin_function_or_method] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[math-module] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[sys-module] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[function-type] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[<genexpr>-generator] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_typename[obj18-list_iterator] type: Function lineno: 44 - nodeid: tests/test_utils_utils.py::test_next_int[nums0-4] type: Function lineno: 77 - nodeid: tests/test_utils_utils.py::test_next_int[nums1-21] type: Function lineno: 77 - nodeid: tests/test_utils_utils.py::test_next_int[nums2-0] type: Function lineno: 77 - nodeid: tests/test_utils_utils.py::test_zero_pad[7-3-007] type: Function lineno: 87 - nodeid: tests/test_utils_utils.py::test_zero_pad[123-5-00123] type: Function lineno: 87 - nodeid: tests/test_utils_utils.py::test_zero_pad[0-2-00] type: Function lineno: 87 - nodeid: tests/test_utils_utils.py::test_iround[3.6-4] type: Function lineno: 97 - nodeid: tests/test_utils_utils.py::test_iround[2.1-2] type: Function lineno: 97 - nodeid: tests/test_utils_utils.py::test_iround[-1.5--2] type: Function lineno: 97 - nodeid: tests/test_utils_utils.py::test_iround[-1.4--1] type: Function lineno: 97 - nodeid: tests/test_utils_utils.py::test_sorted_naturally[items0-expected0] type: Function lineno: 108 - nodeid: tests/test_utils_utils.py::test_sorted_naturally[items1-expected1] type: Function lineno: 108 - nodeid: tests/test_utils_utils.py::test_sorted_naturally_reverse[items0-expected0] type: Function lineno: 115 - Outcome:
-
✅ tests/test_utils_xrange.py
- Outcome:
passed - result:
- nodeid: tests/test_utils_xrange.py::test_xrange_finite[args0-kwargs0-expected0] type: Function lineno: 11 - nodeid: tests/test_utils_xrange.py::test_xrange_finite[args1-kwargs1-expected1] type: Function lineno: 11 - nodeid: tests/test_utils_xrange.py::test_xrange_finite[args2-kwargs2-expected2] type: Function lineno: 11 - nodeid: tests/test_utils_xrange.py::test_xrange_finite[args3-kwargs3-expected3] type: Function lineno: 11 - nodeid: tests/test_utils_xrange.py::test_xrange_infinite[args0-kwargs0-count(0)] type: Function lineno: 20 - nodeid: tests/test_utils_xrange.py::test_xrange_infinite[args1-kwargs1-count(0, 2)] type: Function lineno: 20 - nodeid: tests/test_utils_xrange.py::test_xrange_too_many_args[args0] type: Function lineno: 31 - Outcome:
- Outcome:
✅ . (1 tests)
-
✅ .
- Outcome:
passed - result:
- nodeid: ci-reports type: Dir - nodeid: elog-2.7.1 type: Dir - nodeid: elog_instance type: Dir - nodeid: morbidissimo type: Dir - nodeid: mxml type: Dir - nodeid: outputs type: Dir - nodeid: slic type: Package - nodeid: temp-ci type: Dir - nodeid: tests type: Dir - Outcome:
⚠️ Warnings
Warnings nº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 nº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 nº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 nº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