Clone
1
run 1771 TEST commit a99c3a9
ci-bot edited this page 2025-08-06 21:51:20 +00:00

Test Report

View CI Run 1771 | Commit a99c3a9

🧪 Test Report

Generated on 2025-08-06 23:51:12 CEST

🧾 General Info

  • duration: 11.94078016281128
  • root: /workspace/tligui_y/slic
  • environment: {}

📋 Summary

  • Passed: 477
  • Failed: 33
  • Total: 510
  • Collected: 510

🔎 Tests

Passed (477)
  • 📄 morbidissimo/morbidissimo/morioc/test_infer_type.py

    Function: test_it_type_str

    • Test 1

      📌 Setup phase

      duration:

      0.0006521008908748627
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002347058616578579
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00020026974380016327
      

      outcome:

      passed
      

    Function: test_it_type_float

    • Test 2

      📌 Setup phase

      duration:

      0.00012655695900321007
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001437310129404068
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001011076383292675
      

      outcome:

      passed
      

    Function: test_it_type_int

    • Test 3

      📌 Setup phase

      duration:

      0.00010797660797834396
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013532303273677826
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010092882439494133
      

      outcome:

      passed
      

    Function: test_it_value_str

    • Test 4

      📌 Setup phase

      duration:

      0.00011009117588400841
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001392788253724575
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.460700675845146e-05
      

      outcome:

      passed
      

    Function: test_it_value_long_str

    • Test 5

      📌 Setup phase

      duration:

      0.00010445434600114822
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001438581384718418
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.562401100993156e-05
      

      outcome:

      passed
      

    Function: test_it_value_float

    • Test 6

      📌 Setup phase

      duration:

      0.00010415865108370781
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015703309327363968
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.899400174617767e-05
      

      outcome:

      passed
      

    Function: test_it_value_int

    • Test 7

      📌 Setup phase

      duration:

      0.0001067272387444973
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014741113409399986
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.877607226371765e-05
      

      outcome:

      passed
      

    Function: test_it_empty_value_str

    • Test 8

      📌 Setup phase

      duration:

      0.000109856016933918
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014206068590283394
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010418565943837166
      

      outcome:

      passed
      

    Function: test_it_empty_value_float

    • Test 9

      📌 Setup phase

      duration:

      0.00010597566142678261
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013082195073366165
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.876396507024765e-05
      

      outcome:

      passed
      

    Function: test_it_empty_value_int

    • Test 10

      📌 Setup phase

      duration:

      0.00010563386604189873
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013159029185771942
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.272107854485512e-05
      

      outcome:

      passed
      

    Function: test_pstrue_str

    • Test 11

      📌 Setup phase

      duration:

      0.00010342709720134735
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001322389580309391
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.585870429873466e-05
      

      outcome:

      passed
      

    Function: test_pstrue_float

    • Test 12

      📌 Setup phase

      duration:

      0.00011340994387865067
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013528112322092056
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.278301149606705e-05
      

      outcome:

      passed
      

    Function: test_pstrue_int

    • Test 13

      📌 Setup phase

      duration:

      0.00010191323235630989
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001354571431875229
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.637279435992241e-05
      

      outcome:

      passed
      

    Function: test_psfalse_str

    • Test 14

      📌 Setup phase

      duration:

      0.00010543689131736755
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013994285836815834
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.234016761183739e-05
      

      outcome:

      passed
      

    Function: test_psfalse_float

    • Test 15

      📌 Setup phase

      duration:

      0.00010616285726428032
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001346520148217678
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.755697101354599e-05
      

      outcome:

      passed
      

    Function: test_psfalse_int

    • Test 16

      📌 Setup phase

      duration:

      0.00010385271161794662
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001302049495279789
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010018795728683472
      

      outcome:

      passed
      

    Function: test_it_None

    • Test 17

      📌 Setup phase

      duration:

      0.00010801665484905243
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015527568757534027
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.803799912333488e-05
      

      outcome:

      passed
      

    Function: test_it_True

    • Test 18

      📌 Setup phase

      duration:

      0.00010420521721243858
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013557681813836098
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.707501158118248e-05
      

      outcome:

      passed
      

    Function: test_it_False

    • Test 19

      📌 Setup phase

      duration:

      0.0001055961474776268
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002825278788805008
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011189188808202744
      

      outcome:

      passed
      

    Function: test_it_nan

    • Test 20

      📌 Setup phase

      duration:

      0.00011370517313480377
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000141264870762825
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.951693937182426e-05
      

      outcome:

      passed
      

    Function: test_it_np_nan

    • Test 21

      📌 Setup phase

      duration:

      0.00010701408609747887
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001328401267528534
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.420933201909065e-05
      

      outcome:

      passed
      

    Function: test_it_np1D_int

    • Test 22

      📌 Setup phase

      duration:

      0.00011046510189771652
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001859576441347599
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010522501543164253
      

      outcome:

      passed
      

    Function: test_it_np2D_int

    • Test 23

      📌 Setup phase

      duration:

      0.00011098803952336311
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001697721891105175
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.807664901018143e-05
      

      outcome:

      passed
      

    Function: test_it_np1D_float

    • Test 24

      📌 Setup phase

      duration:

      0.00012258579954504967
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002173949033021927
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010033976286649704
      

      outcome:

      passed
      

    Function: test_it_np2D_float

    • Test 25

      📌 Setup phase

      duration:

      0.00012489687651395798
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00020177289843559265
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.711598977446556e-05
      

      outcome:

      passed
      

    Function: test_it_np1D_bool

    • Test 26

      📌 Setup phase

      duration:

      0.00012204889208078384
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015858188271522522
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.743822738528252e-05
      

      outcome:

      passed
      

    Function: test_it_np1D_object

    • Test 27

      📌 Setup phase

      duration:

      0.00010462803766131401
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014811893925070763
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.484635666012764e-05
      

      outcome:

      passed
      

    Function: test_it_np_scalar_int

    • Test 28

      📌 Setup phase

      duration:

      0.00010911887511610985
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017263274639844894
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.676069021224976e-05
      

      outcome:

      passed
      

    Function: test_it_np_scalar_float

    • Test 29

      📌 Setup phase

      duration:

      0.000109079759567976
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017077382653951645
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.780982509255409e-05
      

      outcome:

      passed
      

    Function: test_it_np_scalar_bool

    • Test 30

      📌 Setup phase

      duration:

      0.00010896287858486176
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017941603437066078
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.720958769321442e-05
      

      outcome:

      passed
      

    Function: test_it_list

    • Test 31

      📌 Setup phase

      duration:

      0.00010303035378456116
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014253798872232437
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010060425847768784
      

      outcome:

      passed
      

    Function: test_it_tuple

    • Test 32

      📌 Setup phase

      duration:

      0.00010613212361931801
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001433766447007656
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010681105777621269
      

      outcome:

      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.0003720247186720371
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015785498544573784
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001574368216097355
      

      outcome:

      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.000289304181933403
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014249607920646667
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015171896666288376
      

      outcome:

      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.00027430010959506035
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014052120968699455
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015159789472818375
      

      outcome:

      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.00025700218975543976
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013724295422434807
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016378099098801613
      

      outcome:

      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.0002638953737914562
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013778218999505043
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017028022557497025
      

      outcome:

      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.0002636602148413658
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013695191591978073
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014845607802271843
      

      outcome:

      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.00027041463181376457
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015321513637900352
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015030987560749054
      

      outcome:

      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.00033399323001503944
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015199463814496994
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001544109545648098
      

      outcome:

      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.0002648099325597286
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013584084808826447
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001562577672302723
      

      outcome:

      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.000218953937292099
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015490269288420677
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001321369782090187
      

      outcome:

      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.00022264476865530014
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001577688381075859
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001466129906475544
      

      outcome:

      passed
      
    • Test 44
      params: pos=[], expected_names=[]

      📌 Runtime Parameters

      params:
        pos:
      []
        expected_names:
      []
      id: pos2-expected_names2
      

      📌 Setup phase

      duration:

      0.00020935013890266418
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013676797971129417
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014892686158418655
      

      outcome:

      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.00039619021117687225
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00019142497330904007
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015513692051172256
      

      outcome:

      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.0002717040479183197
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014573009684681892
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015134504064917564
      

      outcome:

      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.00028705084696412086
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014293193817138672
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001518833450973034
      

      outcome:

      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.0002526300959289074
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000180782750248909
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016547692939639091
      

      outcome:

      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.0002676257863640785
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017220107838511467
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015641609206795692
      

      outcome:

      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.00027221115306019783
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001739170402288437
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015166308730840683
      

      outcome:

      passed
      

    Function: test_get_args_parametrized

    • Test 51
      params: func=" at 0x7f99e1a315e0>", expected_pos=["a", "b"], expected_kw={"c": 3, "d": 4}

      📌 Runtime Parameters

      params:
        func: <function <lambda> at 0x7f99e1a315e0>
        expected_pos:
          - a
          - b
        expected_kw:
          c: 3
          d: 4
      id: <lambda>-expected_pos0-expected_kw0
      

      📌 Setup phase

      duration:

      0.00027293572202324867
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001894659362733364
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015335623174905777
      

      outcome:

      passed
      
    • Test 52
      params: func=" at 0x7f99e1a34550>", expected_pos=[], expected_kw="{'x': 1, 'y': , 'z': 0}"

      📌 Runtime Parameters

      params:
        func: <function <lambda> at 0x7f99e1a34550>
        expected_pos:
      []
        expected_kw: {'x': 1, 'y': <class 'inspect._empty'>, 'z': 0}
      id: <lambda>-expected_pos1-expected_kw1
      

      📌 Setup phase

      duration:

      0.0002881963737308979
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00018762890249490738
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001528528518974781
      

      outcome:

      passed
      
    • Test 53
      params: func=" at 0x7f99e1a34670>", expected_pos=[], expected_kw={}

      📌 Runtime Parameters

      params:
        func: <function <lambda> at 0x7f99e1a34670>
        expected_pos:
      []
        expected_kw:
      {}
      id: <lambda>-expected_pos2-expected_kw2
      

      📌 Setup phase

      duration:

      0.0002618790604174137
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00018105190247297287
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016988208517432213
      

      outcome:

      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 0x7f99e1a348b0>
        expected_sig: (a, b, d=30, c=10)
      id: wrap_all-(a, b, d=30, c=10)
      

      📌 Setup phase

      duration:

      0.0002259998582303524
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015782099217176437
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013809092342853546
      

      outcome:

      passed
      
    • Test 55
      params: func="", expected_sig="(a, b, c=10, d=20)"

      📌 Runtime Parameters

      params:
        func: <function wrap_skip at 0x7f99e1a34940>
        expected_sig: (a, b, c=10, d=20)
      id: wrap_skip-(a, b, c=10, d=20)
      

      📌 Setup phase

      duration:

      0.0002171304076910019
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015812506899237633
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013784179463982582
      

      outcome:

      passed
      
    • Test 56
      params: func="", expected_sig="(x, y, c=10, d=20)"

      📌 Runtime Parameters

      params:
        func: <function wrap_ignore_all at 0x7f99e1a349d0>
        expected_sig: (x, y, c=10, d=20)
      id: wrap_ignore_all-(x, y, c=10, d=20)
      

      📌 Setup phase

      duration:

      0.00022412417456507683
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001606023870408535
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001319199800491333
      

      outcome:

      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 0x7f99e1a348b0>
        args:
          - 1
          - 2
          - 3
        kwargs:
      {}
        expected_result: 36
      id: wrap_all-args0-kwargs0-36
      

      📌 Setup phase

      duration:

      0.000317293219268322
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013939989730715752
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016409298405051231
      

      outcome:

      passed
      
    • Test 58
      params: func="", args=[1, 2, 3], kwargs={"d": 5}, expected_result=11

      📌 Runtime Parameters

      params:
        func: <function wrap_all at 0x7f99e1a348b0>
        args:
          - 1
          - 2
          - 3
        kwargs:
          d: 5
        expected_result: 11
      id: wrap_all-args1-kwargs1-11
      

      📌 Setup phase

      duration:

      0.0003142263740301132
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014063110575079918
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001628650352358818
      

      outcome:

      passed
      
    • Test 59
      params: func="", args=[0, 0], kwargs={"c": 3, "d": 4}, expected_result=10

      📌 Runtime Parameters

      params:
        func: <function wrap_skip at 0x7f99e1a34940>
        args:
          - (vide)
          - (vide)
        kwargs:
          c: 3
          d: 4
        expected_result: 10
      id: wrap_skip-args2-kwargs2-10
      

      📌 Setup phase

      duration:

      0.0002975207753479481
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013517262414097786
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018536439165472984
      

      outcome:

      passed
      
    • Test 60
      params: func="", args=[0, 0], kwargs={}, expected_result=10

      📌 Runtime Parameters

      params:
        func: <function wrap_ignore_all at 0x7f99e1a349d0>
        args:
          - (vide)
          - (vide)
        kwargs:
      {}
        expected_result: 10
      id: wrap_ignore_all-args3-kwargs3-10
      

      📌 Setup phase

      duration:

      0.0003099110908806324
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001330748200416565
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016220472753047943
      

      outcome:

      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.00032298406586050987
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0010544122196733952
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019207270815968513
      

      outcome:

      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.0003415970131754875
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005327221006155014
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001871781423687935
      

      outcome:

      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.00031920382753014565
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005194819532334805
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019574491307139397
      

      outcome:

      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.00031603407114744186
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005861329846084118
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018631108105182648
      

      outcome:

      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.0003186790272593498
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005338750779628754
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001858733594417572
      

      outcome:

      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.0003244462423026562
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005236109718680382
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018787430599331856
      

      outcome:

      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.00032269302755594254
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005417186766862869
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018214434385299683
      

      outcome:

      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.00031505804508924484
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005912650376558304
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018368661403656006
      

      outcome:

      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.00032250024378299713
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0004823780618607998
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001841578632593155
      

      outcome:

      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.0003141593188047409
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005030888132750988
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018776580691337585
      

      outcome:

      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.0003172340802848339
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005900259129703045
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018359394744038582
      

      outcome:

      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.00033577531576156616
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0004859180189669132
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017770100384950638
      

      outcome:

      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.00031275488436222076
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0004949378781020641
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017648516222834587
      

      outcome:

      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.00032144831493496895
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005579069256782532
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001822933554649353
      

      outcome:

      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.00034207897260785103
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006011268123984337
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018123025074601173
      

      outcome:

      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.0003238031640648842
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0004908931441605091
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018678000196814537
      

      outcome:

      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.0003120242618024349
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005074408836662769
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017765909433364868
      

      outcome:

      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.00032712938264012337
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005125137977302074
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019110273569822311
      

      outcome:

      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.00032584182918071747
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006054211407899857
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019321264699101448
      

      outcome:

      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.0003180340863764286
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005311351269483566
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018029985949397087
      

      outcome:

      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.00031400518491864204
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000583430752158165
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018426962196826935
      

      outcome:

      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.0003327499143779278
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006365310400724411
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001853429712355137
      

      outcome:

      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.00033305585384368896
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005224980413913727
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019033486023545265
      

      outcome:

      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.0003148019313812256
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0004955241456627846
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018353108316659927
      

      outcome:

      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.0003139739856123924
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005117747932672501
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018563494086265564
      

      outcome:

      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.0003268499858677387
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005928259342908859
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001807468943297863
      

      outcome:

      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.00031332066282629967
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0004882761277258396
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017906585708260536
      

      outcome:

      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.0003170417621731758
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005068639293313026
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018773600459098816
      

      outcome:

      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.00032637035474181175
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005171326920390129
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018612714484333992
      

      outcome:

      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.00031182775273919106
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005940110422670841
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019680988043546677
      

      outcome:

      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.0003150179982185364
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0004958291538059711
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001831958070397377
      

      outcome:

      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.00032213423401117325
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000498700886964798
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017690472304821014
      

      outcome:

      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.0003146510571241379
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006426190957427025
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00020148605108261108
      

      outcome:

      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.00031128618866205215
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0004933401942253113
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018173782154917717
      

      outcome:

      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.00031473487615585327
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005398029461503029
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001849411055445671
      

      outcome:

      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.0003231111913919449
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005312771536409855
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00021428801119327545
      

      outcome:

      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.00036432407796382904
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006731012836098671
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00021363794803619385
      

      outcome:

      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.00040684081614017487
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006278529763221741
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.000241084024310112
      

      outcome:

      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.0004124613478779793
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005680299364030361
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002160542644560337
      

      outcome:

      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.0003565973602235317
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006692870520055294
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001996885985136032
      

      outcome:

      passed
      
  • 📄 test_utils_channels.py

    Function: test_load_channels_and_channels_class_with_professional_names

    • Test 101

      📌 Setup phase

      duration:

      0.00012350315228104591
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0009352168999612331
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001226537860929966
      

      outcome:

      passed
      
  • 📄 test_utils_config.py

    Function: test_config_with_nested_and_list_data

    • Test 102

      📌 Setup phase

      duration:

      0.00012355810031294823
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000546933151781559
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011680508032441139
      

      outcome:

      passed
      

    Function: test_config_with_strange_and_edge_keys

    • Test 103

      📌 Setup phase

      duration:

      0.00011228304356336594
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0007058619521558285
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012052571401000023
      

      outcome:

      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.00019504781812429428
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015743309631943703
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001792791299521923
      

      outcome:

      passed
      
    • Test 105
      params: base_color="blue"

      📌 Runtime Parameters

      params:
        base_color: blue
      id: blue
      

      📌 Setup phase

      duration:

      0.00017841486260294914
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015095993876457214
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012137461453676224
      

      outcome:

      passed
      
    • Test 106
      params: base_color="yellow"

      📌 Runtime Parameters

      params:
        base_color: yellow
      id: yellow
      

      📌 Setup phase

      duration:

      0.000168616883456707
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014542462304234505
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012582307681441307
      

      outcome:

      passed
      
    • Test 107
      params: base_color="green"

      📌 Runtime Parameters

      params:
        base_color: green
      id: green
      

      📌 Setup phase

      duration:

      0.00017205718904733658
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014527840539813042
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011888192966580391
      

      outcome:

      passed
      
    • Test 108
      params: base_color="cyan"

      📌 Runtime Parameters

      params:
        base_color: cyan
      id: cyan
      

      📌 Setup phase

      duration:

      0.00016938894987106323
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015524914488196373
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012231385335326195
      

      outcome:

      passed
      
    • Test 109
      params: base_color="magenta"

      📌 Runtime Parameters

      params:
        base_color: magenta
      id: magenta
      

      📌 Setup phase

      duration:

      0.00016949372366070747
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015148287639021873
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012317905202507973
      

      outcome:

      passed
      
    • Test 110
      params: base_color="white"

      📌 Runtime Parameters

      params:
        base_color: white
      id: white
      

      📌 Setup phase

      duration:

      0.0001806197687983513
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016275327652692795
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012078369036316872
      

      outcome:

      passed
      
    • Test 111
      params: base_color="black"

      📌 Runtime Parameters

      params:
        base_color: black
      id: black
      

      📌 Setup phase

      duration:

      0.00017629936337471008
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016044080257415771
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012392830103635788
      

      outcome:

      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.0006107301451265812
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00024174712598323822
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00025668321177363396
      

      outcome:

      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.00044724205508828163
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00023916363716125488
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00023940345272421837
      

      outcome:

      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.00045724213123321533
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00022128596901893616
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002481956034898758
      

      outcome:

      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.00046323612332344055
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002155662514269352
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002469699829816818
      

      outcome:

      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.0004491889849305153
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00021124305203557014
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00024104630574584007
      

      outcome:

      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.00046475185081362724
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002197069115936756
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002358788624405861
      

      outcome:

      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.0004562758840620518
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00024742214009165764
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0005610734224319458
      

      outcome:

      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.00047210510820150375
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00022688787430524826
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00025407690554857254
      

      outcome:

      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.00046035507693886757
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00020954804494976997
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002401689998805523
      

      outcome:

      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.0004504607059061527
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002205180935561657
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00023114588111639023
      

      outcome:

      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.0004620905965566635
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00020465487614274025
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00024328706786036491
      

      outcome:

      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.0004368661902844906
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002238210290670395
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002311193384230137
      

      outcome:

      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.00045904796570539474
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00022985227406024933
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002469690516591072
      

      outcome:

      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.00045486679300665855
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00022904109209775925
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002376912161707878
      

      outcome:

      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.00044598616659641266
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00021348195150494576
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00023834733292460442
      

      outcome:

      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.00043923500925302505
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002119871787726879
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002441410906612873
      

      outcome:

      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.00028009386733174324
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0008390028961002827
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017327489331364632
      

      outcome:

      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.0002817204222083092
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0008611739613115788
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016792304813861847
      

      outcome:

      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.0002856147475540638
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0007707192562520504
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017625698819756508
      

      outcome:

      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.00027726730331778526
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0008507706224918365
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017577409744262695
      

      outcome:

      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.0002925838343799114
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00075533427298069
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016918499022722244
      

      outcome:

      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.00029556499794125557
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014360295608639717
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015165703371167183
      

      outcome:

      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.0003333711065351963
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016290787607431412
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001610303297638893
      

      outcome:

      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.0002666567452251911
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016225827857851982
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001565706916153431
      

      outcome:

      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.00026236986741423607
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013688812032341957
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014812685549259186
      

      outcome:

      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.0002950136549770832
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001613488420844078
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001571299508213997
      

      outcome:

      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.0002825041301548481
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001408732496201992
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015977676957845688
      

      outcome:

      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.00026738597080111504
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013739988207817078
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016647903248667717
      

      outcome:

      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.00026555033400654793
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001405361108481884
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014891615137457848
      

      outcome:

      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.0002663019113242626
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014157593250274658
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015280628576874733
      

      outcome:

      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.0002611139789223671
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00018113898113369942
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015311501920223236
      

      outcome:

      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.00026416825130581856
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001609749160706997
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014661438763141632
      

      outcome:

      passed
      

    Function: test_attrdict_dir

    • Test 146
      params: data={"alpha": 1, "beta": 2}, expected_keys="{'beta', 'alpha'}"

      📌 Runtime Parameters

      params:
        data:
          alpha: 1
          beta: 2
        expected_keys: {'beta', 'alpha'}
      id: data0-expected_keys0
      

      📌 Setup phase

      duration:

      0.0002368181012570858
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014335708692669868
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013563083484768867
      

      outcome:

      passed
      
    • Test 147
      params: data={}, expected_keys="set()"

      📌 Runtime Parameters

      params:
        data:
      {}
        expected_keys: set()
      id: data1-expected_keys1
      

      📌 Setup phase

      duration:

      0.00021233083680272102
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016084779053926468
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013848301023244858
      

      outcome:

      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.0003050430677831173
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013832515105605125
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017397385090589523
      

      outcome:

      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.00030679814517498016
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017728889361023903
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016828672960400581
      

      outcome:

      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.0003004353493452072
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001567583531141281
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.000165608711540699
      

      outcome:

      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.0003182911314070225
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015584705397486687
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001726062037050724
      

      outcome:

      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.0003046155907213688
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001427270472049713
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018420210108160973
      

      outcome:

      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.0003093141131103039
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001401202753186226
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017168698832392693
      

      outcome:

      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.00030456623062491417
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001514139585196972
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016341684386134148
      

      outcome:

      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.0003158319741487503
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00024671293795108795
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001664087176322937
      

      outcome:

      passed
      
  • 📄 test_utils_dotdir.py

    Function: test_dotdir_creation_and_base_exists

    • Test 156

      📌 Setup phase

      duration:

      0.001326963771134615
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002470300532877445
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00021753599867224693
      

      outcome:

      passed
      

    Function: test_dotdir_repr_returns_path_str

    • Test 157

      📌 Setup phase

      duration:

      0.0005978019908070564
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002153250388801098
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002205967903137207
      

      outcome:

      passed
      

    Function: test_dotdir_call

    • Test 158

      📌 Setup phase

      duration:

      0.0006020441651344299
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002291337586939335
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00021074386313557625
      

      outcome:

      passed
      
  • 📄 test_utils_elog.py

    Function: test_check_required_attributes

    • Test 159

      📌 Setup phase

      duration:

      0.00012838095426559448
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0053120809607207775
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012397626414895058
      

      outcome:

      passed
      

    Function: test_get_default_elog_instance_with_direct_password_and_real_check

    • Test 161

      📌 Setup phase

      duration:

      0.00012829620391130447
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.007966516073793173
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012281769886612892
      

      outcome:

      passed
      

    Function: test_get_default_elog_instance_asks_password_and_opens

    • Test 162

      📌 Setup phase

      duration:

      0.00012547895312309265
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.008387070149183273
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012475810945034027
      

      outcome:

      passed
      

    Function: test_get_default_elog_with_path_home

    • Test 163

      📌 Setup phase

      duration:

      0.00011750496923923492
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.008877979125827551
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001242482103407383
      

      outcome:

      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.0002914527431130409
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017381971701979637
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014747632667422295
      

      outcome:

      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.0002225460484623909
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001650187186896801
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001360410824418068
      

      outcome:

      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.00022351276129484177
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015744799748063087
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013950979337096214
      

      outcome:

      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.0002253251150250435
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015952996909618378
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013697799295186996
      

      outcome:

      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.00022249016910791397
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014984607696533203
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014178501442074776
      

      outcome:

      passed
      
    • Test 170
      params: expr="-5", expected=-5

      📌 Runtime Parameters

      params:
        expr: -5
        expected: -5
      id: -5--5
      

      📌 Setup phase

      duration:

      0.0002328469417989254
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015188474208116531
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013569416478276253
      

      outcome:

      passed
      
    • Test 171
      params: expr="+7", expected=7

      📌 Runtime Parameters

      params:
        expr: +7
        expected: 7
      id: +7-7
      

      📌 Setup phase

      duration:

      0.00022503873333334923
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015566404908895493
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013654585927724838
      

      outcome:

      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.00021660001948475838
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001632911153137684
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014562997967004776
      

      outcome:

      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.0002068416215479374
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015851901844143867
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014026369899511337
      

      outcome:

      passed
      
    • Test 174
      params: expr="-(-3)", expected=3

      📌 Runtime Parameters

      params:
        expr: -(-3)
        expected: 3
      id: -(-3)-3
      

      📌 Setup phase

      duration:

      0.00021969107910990715
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015530874952673912
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014099106192588806
      

      outcome:

      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.0002147839404642582
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017545698210597038
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001358487643301487
      

      outcome:

      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.00020927609875798225
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016819266602396965
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013964716345071793
      

      outcome:

      passed
      
    • Test 177
      params: expr="(((3)))", expected=3

      📌 Runtime Parameters

      params:
        expr: (((3)))
        expected: 3
      id: (((3)))-3
      

      📌 Setup phase

      duration:

      0.00021638209000229836
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015548523515462875
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013215793296694756
      

      outcome:

      passed
      
    • Test 178
      params: expr="-(-(-2))", expected=-2

      📌 Runtime Parameters

      params:
        expr: -(-(-2))
        expected: -2
      id: -(-(-2))--2
      

      📌 Setup phase

      duration:

      0.000221913680434227
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016124872490763664
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013712700456380844
      

      outcome:

      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.00021937303245067596
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015281373634934425
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013404106721282005
      

      outcome:

      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.00023366697132587433
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015481095761060715
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013160938397049904
      

      outcome:

      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.0002152533270418644
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015165889635682106
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013363081961870193
      

      outcome:

      passed
      
    • Test 182
      params: expr="'string'", expected="string"

      📌 Runtime Parameters

      params:
        expr: 'string'
        expected: string
      id: 'string'-string
      

      📌 Setup phase

      duration:

      0.00020608492195606232
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014006998389959335
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013041915372014046
      

      outcome:

      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.00021792296320199966
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015289988368749619
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014482485130429268
      

      outcome:

      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.00020473217591643333
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014985818415880203
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014793220907449722
      

      outcome:

      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.00021568825468420982
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003667771816253662
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001498931087553501
      

      outcome:

      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.0002243397757411003
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00034570274874567986
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013716472312808037
      

      outcome:

      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.00022674119099974632
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00035374565050005913
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014837412163615227
      

      outcome:

      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.00022515002638101578
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003439499996602535
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013983296230435371
      

      outcome:

      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.00021162116900086403
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00033138133585453033
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001453673467040062
      

      outcome:

      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.00023884885013103485
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001775459386408329
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013721175491809845
      

      outcome:

      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.00021605519577860832
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00040582194924354553
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014325277879834175
      

      outcome:

      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.00022310996428132057
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003451691009104252
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013962667435407639
      

      outcome:

      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.00020955689251422882
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016865599900484085
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013825995847582817
      

      outcome:

      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.00022744480520486832
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016838498413562775
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001332429237663746
      

      outcome:

      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.0002292129211127758
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015596020966768265
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013644061982631683
      

      outcome:

      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.00021056365221738815
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015979120507836342
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.000135079026222229
      

      outcome:

      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.00021643098443746567
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001574382185935974
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013418495655059814
      

      outcome:

      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.00021199369803071022
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014877784997224808
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014011608436703682
      

      outcome:

      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.00026424089446663857
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015911273658275604
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015135714784264565
      

      outcome:

      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.0002471981570124626
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016331812366843224
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015585590153932571
      

      outcome:

      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.00026054587215185165
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015471596270799637
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015174457803368568
      

      outcome:

      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.0002693319693207741
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001546270214021206
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014681881293654442
      

      outcome:

      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 0x7f99e15ccd30>
        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.0002495627850294113
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015872064977884293
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013617891818284988
      

      outcome:

      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 0x7f99e15cce50>
        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.00021109683439135551
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001408671960234642
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015370920300483704
      

      outcome:

      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 0x7f99e15ccee0>
        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.0002194419503211975
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014393823221325874
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015521561726927757
      

      outcome:

      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 0x7f99e15ccf70>
        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.00021801190450787544
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014519412070512772
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013330206274986267
      

      outcome:

      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 0x7f99e1551040>
        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.00020894687622785568
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014525838196277618
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013617798686027527
      

      outcome:

      passed
      

    Function: test_printed_exception

    • Test 208
      params: func="", expected_output="KeyError: 'missing'"

      📌 Runtime Parameters

      params:
        func: <function cause_key_error at 0x7f99e15ccd30>
        expected_output: KeyError: 'missing'
      id: cause_key_error-KeyError: 'missing'
      

      📌 Setup phase

      duration:

      0.0006723459810018539
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0009009740315377712
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00042037665843963623
      

      outcome:

      passed
      
    • Test 209
      params: func="", expected_output="IndexError: list index out of range"

      📌 Runtime Parameters

      params:
        func: <function cause_index_error at 0x7f99e15cce50>
        expected_output: IndexError: list index out of range
      id: cause_index_error-IndexError: list index out of range
      

      📌 Setup phase

      duration:

      0.0005944329313933849
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0007301541045308113
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00042387424036860466
      

      outcome:

      passed
      
    • Test 210
      params: func="", expected_output="ZeroDivisionError: division by zero"

      📌 Runtime Parameters

      params:
        func: <function cause_zero_division at 0x7f99e15ccee0>
        expected_output: ZeroDivisionError: division by zero
      id: cause_zero_division-ZeroDivisionError: division by zero
      

      📌 Setup phase

      duration:

      0.0005510007031261921
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0007153190672397614
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0004047676920890808
      

      outcome:

      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 0x7f99e15ccf70>
        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.0005568596534430981
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0007548178546130657
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00044837407767772675
      

      outcome:

      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 0x7f99e1551040>
        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.000542942900210619
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0008011190220713615
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00040687108412384987
      

      outcome:

      passed
      
  • 📄 test_utils_get_adj.py

    Function: test_get_adj_success

    • Test 213

      📌 Setup phase

      duration:

      0.00012887688353657722
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000837214756757021
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011177314445376396
      

      outcome:

      passed
      

    Function: test_get_adj_not_found

    • Test 214

      📌 Setup phase

      duration:

      0.0004681050777435303
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000888484064489603
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00038049696013331413
      

      outcome:

      passed
      

    Function: test_ensure_adjs_mixed

    • Test 215

      📌 Setup phase

      duration:

      0.00012015784159302711
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0007675769738852978
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011765211820602417
      

      outcome:

      passed
      

    Function: test_get_adjs_filter

    • Test 216

      📌 Setup phase

      duration:

      0.00011280225589871407
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000827874056994915
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011444790288805962
      

      outcome:

      passed
      
  • 📄 test_utils_hastyepics.py

    Function: test_motor_invalid_name_raises

    • Test 219

      📌 Setup phase

      duration:

      0.00011952081695199013
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00025660591199994087
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010926090180873871
      

      outcome:

      passed
      

    Function: test_motor_init_list_has_no_disabled

    • Test 220

      📌 Setup phase

      duration:

      0.00011955294758081436
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015262421220541
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.967805817723274e-05
      

      outcome:

      passed
      

    Function: test_motor_pv_connection_skipped_by_default

    • Test 222

      📌 Setup phase

      duration:

      0.0001286230981349945
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003522750921547413
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010605296120047569
      

      outcome:

      passed
      

    Function: test_motor_adds_all_extras_pvs

    • Test 223

      📌 Setup phase

      duration:

      0.00010735122486948967
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000334668904542923
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011046603322029114
      

      outcome:

      passed
      

    Function: test_motor_PV_method_exists_and_works

    • Test 224

      📌 Setup phase

      duration:

      0.00010969676077365875
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000356883741915226
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011402415111660957
      

      outcome:

      passed
      
  • 📄 test_utils_ipy.py

    Function: test_devices_repr_fallback_and_ignore

    • Test 225

      📌 Setup phase

      duration:

      0.0007377867586910725
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0007547643035650253
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002501700073480606
      

      outcome:

      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.0008238540031015873
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006028031930327415
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019537704065442085
      

      outcome:

      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.0006194580346345901
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00040561938658356667
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001917998306453228
      

      outcome:

      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.0005957810208201408
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000426705926656723
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017068209126591682
      

      outcome:

      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.0006256718188524246
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00037992512807250023
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017220713198184967
      

      outcome:

      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.0006088889203965664
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003527742810547352
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018321722745895386
      

      outcome:

      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.0005983691662549973
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003721681423485279
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018471898511052132
      

      outcome:

      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.00062149902805686
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00048584165051579475
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.000175470020622015
      

      outcome:

      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.0006134593859314919
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005469378083944321
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001875152811408043
      

      outcome:

      passed
      
  • 📄 test_utils_lazypv.py

    Function: test_getattr

    • Test 234

      📌 Setup phase

      duration:

      0.00016370881348848343
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00026742368936538696
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010652700439095497
      

      outcome:

      passed
      
  • 📄 test_utils_logcfg.py

    Function: test_custom_log_outputs

    • Test 235
      params: levelname="LONG", logfunc=" at 0x7f99e153f820>", message="This is a LONG message"

      📌 Runtime Parameters

      params:
        levelname: LONG
        logfunc: <function <lambda> at 0x7f99e153f820>
        message: This is a LONG message
      id: LONG-<lambda>-This is a LONG message
      

      📌 Setup phase

      duration:

      0.0014295526780188084
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0007279710844159126
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00022743083536624908
      

      outcome:

      passed
      
    • Test 236
      params: levelname="ENLARGE", logfunc=" at 0x7f99e153f8b0>", message="Please ENLARGE this!"

      📌 Runtime Parameters

      params:
        levelname: ENLARGE
        logfunc: <function <lambda> at 0x7f99e153f8b0>
        message: Please ENLARGE this!
      id: ENLARGE-<lambda>-Please ENLARGE this!
      

      📌 Setup phase

      duration:

      0.0004031131975352764
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00040608737617731094
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00021664006635546684
      

      outcome:

      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.0005762390792369843
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0007887943647801876
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002553081139922142
      

      outcome:

      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.0003970297984778881
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0004420247860252857
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002486156299710274
      

      outcome:

      passed
      

    Function: test_ignore_only_by_level

    • Test 240

      📌 Setup phase

      duration:

      0.00023877806961536407
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00040101027116179466
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016521522775292397
      

      outcome:

      passed
      

    Function: test_ignore_only_by_msg

    • Test 241

      📌 Setup phase

      duration:

      0.0002523958683013916
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00037198513746261597
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016374699771404266
      

      outcome:

      passed
      

    Function: test_filter_removed_after_context

    • Test 242

      📌 Setup phase

      duration:

      0.000220439862459898
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003629741258919239
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018776720389723778
      

      outcome:

      passed
      
  • 📄 test_utils_metaclasses.py

    Function: test_combine_classes_combines_methods

    • Test 243

      📌 Setup phase

      duration:

      0.00012196134775876999
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00019362382590770721
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001055416651070118
      

      outcome:

      passed
      

    Function: test_registryabc_combines_registrymeta_and_abcmeta

    • Test 244

      📌 Setup phase

      duration:

      0.00011134706437587738
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.004997597075998783
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001225573942065239
      

      outcome:

      passed
      
  • 📄 test_utils_namespace.py

    Function: test_namespace_pretty_repr_mixed_and_nested

    • Test 245

      📌 Setup phase

      duration:

      0.00013122102245688438
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002860287204384804
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011932803317904472
      

      outcome:

      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.00034740008413791656
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.018791006412357092
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002452288754284382
      

      outcome:

      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.0003366610035300255
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00038528675213456154
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019034277647733688
      

      outcome:

      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.00034484779462218285
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00037649087607860565
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001889299601316452
      

      outcome:

      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.0003384556621313095
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00034424103796482086
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017959019169211388
      

      outcome:

      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.0003300076350569725
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00034625129774212837
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018175598233938217
      

      outcome:

      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.0003445991314947605
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003293990157544613
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019317306578159332
      

      outcome:

      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.00033185817301273346
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003495989367365837
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.000188551377505064
      

      outcome:

      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.0003340085968375206
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00033724401146173477
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019009318202733994
      

      outcome:

      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.0003427448682487011
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00033655669540166855
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019047316163778305
      

      outcome:

      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.0003786343149840832
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00035568326711654663
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002063489519059658
      

      outcome:

      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.00037675676867365837
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00034215766936540604
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00020037731155753136
      

      outcome:

      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.0004032077267765999
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003475896082818508
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.000197703018784523
      

      outcome:

      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.00039511220529675484
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003247261047363281
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002164277248084545
      

      outcome:

      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.0003796098753809929
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000338143203407526
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00020557688549160957
      

      outcome:

      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.0003874441608786583
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00032815011218190193
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00021080998703837395
      

      outcome:

      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.00036133406683802605
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016156164929270744
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001722271554172039
      

      outcome:

      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.00031209923326969147
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014432519674301147
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017521390691399574
      

      outcome:

      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.00030406098812818527
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013396795839071274
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001630987972021103
      

      outcome:

      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.00030314410105347633
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013859383761882782
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016378797590732574
      

      outcome:

      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.0002992739900946617
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013316329568624496
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016682595014572144
      

      outcome:

      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.000310518778860569
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00029559899121522903
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019446620717644691
      

      outcome:

      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.0003278059884905815
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002476191148161888
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017929496243596077
      

      outcome:

      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.0003369878977537155
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00023652566596865654
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017492985352873802
      

      outcome:

      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.0003213840536773205
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00022533629089593887
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017437618225812912
      

      outcome:

      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.00027189403772354126
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014535477384924889
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015021255239844322
      

      outcome:

      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.00026642903685569763
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014343392103910446
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015093619003891945
      

      outcome:

      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.0003057164140045643
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014374777674674988
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015159789472818375
      

      outcome:

      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.0002266247756779194
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015076110139489174
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015659118071198463
      

      outcome:

      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.00024310685694217682
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014863209798932076
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001411200501024723
      

      outcome:

      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.00022407062351703644
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015045097097754478
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014322390779852867
      

      outcome:

      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.0002179979346692562
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001447778195142746
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015138275921344757
      

      outcome:

      passed
      
    • Test 292
      params: val=[1, 2, 3], expected=[]

      📌 Runtime Parameters

      params:
        val:
          - 1
          - 2
          - 3
        expected:
      []
      id: val1-expected1
      

      📌 Setup phase

      duration:

      0.0002461373805999756
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013981293886899948
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014075962826609612
      

      outcome:

      passed
      
    • Test 293
      params: val=42, expected=[]

      📌 Runtime Parameters

      params:
        val: 42
        expected:
      []
      id: 42-expected2
      

      📌 Setup phase

      duration:

      0.00022759800776839256
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000135000329464674
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013477308675646782
      

      outcome:

      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.00021833041682839394
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013617193326354027
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015677837654948235
      

      outcome:

      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.00023067975416779518
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013732817023992538
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001402953639626503
      

      outcome:

      passed
      
    • Test 296
      params: val=42, expected=false

      📌 Runtime Parameters

      params:
        val: 42
        expected: False
      id: 42-False
      

      📌 Setup phase

      duration:

      0.00021868012845516205
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013394374400377274
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013636797666549683
      

      outcome:

      passed
      
  • 📄 test_utils_path.py

    Function: test_can_create_all_files_user_says_yes

    • Test 297

      📌 Setup phase

      duration:

      0.00012730387970805168
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005994844250380993
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011062296107411385
      

      outcome:

      passed
      

    Function: test_can_create_all_files_user_says_no

    • Test 298

      📌 Setup phase

      duration:

      0.00012292666360735893
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00038716383278369904
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011252937838435173
      

      outcome:

      passed
      

    Function: test_make_missing_dir_creates_folder

    • Test 299

      📌 Setup phase

      duration:

      0.00010981690138578415
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005360017530620098
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012077717110514641
      

      outcome:

      passed
      

    Function: test_glob_files_returns_matching_files_only

    • Test 300

      📌 Setup phase

      duration:

      0.00011735595762729645
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0009276960045099258
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012047123163938522
      

      outcome:

      passed
      

    Function: test_filter_files_excludes_directories

    • Test 301

      📌 Setup phase

      duration:

      0.000114459078758955
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0007638768292963505
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011695362627506256
      

      outcome:

      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.0005710143595933914
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003364342264831066
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016164081171154976
      

      outcome:

      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.0005722427740693092
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00030022114515304565
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016513001173734665
      

      outcome:

      passed
      
    • Test 304
      params: test_obj="simple string"

      📌 Runtime Parameters

      params:
        test_obj: simple string
      id: simple string
      

      📌 Setup phase

      duration:

      0.0005082688294351101
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00026591308414936066
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018113106489181519
      

      outcome:

      passed
      
    • Test 305
      params: test_obj=42

      📌 Runtime Parameters

      params:
        test_obj: 42
      id: 42
      

      📌 Setup phase

      duration:

      0.0005234158597886562
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00028629787266254425
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015435507521033287
      

      outcome:

      passed
      
    • Test 306
      params: test_obj=3.14159

      📌 Runtime Parameters

      params:
        test_obj: 3.14159
      id: 3.14159
      

      📌 Setup phase

      duration:

      0.0005241329781711102
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002849530428647995
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015415530651807785
      

      outcome:

      passed
      
    • Test 307
      params: test_obj=[true, false, null]

      📌 Runtime Parameters

      params:
        test_obj:
          - True
          - (vide)
          - (vide)
      id: test_obj5
      

      📌 Setup phase

      duration:

      0.0005779829807579517
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002777460031211376
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001686769537627697
      

      outcome:

      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.0005135079845786095
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002823583781719208
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001584598794579506
      

      outcome:

      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.000249713659286499
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014909682795405388
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013564294204115868
      

      outcome:

      passed
      
    • Test 310
      params: seq=[], expected=0

      📌 Runtime Parameters

      params:
        seq:
      []
        expected: 0
      id: seq1-0
      

      📌 Setup phase

      duration:

      0.0002251090481877327
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014294125139713287
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015069497749209404
      

      outcome:

      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.0002171131782233715
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014837412163615227
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013901200145483017
      

      outcome:

      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.00022507086396217346
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001548859290778637
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001389780081808567
      

      outcome:

      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.00020901812240481377
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001382441259920597
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014027440920472145
      

      outcome:

      passed
      
    • Test 314
      params: value="hello", expected=5

      📌 Runtime Parameters

      params:
        value: hello
        expected: 5
      id: hello-5
      

      📌 Setup phase

      duration:

      0.00023254891857504845
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001349765807390213
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013411417603492737
      

      outcome:

      passed
      
    • Test 315
      params: value=false, expected=5

      📌 Runtime Parameters

      params:
        value: False
        expected: 5
      id: False-5
      

      📌 Setup phase

      duration:

      0.00022800685837864876
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013233395293354988
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013863667845726013
      

      outcome:

      passed
      
    • Test 316
      params: value=null, expected=4

      📌 Runtime Parameters

      params:
        value: None
        expected: 4
      id: None-4
      

      📌 Setup phase

      duration:

      0.00021803099662065506
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013745902106165886
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013718707486987114
      

      outcome:

      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.0002183038741350174
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001326180063188076
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013980921357870102
      

      outcome:

      passed
      
    • Test 318
      params: value={"a": 1}, expected=8

      📌 Runtime Parameters

      params:
        value:
          a: 1
        expected: 8
      id: value5-8
      

      📌 Setup phase

      duration:

      0.00022317701950669289
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013583991676568985
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013495096936821938
      

      outcome:

      passed
      
    • Test 319
      params: value=[1, 2], expected=6

      📌 Runtime Parameters

      params:
        value:
          - 1
          - 2
        expected: 6
      id: value6-6
      

      📌 Setup phase

      duration:

      0.0002216910943388939
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013878662139177322
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014497525990009308
      

      outcome:

      passed
      
    • Test 320
      params: value="", expected=0

      📌 Runtime Parameters

      params:
        value: None
        expected: 0
      id: -0
      

      📌 Setup phase

      duration:

      0.00021452223882079124
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013259192928671837
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014381716027855873
      

      outcome:

      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.00022361194714903831
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013438519090414047
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00021957512944936752
      

      outcome:

      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.0002369261346757412
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016321707516908646
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001385929062962532
      

      outcome:

      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.00021302001550793648
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014126300811767578
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013918103650212288
      

      outcome:

      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.00023793382570147514
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016189785674214363
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001575150527060032
      

      outcome:

      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.00024980586022138596
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016516400501132011
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015350058674812317
      

      outcome:

      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.0002425643615424633
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015919189900159836
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014160992577672005
      

      outcome:

      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.00022431882098317146
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014889705926179886
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014527328312397003
      

      outcome:

      passed
      
    • Test 328

      📌 Runtime Parameters

      params:
        data:
          -       - a
            - b
          -       - c
            - d
        expected:
          -       - a
            - c
          -       - b
            - d
      id: data1-expected1
      

      📌 Setup phase

      duration:

      0.00023331539705395699
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001356806606054306
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013479217886924744
      

      outcome:

      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.00023088930174708366
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014779018238186836
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001396089792251587
      

      outcome:

      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.0002689352259039879
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014134403318166733
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015141628682613373
      

      outcome:

      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.0002612578682601452
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000132677610963583
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015605520457029343
      

      outcome:

      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.000269502867013216
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014097383245825768
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015500793233513832
      

      outcome:

      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.00026551075279712677
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013775890693068504
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014964723959565163
      

      outcome:

      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.0002557942643761635
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015195226296782494
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016549928113818169
      

      outcome:

      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.0002800123766064644
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014318712055683136
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014927703887224197
      

      outcome:

      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.00027999794110655785
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014496082440018654
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015926221385598183
      

      outcome:

      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.0002772328443825245
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014408212155103683
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00021555600687861443
      

      outcome:

      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.00026459479704499245
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014205370098352432
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001582740806043148
      

      outcome:

      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.00026019196957349777
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001506498083472252
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015535717830061913
      

      outcome:

      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.0002684439532458782
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014610029757022858
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014880625531077385
      

      outcome:

      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.0002724379301071167
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014753593131899834
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001531532034277916
      

      outcome:

      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.00026225997135043144
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014348095282912254
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014907727017998695
      

      outcome:

      passed
      
    • Test 343
      params: widths=[2, 3], line="=", expected="== ==="

      📌 Runtime Parameters

      params:
        widths:
          - 2
          - 3
        line: =
        expected: == ===
      id: widths1-=-== ===
      

      📌 Setup phase

      duration:

      0.00026284391060471535
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014004111289978027
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001596342772245407
      

      outcome:

      passed
      
    • Test 344
      params: widths=[5, 2], line="*", expected="***** **"

      📌 Runtime Parameters

      params:
        widths:
          - 5
          - 2
        line: *
        expected: ***** **
      id: widths2-*-***** **
      

      📌 Setup phase

      duration:

      0.0002490510232746601
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013499008491635323
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001554391346871853
      

      outcome:

      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.00034170690923929214
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002150312066078186
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015115411952137947
      

      outcome:

      passed
      

    Function: test_printable_dict_of_dicts

    • Test 346

      📌 Setup phase

      duration:

      0.00010829884558916092
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00022028619423508644
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.812274947762489e-05
      

      outcome:

      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.0002826680429279804
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003247261047363281
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001659691333770752
      

      outcome:

      passed
      
  • 📄 test_utils_rangebar.py

    Function: test_full_progress_bar

    • Test 356

      📌 Setup phase

      duration:

      0.00042742909863591194
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002385261468589306
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001834779977798462
      

      outcome:

      passed
      

    Function: test_half_progress_bar

    • Test 357

      📌 Setup phase

      duration:

      0.0002911989577114582
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00020831217989325523
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016339635476469994
      

      outcome:

      passed
      

    Function: test_zero_progress_bar

    • Test 358

      📌 Setup phase

      duration:

      0.00025787297636270523
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00020316289737820625
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016198912635445595
      

      outcome:

      passed
      

    Function: test_overflow_bar

    • Test 359

      📌 Setup phase

      duration:

      0.00027085375040769577
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00018758606165647507
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015938887372612953
      

      outcome:

      passed
      

    Function: test_underflow_bar

    • Test 360

      📌 Setup phase

      duration:

      0.00027473084628582
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017745792865753174
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015240395441651344
      

      outcome:

      passed
      

    Function: test_repr

    • Test 361

      📌 Setup phase

      duration:

      0.00011048279702663422
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014493614435195923
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.811064228415489e-05
      

      outcome:

      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.0003715669736266136
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00018926803022623062
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00020284904167056084
      

      outcome:

      passed
      
    • Test 363
      params: value=10, expected_bar_part="█ "

      📌 Runtime Parameters

      params:
        value: 10
        expected_bar_part:          
      id: 10-\u2588         
      

      📌 Setup phase

      duration:

      0.0003597191534936428
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00019107991829514503
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001948857679963112
      

      outcome:

      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.00037547899410128593
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001908070407807827
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019466597586870193
      

      outcome:

      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.00034517189487814903
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00019707810133695602
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001920820213854313
      

      outcome:

      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.0003815167583525181
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00019384268671274185
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019906600937247276
      

      outcome:

      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.0003569512628018856
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00020815012976527214
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00020295800641179085
      

      outcome:

      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.00038174213841557503
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00020242715254426003
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018928991630673409
      

      outcome:

      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.000355300959199667
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00019181380048394203
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019098492339253426
      

      outcome:

      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.0003681057132780552
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00019570998847484589
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019125919789075851
      

      outcome:

      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.0003539170138537884
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00019078608602285385
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00021682865917682648
      

      outcome:

      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.0003757784143090248
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002008075825870037
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00021792016923427582
      

      outcome:

      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.00023710587993264198
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017364369705319405
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001415703445672989
      

      outcome:

      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.00022690510377287865
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013767695054411888
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001412821002304554
      

      outcome:

      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.00023694569244980812
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014061527326703072
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015307078137993813
      

      outcome:

      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.00027442816644907
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001929430291056633
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001556798815727234
      

      outcome:

      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.0002353619784116745
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014810869470238686
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016167107969522476
      

      outcome:

      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.0002192133106291294
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014013191685080528
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001401081681251526
      

      outcome:

      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.00022336002439260483
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015890784561634064
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013458402827382088
      

      outcome:

      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.00021453620865941048
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013720383867621422
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019253836944699287
      

      outcome:

      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.00024713389575481415
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014223391190171242
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018480978906154633
      

      outcome:

      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.0002336651086807251
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001421780325472355
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014659808948636055
      

      outcome:

      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.00021608639508485794
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016655400395393372
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00022518914192914963
      

      outcome:

      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.0002149888314306736
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001477021723985672
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013967417180538177
      

      outcome:

      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.00022563990205526352
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013595307245850563
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001398618333041668
      

      outcome:

      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.00024943286553025246
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014244113117456436
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015218090265989304
      

      outcome:

      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.00023160502314567566
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014529097825288773
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013940175995230675
      

      outcome:

      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.0002184910699725151
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013677729293704033
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014897389337420464
      

      outcome:

      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.0003073848783969879
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001913970336318016
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014752987772226334
      

      outcome:

      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.0002192188985645771
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001580510288476944
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015877792611718178
      

      outcome:

      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.0002324921078979969
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014073122292757034
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014230702072381973
      

      outcome:

      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.00023715104907751083
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001408969983458519
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013218913227319717
      

      outcome:

      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.00020906561985611916
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013551907613873482
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014323508366942406
      

      outcome:

      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.00021877791732549667
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014413520693778992
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013206293806433678
      

      outcome:

      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.00022559380158782005
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014111492782831192
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014923186972737312
      

      outcome:

      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.0002085990272462368
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013766391202807426
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001618359237909317
      

      outcome:

      passed
      
  • 📄 test_utils_registry.py

    Function: test_metaclass_creates_weakset

    • Test 397

      📌 Setup phase

      duration:

      0.0001201932318508625
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000765796285122633
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.000119001604616642
      

      outcome:

      passed
      

    Function: test_metaclass_tracks_instances

    • Test 398

      📌 Setup phase

      duration:

      0.00011418480426073074
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002268776297569275
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001035020686686039
      

      outcome:

      passed
      

    Function: test_registry_inheritance

    • Test 399

      📌 Setup phase

      duration:

      0.00019182730466127396
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005330890417098999
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014218688011169434
      

      outcome:

      passed
      

    Function: test_instance_tracking

    • Test 400

      📌 Setup phase

      duration:

      0.00018467102199792862
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00020475778728723526
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012170709669589996
      

      outcome:

      passed
      

    Function: test_collect_instances_recursive

    • Test 401

      📌 Setup phase

      duration:

      0.00017503416165709496
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.001173247117549181
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001440560445189476
      

      outcome:

      passed
      

    Function: test_instances_function

    • Test 402

      📌 Setup phase

      duration:

      0.0001965118572115898
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0008420529775321484
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001411321572959423
      

      outcome:

      passed
      

    Function: test_non_registry_class_error

    • Test 403

      📌 Setup phase

      duration:

      0.00012030359357595444
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00020612217485904694
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010304665192961693
      

      outcome:

      passed
      

    Function: test_signature_preservation

    • Test 404

      📌 Setup phase

      duration:

      0.00010950304567813873
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00023793429136276245
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011337175965309143
      

      outcome:

      passed
      
  • 📄 test_utils_richcfg.py

    Function: test_rich_inspector_outputs_more_than_builtin

    • Test 405

      📌 Setup phase

      duration:

      0.00020649004727602005
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.09440679103136063
      

      outcome:

      passed
      

      log:

      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365067.675020848
        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: 1754517067.6750734
        msecs: 675.0733852386475
        relativeCreated: 9002.017498016357
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      

      📌 Teardown phase

      duration:

      0.0002283100038766861
      

      outcome:

      passed
      
  • 📄 test_utils_run_later.py

    Function: test_init_and_repr

    • Test 406

      📌 Setup phase

      duration:

      0.000142799224704504
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00022978801280260086
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011168699711561203
      

      outcome:

      passed
      

    Function: test_call

    • Test 407

      📌 Setup phase

      duration:

      0.00011347420513629913
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017411308363080025
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010059680789709091
      

      outcome:

      passed
      

    Function: test_matmul_with_string

    • Test 408

      📌 Setup phase

      duration:

      0.00011108722537755966
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016175396740436554
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.953416883945465e-05
      

      outcome:

      passed
      

    Function: test_matmul_with_list

    • Test 409

      📌 Setup phase

      duration:

      0.00010528974235057831
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014851009473204613
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.72328707575798e-05
      

      outcome:

      passed
      

    Function: test_matmul_with_single_int

    • Test 410

      📌 Setup phase

      duration:

      0.00011072400957345963
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016401102766394615
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.73469577729702e-05
      

      outcome:

      passed
      

    Function: test_run_at_future_triggered_and_logs

    • Test 411

      📌 Setup phase

      duration:

      0.0002967040054500103
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.20546611910685897
      

      outcome:

      passed
      

      log:

      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365067.775529671
        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.076451
        msecs: 76.45106315612793
        relativeCreated: -18784258596.604824
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365067.876122972
        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.177039
        msecs: 177.03890800476074
        relativeCreated: -18784258496.01698
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      

      📌 Teardown phase

      duration:

      0.00031279074028134346
      

      outcome:

      passed
      

    Function: test_run_at_already_past

    • Test 412

      📌 Setup phase

      duration:

      0.00033035408705472946
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00033556902781128883
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019118189811706543
      

      outcome:

      passed
      

    Function: test_run_in_future_triggered_and_logs

    • Test 413

      📌 Setup phase

      duration:

      0.00025125639513134956
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.20176073955371976
      

      outcome:

      passed
      

      log:

      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365067.976650410
        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.069099
        msecs: 69.09894943237305
        relativeCreated: -18784258603.95694
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365068.77206688
        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.1696384
        msecs: 169.63839530944824
        relativeCreated: -18784258503.417492
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      

      📌 Teardown phase

      duration:

      0.00030524516478180885
      

      outcome:

      passed
      

    Function: test_run_in_past

    • Test 414

      📌 Setup phase

      duration:

      0.0003115888684988022
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003554332070052624
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00019857287406921387
      

      outcome:

      passed
      

    Function: test_run_later_with_seconds

    • Test 415

      📌 Setup phase

      duration:

      0.0002468116581439972
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.20161214284598827
      

      outcome:

      passed
      

      log:

      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365068.177752081
        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.0652192
        msecs: 65.21916389465332
        relativeCreated: -18777058607.836723
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365068.278275435
        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.165723
        msecs: 165.72308540344238
        relativeCreated: -18777058507.3328
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      

      📌 Teardown phase

      duration:

      0.0002993573434650898
      

      outcome:

      passed
      

    Function: test_run_later_with_past_datetime

    • Test 416

      📌 Setup phase

      duration:

      0.0003074980340898037
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00032815104350447655
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017634406685829163
      

      outcome:

      passed
      

    Function: test_today_basic

    • Test 418

      📌 Setup phase

      duration:

      0.00013860594481229782
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006285067647695541
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012271897867321968
      

      outcome:

      passed
      

    Function: test_tomorrow_basic

    • Test 419

      📌 Setup phase

      duration:

      0.0001192968338727951
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003750980831682682
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012121489271521568
      

      outcome:

      passed
      

    Function: test_yesterday_basic

    • Test 420

      📌 Setup phase

      duration:

      0.00011669611558318138
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00034142518416047096
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010729162022471428
      

      outcome:

      passed
      

    Function: test_today_matmul_string

    • Test 421

      📌 Setup phase

      duration:

      0.00011299876496195793
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00034739216789603233
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011130515486001968
      

      outcome:

      passed
      

    Function: test_tomorrow_matmul_list

    • Test 422

      📌 Setup phase

      duration:

      0.00011388910934329033
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0003378288820385933
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010746391490101814
      

      outcome:

      passed
      

    Function: test_yesterday_matmul_single

    • Test 423

      📌 Setup phase

      duration:

      0.00010751700028777122
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00032943394035100937
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016521615907549858
      

      outcome:

      passed
      
  • 📄 test_utils_sendmail.py

    Function: test_sendmail_real_local_verbose

    • Test 424

      📌 Setup phase

      duration:

      0.00012377602979540825
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      1.6828721170313656
      

      outcome:

      passed
      

      log:

      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365068.579824375
        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: 1754517068.5800211
        msecs: 580.0211429595947
        relativeCreated: 9906.965255737305
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365068.680515355
        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: 1754517068.6806202
        msecs: 680.6201934814453
        relativeCreated: 10007.564306259155
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365068.781021783
        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: 1754517068.7811232
        msecs: 781.123161315918
        relativeCreated: 10108.067274093628
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365068.881512917
        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: 1754517068.8816187
        msecs: 881.6187381744385
        relativeCreated: 10208.562850952148
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365068.982160465
        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: 1754517068.9823794
        msecs: 982.3794364929199
        relativeCreated: 10309.32354927063
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365069.82964993
        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: 1754517069.0831728
        msecs: 83.17279815673828
        relativeCreated: 10410.116910934448
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365069.183710032
        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: 1754517069.183817
        msecs: 183.81690979003906
        relativeCreated: 10510.761022567749
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365069.284246615
        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: 1754517069.2843745
        msecs: 284.374475479126
        relativeCreated: 10611.318588256836
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365069.384834875
        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: 1754517069.3849487
        msecs: 384.94873046875
        relativeCreated: 10711.89284324646
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365069.485390329
        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: 1754517069.4854984
        msecs: 485.49842834472656
        relativeCreated: 10812.442541122437
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365069.585931220
        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: 1754517069.5860357
        msecs: 586.0357284545898
        relativeCreated: 10912.9798412323
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365069.686462796
        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: 1754517069.6865692
        msecs: 686.5692138671875
        relativeCreated: 11013.513326644897
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365069.786997693
        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: 1754517069.787097
        msecs: 787.0969772338867
        relativeCreated: 11114.041090011597
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365069.887522272
        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: 1754517069.8876293
        msecs: 887.6292705535889
        relativeCreated: 11214.573383331299
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365069.988092749
        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: 1754517069.9881992
        msecs: 988.1992340087891
        relativeCreated: 11315.143346786499
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365070.88647813
        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: 1754517070.0887654
        msecs: 88.76538276672363
        relativeCreated: 11415.709495544434
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365070.189210228
        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: 1754517070.1893187
        msecs: 189.31865692138672
        relativeCreated: 11516.262769699097
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      

      📌 Teardown phase

      duration:

      0.00027678022161126137
      

      outcome:

      passed
      
  • 📄 test_utils_shortcut.py

    Function: TestShortcutInitialization

    • Test 425

      📌 Setup phase

      duration:

      0.00041206832975149155
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00023788120597600937
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015397602692246437
      

      outcome:

      passed
      
    • Test 426

      📌 Setup phase

      duration:

      0.00020522065460681915
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015754718333482742
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015376275405287743
      

      outcome:

      passed
      

    Function: test_run_method

    • Test 427

      📌 Setup phase

      duration:

      0.0004064338281750679
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006636772304773331
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00023193517699837685
      

      outcome:

      passed
      

    Function: test_repr_output

    • Test 428

      📌 Setup phase

      duration:

      0.00019546691328287125
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017268676310777664
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013318099081516266
      

      outcome:

      passed
      

    Function: test_source_with_regular_function

    • Test 429

      📌 Setup phase

      duration:

      0.00018384307622909546
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006356262601912022
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014706281945109367
      

      outcome:

      passed
      

    Function: test_source_error_handling

    • Test 430

      📌 Setup phase

      duration:

      0.00018138624727725983
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0008851839229464531
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015684403479099274
      

      outcome:

      passed
      

    Function: test_as_shortcut_basic

    • Test 431

      📌 Setup phase

      duration:

      0.00019651325419545174
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017268117517232895
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002927440218627453
      

      outcome:

      passed
      

    Function: test_as_shortcut_with_name

    • Test 432

      📌 Setup phase

      duration:

      0.0002205902710556984
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015762494876980782
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013486994430422783
      

      outcome:

      passed
      

    Function: test_as_shortcut_factory_pattern

    • Test 433

      📌 Setup phase

      duration:

      0.0001744348555803299
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001462707296013832
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015763193368911743
      

      outcome:

      passed
      

    Function: TestShortcutsSingleton

    • Test 434

      📌 Setup phase

      duration:

      0.00028758542612195015
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016706576570868492
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018150173127651215
      

      outcome:

      passed
      
    • Test 435

      📌 Setup phase

      duration:

      0.000290771946310997
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00025106780230998993
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001498982310295105
      

      outcome:

      passed
      
    • Test 436

      📌 Setup phase

      duration:

      0.0002564690075814724
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00019675539806485176
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014753825962543488
      

      outcome:

      passed
      
    • Test 437

      📌 Setup phase

      duration:

      0.00025549810379743576
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00018642889335751534
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015716394409537315
      

      outcome:

      passed
      
    • Test 438

      📌 Setup phase

      duration:

      0.0002504168078303337
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0002506282180547714
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015030615031719208
      

      outcome:

      passed
      

    Function: TestFullIntegration

    • Test 439

      📌 Setup phase

      duration:

      0.0003913328982889652
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006762011907994747
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00024160603061318398
      

      outcome:

      passed
      
    • Test 440

      📌 Setup phase

      duration:

      0.00026432890444993973
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00021033594384789467
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.000153995119035244
      

      outcome:

      passed
      

    Function: test_registry_inheritance

    • Test 441

      📌 Setup phase

      duration:

      0.0001860661432147026
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000142762903124094
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001365160569548607
      

      outcome:

      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.00030236970633268356
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006321682594716549
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00023560691624879837
      

      outcome:

      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.0002849157899618149
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00048037804663181305
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018109194934368134
      

      outcome:

      passed
      
    • Test 444
      params: test_input=[], expected=[], kwargs={}

      📌 Runtime Parameters

      params:
        test_input:
      []
        expected:
      []
        kwargs:
      {}
      id: empty_case
      

      📌 Setup phase

      duration:

      0.0002760239876806736
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017665419727563858
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016344385221600533
      

      outcome:

      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.00028267502784729004
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005626659840345383
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018470780923962593
      

      outcome:

      passed
      
    • Test 446
      params: test_input="z3", "C"], ["a1", "A"], ["m2", "B", expected=["A", "B", "C"], kwargs="{'sort_key': at 0x7f99e17195e0>}"

      📌 Runtime Parameters

      params:
        test_input:
          -       - z3
            - C
          -       - a1
            - A
          -       - m2
            - B
        expected:
          - A
          - B
          - C
        kwargs: {'sort_key': <function <lambda> at 0x7f99e17195e0>}
      id: sort_id
      

      📌 Setup phase

      duration:

      0.00028718728572130203
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006607389077544212
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00018920795992016792
      

      outcome:

      passed
      
    • Test 447
      params: test_input="3", "Charlie"], ["1", "alpha"], ["2", "Beta", expected=["alpha", "Beta", "Charlie"], kwargs="{'sort_key': at 0x7f99e1719670>}"

      📌 Runtime Parameters

      params:
        test_input:
          -       - 3
            - Charlie
          -       - 1
            - alpha
          -       - 2
            - Beta
        expected:
          - alpha
          - Beta
          - Charlie
        kwargs: {'sort_key': <function <lambda> at 0x7f99e1719670>}
      id: sort_case_insensitive
      

      📌 Setup phase

      duration:

      0.0002807457931339741
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006684232503175735
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001845741644501686
      

      outcome:

      passed
      
    • Test 448
      params: test_input="1", "A"], ["2", "BB"], ["3", "CCC", expected=["A", "BB", "CCC"], kwargs="{'sort_key': at 0x7f99e1719700>}"

      📌 Runtime Parameters

      params:
        test_input:
          -       - 1
            - A
          -       - 2
            - BB
          -       - 3
            - CCC
        expected:
          - A
          - BB
          - CCC
        kwargs: {'sort_key': <function <lambda> at 0x7f99e1719700>}
      id: sort_length
      

      📌 Setup phase

      duration:

      0.00027401698753237724
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005558589473366737
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016955984756350517
      

      outcome:

      passed
      
    • Test 449
      params: test_input="1", "A"], ["2", "B"], ["3", "C", expected=["C", "B", "A"], kwargs="{'sort_key': at 0x7f99e1719790>}"

      📌 Runtime Parameters

      params:
        test_input:
          -       - 1
            - A
          -       - 2
            - B
          -       - 3
            - C
        expected:
          - C
          - B
          - A
        kwargs: {'sort_key': <function <lambda> at 0x7f99e1719790>}
      id: sort_reverse
      

      📌 Setup phase

      duration:

      0.00027908990159630775
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005637039430439472
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017047766596078873
      

      outcome:

      passed
      
  • 📄 test_utils_termtitle.py

    Function: test_terminal_title_with_tmux

    • Test 450

      📌 Setup phase

      duration:

      0.00014087697491049767
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.016267249826341867
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00020538130775094032
      

      outcome:

      passed
      
  • 📄 test_utils_tqdm_mod.py

    Function: test_complete_progress_bar

    • Test 451

      📌 Setup phase

      duration:

      0.00014986097812652588
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.004067001864314079
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012124702334403992
      

      outcome:

      passed
      

    Function: test_set_progress_multiple_points

    • Test 452

      📌 Setup phase

      duration:

      0.00012550503015518188
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0016989870928227901
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012687593698501587
      

      outcome:

      passed
      

    Function: test_format_sizeof_alignment

    • Test 453

      📌 Setup phase

      duration:

      0.00012903288006782532
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016294512897729874
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010457774624228477
      

      outcome:

      passed
      

    Function: test_custom_unit

    • Test 455

      📌 Setup phase

      duration:

      0.00013935472816228867
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.004839648958295584
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011422904208302498
      

      outcome:

      passed
      

    Function: test_clamp_above_total

    • Test 456

      📌 Setup phase

      duration:

      0.00011178804561495781
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00048605306074023247
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011201202869415283
      

      outcome:

      passed
      

    Function: test_clamp_below_zero

    • Test 457

      📌 Setup phase

      duration:

      0.0001117209903895855
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0006235111504793167
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00012188497930765152
      

      outcome:

      passed
      
  • 📄 test_utils_trinary.py

    Function: test_check_trinary_valid_values

    • Test 458

      📌 Setup phase

      duration:

      0.00013868696987628937
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001640808768570423
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010312022641301155
      

      outcome:

      passed
      

    Function: test_check_trinary_invalid_value

    • Test 459

      📌 Setup phase

      duration:

      0.00010871700942516327
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00036282511427998543
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011775176972150803
      

      outcome:

      passed
      

    Function: test_check_trinary_with_custom_allowed_values

    • Test 460

      📌 Setup phase

      duration:

      0.00010888231918215752
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016264012083411217
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001116911880671978
      

      outcome:

      passed
      
  • 📄 test_utils_typecast.py

    Function: test_downcast_success

    • Test 461

      📌 Setup phase

      duration:

      0.00012273900210857391
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000170018058270216
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001040501520037651
      

      outcome:

      passed
      

    Function: test_upcast_success

    • Test 462

      📌 Setup phase

      duration:

      0.00010602874681353569
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015335017815232277
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010107085108757019
      

      outcome:

      passed
      

    Function: test_downcast_invalid

    • Test 463

      📌 Setup phase

      duration:

      0.00010635703802108765
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00034246500581502914
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00011488283053040504
      

      outcome:

      passed
      

    Function: test_upcast_invalid

    • Test 464

      📌 Setup phase

      duration:

      0.00011224998161196709
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000172358937561512
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.999191388487816e-05
      

      outcome:

      passed
      

    Function: test_object_identity_preserved

    • Test 465

      📌 Setup phase

      duration:

      0.0001142239198088646
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014339899644255638
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010008411481976509
      

      outcome:

      passed
      

    Function: test_ensure_subclass_valid

    • Test 466

      📌 Setup phase

      duration:

      0.00011424534022808075
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001357230357825756
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.733578190207481e-05
      

      outcome:

      passed
      

    Function: test_ensure_subclass_invalid

    • Test 467

      📌 Setup phase

      duration:

      0.00011766375973820686
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001686164177954197
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0002117939293384552
      

      outcome:

      passed
      

    Function: test_cast_changes_class

    • Test 468

      📌 Setup phase

      duration:

      0.00011294614523649216
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014250772073864937
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010222522541880608
      

      outcome:

      passed
      

    Function: test_cast_preserves_identity

    • Test 469

      📌 Setup phase

      duration:

      0.00010817404836416245
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013243919238448143
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010185316205024719
      

      outcome:

      passed
      
  • 📄 test_utils_utils.py

    Function: test_singleton_instance

    • Test 470

      📌 Setup phase

      duration:

      0.00011320086196064949
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014324812218546867
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00010232068598270416
      

      outcome:

      passed
      

    Function: test_singleton_identity

    • Test 471

      📌 Setup phase

      duration:

      0.00010901922360062599
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001301751472055912
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      9.645894169807434e-05
      

      outcome:

      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.00029685162007808685
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015290314331650734
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015059998258948326
      

      outcome:

      passed
      
    • Test 473
      params: obj=true, expected="bool"

      📌 Runtime Parameters

      params:
        obj: True
        expected: bool
      id: True-bool
      

      📌 Setup phase

      duration:

      0.00022664712741971016
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013768300414085388
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001401742920279503
      

      outcome:

      passed
      
    • Test 474
      params: obj=42, expected="int"

      📌 Runtime Parameters

      params:
        obj: 42
        expected: int
      id: 42-int
      

      📌 Setup phase

      duration:

      0.00023855362087488174
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013377703726291656
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015077181160449982
      

      outcome:

      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.00023024296388030052
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013766391202807426
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013819430023431778
      

      outcome:

      passed
      
    • Test 476
      params: obj="text", expected="str"

      📌 Runtime Parameters

      params:
        obj: text
        expected: str
      id: text-str
      

      📌 Setup phase

      duration:

      0.0002179308794438839
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013777194544672966
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013949116691946983
      

      outcome:

      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.00022071925923228264
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014759087935090065
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001421901397407055
      

      outcome:

      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.00021982518956065178
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001351567916572094
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013603689149022102
      

      outcome:

      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.0002317214384675026
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013845227658748627
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014605000615119934
      

      outcome:

      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.00022736191749572754
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014047510921955109
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014964910224080086
      

      outcome:

      passed
      
    • Test 481
      params: obj=" at 0x7f99e172bee0>", expected="function"

      📌 Runtime Parameters

      params:
        obj: <function <lambda> at 0x7f99e172bee0>
        expected: function
      id: <lambda>-function
      

      📌 Setup phase

      duration:

      0.00031525595113635063
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00016015209257602692
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014759181067347527
      

      outcome:

      passed
      
    • Test 482
      params: obj="", expected="function"

      📌 Runtime Parameters

      params:
        obj: <function sample_function at 0x7f99e172be50>
        expected: function
      id: sample_function-function
      

      📌 Setup phase

      duration:

      0.0002311328426003456
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013661105185747147
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.000138778705149889
      

      outcome:

      passed
      
    • Test 483
      params: obj=".nested at 0x7f99e172bf70>", expected="function"

      📌 Runtime Parameters

      params:
        obj: <function sample_function.<locals>.nested at 0x7f99e172bf70>
        expected: function
      id: nested-function
      

      📌 Setup phase

      duration:

      0.00023392168805003166
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001368471421301365
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013857614248991013
      

      outcome:

      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.00023065321147441864
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014490308240056038
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001500193029642105
      

      outcome:

      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.0002240799367427826
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001367218792438507
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001424252986907959
      

      outcome:

      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.000228045042604208
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013874797150492668
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014269910752773285
      

      outcome:

      passed
      
    • Test 487
      params: obj="", expected="module"

      📌 Runtime Parameters

      params:
        obj: <module 'sys' (built-in)>
        expected: module
      id: sys-module
      

      📌 Setup phase

      duration:

      0.00024115806445479393
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001374189741909504
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013972213491797447
      

      outcome:

      passed
      
    • Test 488
      params: obj="", expected="type"

      📌 Runtime Parameters

      params:
        obj: <class 'function'>
        expected: type
      id: function-type
      

      📌 Setup phase

      duration:

      0.00021310383453965187
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013505620881915092
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015754206106066704
      

      outcome:

      passed
      
    • Test 489
      params: obj=" at 0x7f99e138ecf0>", expected="generator"

      📌 Runtime Parameters

      params:
        obj: <generator object <genexpr> at 0x7f99e138ecf0>
        expected: generator
      id: <genexpr>-generator
      

      📌 Setup phase

      duration:

      0.0002307589165866375
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00013903994113206863
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013840477913618088
      

      outcome:

      passed
      
    • Test 490
      params: obj="", expected="list_iterator"

      📌 Runtime Parameters

      params:
        obj: <list_iterator object at 0x7f99e147a610>
        expected: list_iterator
      id: obj18-list_iterator
      

      📌 Setup phase

      duration:

      0.0002273167483508587
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001472150906920433
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014111772179603577
      

      outcome:

      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.00023892009630799294
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014657899737358093
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001461310312151909
      

      outcome:

      passed
      
    • Test 492
      params: nums=[10, 20], expected=21

      📌 Runtime Parameters

      params:
        nums:
          - 10
          - 20
        expected: 21
      id: nums1-21
      

      📌 Setup phase

      duration:

      0.00022198818624019623
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014184974133968353
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014119688421487808
      

      outcome:

      passed
      
    • Test 493
      params: nums=[], expected=0

      📌 Runtime Parameters

      params:
        nums:
      []
        expected: 0
      id: nums2-0
      

      📌 Setup phase

      duration:

      0.00021964311599731445
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001338878646492958
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013812817633152008
      

      outcome:

      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.00028716493397951126
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015318486839532852
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015122070908546448
      

      outcome:

      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.0002725282683968544
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014029722660779953
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015129661187529564
      

      outcome:

      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.0002675331197679043
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014125602319836617
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016470765694975853
      

      outcome:

      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.0002229316160082817
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001378520391881466
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014117686077952385
      

      outcome:

      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.00022828299552202225
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001466860994696617
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013815099373459816
      

      outcome:

      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.00021638721227645874
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001459638588130474
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001400909386575222
      

      outcome:

      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.00023419177159667015
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001359269954264164
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014318525791168213
      

      outcome:

      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.00022087572142481804
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00018427567556500435
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00014351308345794678
      

      outcome:

      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.00022349786013364792
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00018650107085704803
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00015383213758468628
      

      outcome:

      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.00024378905072808266
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015702378004789352
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00013950886204838753
      

      outcome:

      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.0002889358438551426
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00017004972323775291
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016172602772712708
      

      outcome:

      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.0002640089951455593
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00021952809765934944
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00016931211575865746
      

      outcome:

      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.0002742977812886238
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0001439964398741722
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017252517864108086
      

      outcome:

      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.0002794340252876282
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00014166813343763351
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001631169579923153
      

      outcome:

      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.00027235783636569977
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00015516998246312141
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0001558363437652588
      

      outcome:

      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.0002744779922068119
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00019452907145023346
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.00017005903646349907
      

      outcome:

      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.00017516827210783958
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0004747179336845875
      

      outcome:

      passed
      

      📌 Teardown phase

      duration:

      0.0006746738217771053
      

      outcome:

      passed
      
Failed (33)
  • 📄 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.00026824092492461205
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0008483747951686382
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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.0002783779054880142
      

      outcome:

      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.0002770102582871914
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005493699572980404
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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.00020021060481667519
      

      outcome:

      passed
      
  • 📄 test_utils_elog.py

    Function: test_post

    • Test 160

      📌 Setup phase

      duration:

      0.0001169559545814991
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.008099527098238468
      

      outcome:

      failed
      

      crash:

      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 returned
      

      traceback:

      -   path: tests/test_utils_elog.py
        lineno: 114
        message: None
      -   path: slic/utils/elog.py
        lineno: 16
        message: in post
      -   path: .pixi/envs/default/lib/python3.8/site-packages/elog/logbook.py
        lineno: 315
        message: LogbookInvalidMessageID
      

      longrepr:

      def test_post():
              elog = get_test_elog()
      
              title = "AUTHOR_OVERRIDE_TEST"
              text = "This is a message"
              author = "robot"
      
      >       resp = elog.post(text, Author=author)
      
      tests/test_utils_elog.py:114: 
      _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
      slic/utils/elog.py:16: in post
          return self._log.post(*args, **kwargs)
      _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
      
      self = <elog.logbook.Logbook object at 0x7f99e13533d0>
      message = 'This is a message', msg_id = None, reply = False
      attributes = {'Author': 'robot', 'When': 1754517064, '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': 1754517064, '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.0001399167813360691
      

      outcome:

      passed
      

    Function: test_screenshot

    • Test 164

      📌 Setup phase

      duration:

      0.00012985197827219963
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.006580117624253035
      

      outcome:

      failed
      

      crash:

      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 returned
      

      traceback:

      -   path: tests/test_utils_elog.py
        lineno: 137
        message: None
      -   path: slic/utils/elog.py
        lineno: 21
        message: in screenshot
      -   path: slic/utils/elog.py
        lineno: 16
        message: in post
      -   path: .pixi/envs/default/lib/python3.8/site-packages/elog/logbook.py
        lineno: 315
        message: LogbookInvalidMessageID
      

      longrepr:

      mock_screenshot_class = <MagicMock name='Screenshot' id='140298884726896'>
      
          @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:137: 
      _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
      slic/utils/elog.py:21: in screenshot
          self.post(message, **kwargs)
      slic/utils/elog.py:16: in post
          return self._log.post(*args, **kwargs)
      _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
      
      self = <elog.logbook.Logbook object at 0x7f99e1338100>
      message = 'SCREENSHOT_INTEGRATION_TEST_MSG_456', msg_id = None, reply = False
      attributes = {'Author': 'robot', 'When': 1754517064, 'cmd': 'Submit', 'exp': 'demo', ...}
      attachments = ['/tmp/tmp035xy7l1.png'], suppress_email_notification = False
      encoding = None, timeout = None, kwargs = {'Author': 'robot'}
      new_attachment_list = [('attfile0', ('tmp035xy7l1.png', <_io.BufferedReader name='/tmp/tmp035xy7l1.png'>)), ('Text', ('', b'SCREENSHOT_INTEGRATION_TEST_MSG_456'))]
      objects_to_close = [<_io.BufferedReader name='/tmp/tmp035xy7l1.png'>]
      attributes_to_edit = {'Author': b'robot', 'When': 1754517064, '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.0001481780782341957
      

      outcome:

      passed
      
  • 📄 test_utils_hastyepics.py

    Function: test_motor_instantiation_fast_vs_epics

    • Test 217

      📌 Setup phase

      duration:

      0.0001204577274620533
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.09789439709857106
      

      outcome:

      failed
      

      crash:

      path: /workspace/tligui_y/slic/tests/test_utils_hastyepics.py
      lineno: 37
      message: AssertionError: Fast version (0.009350s) should be faster than EPICS (0.000258s)
      assert 0.009350149380043148 < 0.00025802417658269403
      

      traceback:

      -   path: tests/test_utils_hastyepics.py
        lineno: 37
        message: AssertionError
      

      longrepr:

      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.009350s) should be faster than EPICS (0.000258s)
      E       assert 0.009350149380043148 < 0.00025802417658269403
      
      tests/test_utils_hastyepics.py:37: AssertionError
      

      📌 Teardown phase

      duration:

      0.0004046456888318062
      

      outcome:

      passed
      

    Function: test_motor_without_suffix_and_dot

    • Test 218

      📌 Setup phase

      duration:

      0.00018503516912460327
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.001700086984783411
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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.0001441878266632557
      

      outcome:

      passed
      

    Function: test_motor_initializes_device_attrs

    • Test 221

      📌 Setup phase

      duration:

      0.00010945834219455719
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0013324720785021782
      

      outcome:

      failed
      

      crash:

      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.pv
      

      traceback:

      -   path: tests/test_utils_hastyepics.py
        lineno: 79
        message: AssertionError
      

      longrepr:

      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.00014835689216852188
      

      outcome:

      passed
      
  • 📄 test_utils_logcfg.py

    Function: test_import_logging_once_per_module

    • Test 237

      📌 Setup phase

      duration:

      0.00013955775648355484
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      1.6922898767516017
      

      outcome:

      failed
      

      crash:

      path: /workspace/tligui_y/slic/tests/test_utils_logcfg.py
      lineno: 78
      message: AssertionError: Expected 1 import log for 'math', found 0
      assert 0 == 1
      

      traceback:

      -   path: tests/test_utils_logcfg.py
        lineno: 78
        message: AssertionError
      

      longrepr:

      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.000347859226167202
      

      outcome:

      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.0003656921908259392
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0010091629810631275
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f998df739d0>, 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.0002092961221933365
      

      outcome:

      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.00033481325954198837
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005381489172577858
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f998defa9d0>, 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.0002206983044743538
      

      outcome:

      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.000349205918610096
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0008298358879983425
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f998df15280>, 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.0002301819622516632
      

      outcome:

      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.00037751393392682076
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0004783477634191513
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f998cdfa550>, 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.00021987594664096832
      

      outcome:

      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.00038261618465185165
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0004543052054941654
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f998df15310>, 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.00022225314751267433
      

      outcome:

      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.0003745071589946747
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005044848658144474
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f998cdfaee0>, 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.0002442197874188423
      

      outcome:

      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.00036981282755732536
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00047501223161816597
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f998cdfaa60>, 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.0002298210747539997
      

      outcome:

      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.00037884199991822243
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00045872991904616356
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f998cde1550>, 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.00030204420909285545
      

      outcome:

      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.00042076921090483665
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005597132258117199
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f998e357790>, 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.00025319308042526245
      

      outcome:

      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.0004091248847544193
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.000502465758472681
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f998cde1a60>, 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.0002629803493618965
      

      outcome:

      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.0003964756615459919
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0008328133262693882
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f99e1753dc0>, 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.0002517686225473881
      

      outcome:

      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.00039488309994339943
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0008019478991627693
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f99e1375b80>, 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.0002350551076233387
      

      outcome:

      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.000383967999368906
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005118176341056824
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f998df64dc0>, 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.00024013640359044075
      

      outcome:

      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.0004008370451629162
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.00048361625522375107
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f998cde1af0>, 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.00026066508144140244
      

      outcome:

      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.00038198381662368774
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0005102450959384441
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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 0x7f998cdfa940>, 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.0002522338181734085
      

      outcome:

      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: 
      id: 0.0-          -\x1b[32m
      

      📌 Setup phase

      duration:

      1.0021045031026006
      

      outcome:

      passed
      

      log:

      -   name: pcaspy.Driver.setParam
        msg: START_TIME: value=2025-08-06 21:51:06.462159 alarm=NO_ALARM severity=NO_ALARM flag=True mask=7 time=1123365066.462188735
        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: 1754517066.4622679
        msecs: 462.2678756713867
        relativeCreated: 7789.211988449097
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=4 time=1123365066.462813828
        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: 1754517066.462839
        msecs: 462.83888816833496
        relativeCreated: 7789.783000946045
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365066.563217366
        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: 1754517066.5632744
        msecs: 563.2743835449219
        relativeCreated: 7890.218496322632
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365066.663791476
        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: 1754517066.663843
        msecs: 663.8429164886475
        relativeCreated: 7990.787029266357
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365066.764293365
        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: 1754517066.7643557
        msecs: 764.3556594848633
        relativeCreated: 8091.299772262573
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365066.864825768
        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: 1754517066.8648834
        msecs: 864.8834228515625
        relativeCreated: 8191.8275356292725
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365066.965316262
        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: 1754517066.9653716
        msecs: 965.3716087341309
        relativeCreated: 8292.31572151184
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365067.65813724
        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: 1754517067.0658646
        msecs: 65.86456298828125
        relativeCreated: 8392.808675765991
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365067.166283902
        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: 1754517067.166338
        msecs: 166.3379669189453
        relativeCreated: 8493.282079696655
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365067.266800364
        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: 1754517067.2668552
        msecs: 266.85523986816406
        relativeCreated: 8593.799352645874
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365067.367300428
        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: 1754517067.3673604
        msecs: 367.36035346984863
        relativeCreated: 8694.304466247559
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      

      📌 Call phase

      duration:

      0.017569529358297586
      

      outcome:

      failed
      

      crash:

      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 |██████████████████████████████| 0 ]   0
      
      assert []
      

      traceback:

      -   path: tests/test_utils_pv.py
        lineno: 81
        message: AssertionError
      

      log:

      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365067.467806371
        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: 1754517067.4678707
        msecs: 467.87071228027344
        relativeCreated: 8794.814825057983
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   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: 1754517067.4748237
        msecs: 474.8237133026123
        relativeCreated: 8801.767826080322
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 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: 1754517067.4752746
        msecs: 475.27456283569336
        relativeCreated: 8802.218675613403
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365067.475367837
        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: 1754517067.475387
        msecs: 475.3870964050293
        relativeCreated: 8802.33120918274
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   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: 1754517067.4769092
        msecs: 476.9091606140137
        relativeCreated: 8803.853273391724
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 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: 1754517067.477382
        msecs: 477.38194465637207
        relativeCreated: 8804.326057434082
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365067.477442007
        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: 1754517067.477455
        msecs: 477.45490074157715
        relativeCreated: 8804.399013519287
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      

      longrepr:

      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 |██████████████████████████████| 0 ]   0
      E         
      E       assert []
      
      tests/test_utils_pv.py:81: AssertionError
      

      📌 Teardown phase

      duration:

      0.000266531016677618
      

      outcome:

      passed
      
    • Test 349
      params: value=25.0, expected_bar="██▌ ", expected_color="\u001b[32m"

      📌 Runtime Parameters

      params:
        value: 25.0
        expected_bar: ██▌       
        expected_color: 
      id: 25.0-\u2588\u2588\u258c       -\x1b[32m
      

      📌 Setup phase

      duration:

      0.0003905799239873886
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0025472589768469334
      

      outcome:

      failed
      

      crash:

      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 |                              | 25 ]   0
        [DEBUG] Callback called with value = 25.0
        [ 0 |██████████████████████████████| 25 ]   25
      
      assert []
      

      traceback:

      -   path: tests/test_utils_pv.py
        lineno: 81
        message: AssertionError
      

      log:

      -   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: 1754517067.4846075
        msecs: 484.607458114624
        relativeCreated: 8811.551570892334
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 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: 1754517067.4849238
        msecs: 484.9238395690918
        relativeCreated: 8811.867952346802
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365067.485002352
        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: 1754517067.4850168
        msecs: 485.0168228149414
        relativeCreated: 8811.960935592651
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   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: 1754517067.485606
        msecs: 485.60595512390137
        relativeCreated: 8812.550067901611
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 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: 1754517067.4859352
        msecs: 485.9352111816406
        relativeCreated: 8812.87932395935
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=25.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123365067.485995531
        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: 1754517067.4860082
        msecs: 486.0081672668457
        relativeCreated: 8812.952280044556
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      

      longrepr:

      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 |                              | 25 ]   0
      E         [DEBUG] Callback called with value = 25.0
      E         [ 0 |██████████████████████████████| 25 ]   25
      E         
      E       assert []
      
      tests/test_utils_pv.py:81: AssertionError
      

      📌 Teardown phase

      duration:

      0.00021901214495301247
      

      outcome:

      passed
      
    • Test 350
      params: value=50.0, expected_bar="█████ ", expected_color="\u001b[32m"

      📌 Runtime Parameters

      params:
        value: 50.0
        expected_bar: █████     
        expected_color: 
      id: 50.0-\u2588\u2588\u2588\u2588\u2588     -\x1b[32m
      

      📌 Setup phase

      duration:

      0.00033805472776293755
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0021198210306465626
      

      outcome:

      failed
      

      crash:

      path: /workspace/tligui_y/slic/tests/test_utils_pv.py
      lineno: 62
      message: assert 25.0 == 0.0 ± 1.0e-12
      
        comparison failed
        Obtained: 25.0
        Expected: 0.0 ± 1.0e-12
      

      traceback:

      -   path: tests/test_utils_pv.py
        lineno: 62
        message: AssertionError
      

      log:

      -   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: 1754517067.4926164
        msecs: 492.6164150238037
        relativeCreated: 8819.560527801514
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 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: 1754517067.4930067
        msecs: 493.00670623779297
        relativeCreated: 8819.950819015503
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123365067.493067624
        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: 1754517067.4930813
        msecs: 493.08133125305176
        relativeCreated: 8820.025444030762
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   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: 1754517067.4938996
        msecs: 493.8995838165283
        relativeCreated: 8820.843696594238
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      

      longrepr:

      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)
      E       assert 25.0 == 0.0 ± 1.0e-12
      E         
      E         comparison failed
      E         Obtained: 25.0
      E         Expected: 0.0 ± 1.0e-12
      
      tests/test_utils_pv.py:62: AssertionError
      

      📌 Teardown phase

      duration:

      0.00021135015413165092
      

      outcome:

      passed
      
    • Test 351
      params: value=75.0, expected_bar="███████▌ ", expected_color="\u001b[32m"

      📌 Runtime Parameters

      params:
        value: 75.0
        expected_bar: ███████▌  
        expected_color: 
      id: 75.0-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u258c  -\x1b[32m
      

      📌 Setup phase

      duration:

      0.0003164517693221569
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.002206284087151289
      

      outcome:

      failed
      

      crash:

      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 = 75.0
        [ 0 |                              | 75 ]   0
        [DEBUG] Callback called with value = 75.0
        [ 0 |██████████████████████████████| 75 ]   75
      
      assert []
      

      traceback:

      -   path: tests/test_utils_pv.py
        lineno: 81
        message: AssertionError
      

      log:

      -   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: 1754517067.4996915
        msecs: 499.6914863586426
        relativeCreated: 8826.635599136353
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 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: 1754517067.499986
        msecs: 499.985933303833
        relativeCreated: 8826.930046081543
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365067.500055322
        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: 1754517067.500107
        msecs: 500.1070499420166
        relativeCreated: 8827.051162719727
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   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: 1754517067.500512
        msecs: 500.51188468933105
        relativeCreated: 8827.455997467041
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 root  old=0.0 new=75.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: 1754517067.500766
        msecs: 500.7660388946533
        relativeCreated: 8827.710151672363
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=75.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123365067.500820053
        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: 1754517067.500832
        msecs: 500.83208084106445
        relativeCreated: 8827.776193618774
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      

      longrepr:

      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)
      
              # 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 = 75.0
      E         [ 0 |                              | 75 ]   0
      E         [DEBUG] Callback called with value = 75.0
      E         [ 0 |██████████████████████████████| 75 ]   75
      E         
      E       assert []
      
      tests/test_utils_pv.py:81: AssertionError
      

      📌 Teardown phase

      duration:

      0.00020564906299114227
      

      outcome:

      passed
      
    • Test 352
      params: value=100.0, expected_bar="██████████", expected_color="\u001b[32m"

      📌 Runtime Parameters

      params:
        value: 100.0
        expected_bar: ██████████
        expected_color: 
      id: 100.0-\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588-\x1b[32m
      

      📌 Setup phase

      duration:

      0.0003221025690436363
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0023551960475742817
      

      outcome:

      failed
      

      crash:

      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 |                              | 100 ]   0
        [DEBUG] Callback called with value = 100.0
        [ 0 |██████████████████████████████| 100 ]   100
      
      assert []
      

      traceback:

      -   path: tests/test_utils_pv.py
        lineno: 81
        message: AssertionError
      

      log:

      -   name: pcaspy.SimplePV.getValue
        msg: VAL: Read value 75.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: 1754517067.507325
        msecs: 507.3249340057373
        relativeCreated: 8834.269046783447
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 root  old=75.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: 1754517067.5076678
        msecs: 507.66777992248535
        relativeCreated: 8834.611892700195
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123365067.507743943
        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: 1754517067.5077565
        msecs: 507.75647163391113
        relativeCreated: 8834.700584411621
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   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: 1754517067.5083256
        msecs: 508.32557678222656
        relativeCreated: 8835.269689559937
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 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: 1754517067.5085807
        msecs: 508.58068466186523
        relativeCreated: 8835.524797439575
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=100.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123365067.508634856
        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: 1754517067.5086455
        msecs: 508.64553451538086
        relativeCreated: 8835.58964729309
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      

      longrepr:

      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 |                              | 100 ]   0
      E         [DEBUG] Callback called with value = 100.0
      E         [ 0 |██████████████████████████████| 100 ]   100
      E         
      E       assert []
      
      tests/test_utils_pv.py:81: AssertionError
      

      📌 Teardown phase

      duration:

      0.0002125031314790249
      

      outcome:

      passed
      
    • Test 353
      params: value=150.0, expected_bar=">>>>>>>>>>", expected_color="\u001b[31m"

      📌 Runtime Parameters

      params:
        value: 150.0
        expected_bar: >>>>>>>>>>
        expected_color: 
      id: 150.0->>>>>>>>>>-\x1b[31m
      

      📌 Setup phase

      duration:

      0.00031398097053170204
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0025028041563928127
      

      outcome:

      failed
      

      crash:

      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 = 150.0
        [ 0 |                              | 150 ]   0
        [DEBUG] Callback called with value = 150.0
        [ 0 |██████████████████████████████| 150 ]   150
      
      assert []
      

      traceback:

      -   path: tests/test_utils_pv.py
        lineno: 81
        message: AssertionError
      

      log:

      -   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: 1754517067.5149915
        msecs: 514.9915218353271
        relativeCreated: 8841.935634613037
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 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: 1754517067.5152643
        msecs: 515.2642726898193
        relativeCreated: 8842.20838546753
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123365067.515321778
        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: 1754517067.5153337
        msecs: 515.3336524963379
        relativeCreated: 8842.277765274048
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   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: 1754517067.516021
        msecs: 516.0210132598877
        relativeCreated: 8842.965126037598
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 root  old=0.0 new=150.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: 1754517067.5162907
        msecs: 516.2906646728516
        relativeCreated: 8843.234777450562
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=150.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123365067.516346858
        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: 1754517067.5163589
        msecs: 516.3588523864746
        relativeCreated: 8843.302965164185
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      

      longrepr:

      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)
      
              # 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 = 150.0
      E         [ 0 |                              | 150 ]   0
      E         [DEBUG] Callback called with value = 150.0
      E         [ 0 |██████████████████████████████| 150 ]   150
      E         
      E       assert []
      
      tests/test_utils_pv.py:81: AssertionError
      

      📌 Teardown phase

      duration:

      0.00020554475486278534
      

      outcome:

      passed
      
    • Test 354
      params: value=-50.0, expected_bar="<<<<<<<<<<", expected_color="\u001b[31m"

      📌 Runtime Parameters

      params:
        value: -50.0
        expected_bar: <<<<<<<<<<
        expected_color: 
      id: -50.0-<<<<<<<<<<-\x1b[31m
      

      📌 Setup phase

      duration:

      0.00030178995802998543
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.002495944034308195
      

      outcome:

      failed
      

      crash:

      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 |                              | -50 ]   0
        [DEBUG] Callback called with value = -50.0
        [ 0 |██████████████████████████████| -50 ]   -50
      
      assert []
      

      traceback:

      -   path: tests/test_utils_pv.py
        lineno: 81
        message: AssertionError
      

      log:

      -   name: pcaspy.SimplePV.getValue
        msg: VAL: Read value 150.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: 1754517067.5227077
        msecs: 522.7077007293701
        relativeCreated: 8849.65181350708
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 root  old=150.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: 1754517067.523049
        msecs: 523.0491161346436
        relativeCreated: 8849.993228912354
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123365067.523122227
        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: 1754517067.5231354
        msecs: 523.1354236602783
        relativeCreated: 8850.079536437988
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   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: 1754517067.5237656
        msecs: 523.7655639648438
        relativeCreated: 8850.709676742554
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 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: 1754517067.5240169
        msecs: 524.0168571472168
        relativeCreated: 8850.960969924927
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=-50.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123365067.524082964
        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: 1754517067.5240967
        msecs: 524.0967273712158
        relativeCreated: 8851.040840148926
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      

      longrepr:

      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 |                              | -50 ]   0
      E         [DEBUG] Callback called with value = -50.0
      E         [ 0 |██████████████████████████████| -50 ]   -50
      E         
      E       assert []
      
      tests/test_utils_pv.py:81: AssertionError
      

      📌 Teardown phase

      duration:

      0.00020251795649528503
      

      outcome:

      passed
      

    Function: test_use_callback_context_manager

    • Test 355

      📌 Setup phase

      duration:

      0.00014590099453926086
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.0013435939326882362
      

      outcome:

      failed
      

      crash:

      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: AttributeError
      

      log:

      -   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: 1754517067.5304258
        msecs: 530.4257869720459
        relativeCreated: 8857.369899749756
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.SimplePV.writeValue
        msg: VAL: 5d78f845f820 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: 1754517067.5307498
        msecs: 530.7497978210449
        relativeCreated: 8857.693910598755
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=True mask=3 time=1123365067.530805449
        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: 1754517067.5308177
        msecs: 530.8177471160889
        relativeCreated: 8857.761859893799
        thread: 140297451218624
        threadName: Thread-4
        processName: MainProcess
        process: 2324
      

      longrepr:

      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.00020042387768626213
      

      outcome:

      passed
      
  • 📄 test_utils_run_later.py

    Function: test_run_at_tqdm_multiple_updates

    • Test 417

      📌 Setup phase

      duration:

      0.00030464399605989456
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.20231676008552313
      

      outcome:

      failed
      

      crash:

      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-06 21:51:08.317451\nwill run at        2025-08-06 21:51:08.517429\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
      

      traceback:

      -   path: tests/test_utils_run_later.py
        lineno: 128
        message: AssertionError
      

      log:

      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365068.378777608
        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: 1754517068.3788748
        msecs: 378.8747787475586
        relativeCreated: 9705.818891525269
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      -   name: pcaspy.Driver.setParam
        msg: VAL: value=0.0 alarm=NO_ALARM severity=NO_ALARM flag=False mask=0 time=1123365068.479279887
        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: 1754517068.4793637
        msecs: 479.36367988586426
        relativeCreated: 9806.307792663574
        thread: 140297442825920
        threadName: Thread-3
        processName: MainProcess
        process: 2324
      

      longrepr:

      monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7f998ceadbe0>
      capsys = <_pytest.capture.CaptureFixture object at 0x7f998ceadb80>
      
          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-06 21:51:08.317451\nwill run at        2025-08-06 21:51:08.517429\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.000325620174407959
      

      outcome:

      passed
      
  • 📄 test_utils_tqdm_mod.py

    Function: test_float_alignment_in_bar

    • Test 454

      📌 Setup phase

      duration:

      0.00011027604341506958
      

      outcome:

      passed
      

      📌 Call phase

      duration:

      0.001489606685936451
      

      outcome:

      failed
      

      crash:

      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: AssertionError
      

      longrepr:

      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.0001487182453274727
      

      outcome:

      passed
      

📚 Collected files

(1 tests)
    • Outcome: passed
    • result:
    -   nodeid: .
      type: Dir
    
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
      
    • ci-reports/allure/data
      • Outcome: passed
      • result:
      -   nodeid: ci-reports/allure/data/test-cases
        type: Dir
      
    • ci-reports/allure/data/test-cases
      • Outcome: passed
      • result:
      []
      
    • ci-reports/allure/export
      • Outcome: passed
      • result:
      []
      
    • ci-reports/allure/history
      • Outcome: passed
      • result:
      []
      
    • 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
      
    • ci-reports/allure/plugin/behaviors
      • Outcome: passed
      • result:
      []
      
    • ci-reports/allure/plugin/packages
      • Outcome: passed
      • result:
      []
      
    • ci-reports/allure/plugin/screen-diff
      • Outcome: passed
      • result:
      []
      
    • ci-reports/allure/widgets
      • Outcome: passed
      • result:
      []
      
    • ci-reports/junit
      • Outcome: passed
      • result:
      []
      
    • ci-reports/markdown
      • Outcome: passed
      • result:
      []
      
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
      
    • morbidissimo/morbidissimo/modman
      • Outcome: passed
      • result:
      -   nodeid: morbidissimo/morbidissimo/modman/scripts
        type: Dir
      
    • morbidissimo/morbidissimo/modman/scripts
      • Outcome: passed
      • result:
      []
      
    • morbidissimo/morbidissimo/morioc
      • Outcome: passed
      • result:
      -   nodeid: morbidissimo/morbidissimo/morioc/test_infer_type.py
        type: Module
      
    • 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
      
outputs (1 tests)
  • outputs
    • Outcome: passed
    • result:
    []
    
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
      
    • slic/core/acquisition
      • Outcome: passed
      • result:
      -   nodeid: slic/core/acquisition/broker
        type: Package
      
    • slic/core/acquisition/broker
      • Outcome: passed
      • result:
      []
      
    • slic/core/adjustable
      • Outcome: passed
      • result:
      []
      
    • slic/core/condition
      • Outcome: passed
      • result:
      []
      
    • slic/core/device
      • Outcome: passed
      • result:
      []
      
    • slic/core/scanner
      • Outcome: passed
      • result:
      []
      
    • slic/core/sensor
      • Outcome: passed
      • result:
      []
      
    • slic/core/task
      • Outcome: passed
      • result:
      []
      
    • 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
      
    • slic/devices/cameras
      • Outcome: passed
      • result:
      []
      
    • slic/devices/endstations
      • Outcome: passed
      • result:
      []
      
    • slic/devices/general
      • Outcome: passed
      • result:
      -   nodeid: slic/devices/general/detectors
        type: Package
      -   nodeid: slic/devices/general/unused
        type: Dir
      
    • slic/devices/general/detectors
      • Outcome: passed
      • result:
      []
      
    • slic/devices/general/unused
      • Outcome: passed
      • result:
      []
      
    • slic/devices/loptics
      • Outcome: passed
      • result:
      []
      
    • slic/devices/timing
      • Outcome: passed
      • result:
      -   nodeid: slic/devices/timing/events
        type: Package
      
    • slic/devices/timing/events
      • Outcome: passed
      • result:
      []
      
    • slic/devices/xdiagnostics
      • Outcome: passed
      • result:
      []
      
    • slic/devices/xoptics
      • Outcome: passed
      • result:
      -   nodeid: slic/devices/xoptics/slits
        type: Package
      -   nodeid: slic/devices/xoptics/unused
        type: Dir
      
    • slic/devices/xoptics/slits
      • Outcome: passed
      • result:
      []
      
    • slic/devices/xoptics/unused
      • Outcome: passed
      • result:
      []
      
    • slic/gui
      • Outcome: passed
      • result:
      -   nodeid: slic/gui/daqpanels
        type: Package
      -   nodeid: slic/gui/widgets
        type: Package
      
    • slic/gui/daqpanels
      • Outcome: passed
      • result:
      []
      
    • slic/gui/widgets
      • Outcome: passed
      • result:
      []
      
    • slic/utils
      • Outcome: passed
      • result:
      -   nodeid: slic/utils/ioc
        type: Package
      -   nodeid: slic/utils/unused
        type: Dir
      
    • slic/utils/ioc
      • Outcome: passed
      • result:
      []
      
    • slic/utils/unused
      • Outcome: passed
      • result:
      -   nodeid: slic/utils/unused/xsim
        type: Package
      
    • slic/utils/unused/xsim
      • Outcome: passed
      • result:
      []
      
temp-ci (1 tests)
  • temp-ci
    • Outcome: passed
    • result:
    []
    
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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • tests/test_utils_elog.py
      • Outcome: passed
      • result:
      -   nodeid: tests/test_utils_elog.py::test_check_required_attributes
        type: Function
        lineno: 28
      -   nodeid: tests/test_utils_elog.py::test_post
        type: Function
        lineno: 106
      -   nodeid: tests/test_utils_elog.py::test_get_default_elog_instance_with_direct_password_and_real_check
        type: Function
        lineno: 43
      -   nodeid: tests/test_utils_elog.py::test_get_default_elog_instance_asks_password_and_opens
        type: Function
        lineno: 57
      -   nodeid: tests/test_utils_elog.py::test_get_default_elog_with_path_home
        type: Function
        lineno: 75
      -   nodeid: tests/test_utils_elog.py::test_screenshot
        type: Function
        lineno: 124
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • tests/test_utils_ipy.py
      • Outcome: passed
      • result:
      -   nodeid: tests/test_utils_ipy.py::test_devices_repr_fallback_and_ignore
        type: Function
        lineno: 19
      
    • 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
      
    • tests/test_utils_lazypv.py
      • Outcome: passed
      • result:
      -   nodeid: tests/test_utils_lazypv.py::test_getattr
        type: Function
        lineno: 7
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • tests/test_utils_sendmail.py
      • Outcome: passed
      • result:
      -   nodeid: tests/test_utils_sendmail.py::test_sendmail_real_local_verbose
        type: Function
        lineno: 70
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • tests/test_utils_termtitle.py
      • Outcome: passed
      • result:
      -   nodeid: tests/test_utils_termtitle.py::test_terminal_title_with_tmux
        type: Function
        lineno: 9
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
    • 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
      
. (1 tests)
  • .
    • Outcome: passed
    • result:
    -   nodeid: ci-reports
      type: Dir
    -   nodeid: morbidissimo
      type: Dir
    -   nodeid: outputs
      type: Dir
    -   nodeid: slic
      type: Package
    -   nodeid: temp-ci
      type: Dir
    -   nodeid: tests
      type: Dir
    

⚠️ 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