diff --git a/ci-reports/markdown/TEST-REPORT.md b/ci-reports/markdown/TEST-REPORT.md index d7dad7a00..a0d925345 100644 --- a/ci-reports/markdown/TEST-REPORT.md +++ b/ci-reports/markdown/TEST-REPORT.md @@ -9,7 +9,7 @@ ============================= test session starts ============================== platform linux -- Python 3.8.20, pytest-8.3.4, pluggy-1.5.0 rootdir: /workspace/tligui_y/slic -plugins: cov-5.0.0, allure-pytest-2.13.5, html-4.1.1, metadata-3.1.1, json-report-1.5.0, md-report-0.6.2 +plugins: html-4.1.1, metadata-3.1.1, cov-5.0.0, allure-pytest-2.13.5, json-report-1.5.0, md-report-0.6.2 collected 72 items / 2 errors tests/test_io_utils.py ..FFFFFF.F @@ -93,7 +93,7 @@ E FileNotFoundError: [Errno 2] No such file or directory: 'nonexistent.fil functions/io_utils.py:2: FileNotFoundError ____________________________ test_permission_error _____________________________ -monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7f4c5582d8b0> +monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7fe48ba5c730> def test_permission_error(monkeypatch): # Patch open to raise PermissionError simulating access denial @@ -117,7 +117,7 @@ E PermissionError: Permission denied tests/test_io_utils.py:34: PermissionError _____________________________ test_mock_open_error _____________________________ -monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7f4c55de1430> +monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7fe48bf96580> def test_mock_open_error(monkeypatch): # Mock open() to raise IOError simulating read error @@ -134,7 +134,7 @@ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ return self._execute_mock_call(*args, **kwargs) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -self = +self = args = ('file.txt', 'r'), kwargs = {}, effect = OSError('Mocked IOError') def _execute_mock_call(self, /, *args, **kwargs): @@ -160,7 +160,7 @@ E ValueError: I/O operation on closed file tests/test_io_utils.py:50: ValueError ________________________________ test_os_error _________________________________ -monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7f4c55af8df0> +monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7fe48bd63df0> def test_os_error(monkeypatch): # Patch os.remove to raise OSError simulating filesystem error @@ -328,7 +328,7 @@ tests/test_math_utils.py:106: StopIteration The above exception was the direct cause of the following exception: cls = -func = . at 0x7f4c55fca700> +func = . at 0x7fe48be3c700> when = 'call' reraise = (, ) @@ -457,7 +457,7 @@ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ name = 'non_existent_module_xyz' -import_ = +import_ = > ??? E ModuleNotFoundError: No module named 'non_existent_module_xyz' @@ -562,17 +562,17 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive !!!!!!!!!!!!!!!!!!!!!!!!!!!!!! KeyboardInterrupt !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! /workspace/tligui_y/slic/tests/test_string_utils.py:52: KeyboardInterrupt (to show a full traceback on KeyboardInterrupt use --full-trace) -=== 32 failed, 35 passed, 1 skipped, 2 xfailed, 1 warning, 3 errors in 0.79s === +=== 32 failed, 35 passed, 1 skipped, 2 xfailed, 1 warning, 3 errors in 0.85s === ``` --- # 🧪 Test Report -*Generated on 2025-07-19 20:08:52 CEST* +*Generated on 2025-07-19 20:10:52 CEST* ## 🧾 General Info -- **duration**: 0.7940311431884766 +- **duration**: 0.8480584621429443 - **root**: /workspace/tligui_y/slic - **environment**: {} @@ -591,9 +591,9 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive ✅ Passed (36) -
- 📄 test_io_utils.py + 📄 test_io_utils.py - ↳ Function: test_read_file + ↳ Function: test_read_file -
✅ Test 1 @@ -602,7 +602,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0035927039571106434 + 0.003604339901357889 ``` **outcome:** @@ -616,7 +616,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.000526093877851963 + 0.0004480029456317425 ``` **outcome:** @@ -630,7 +630,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00026531191542744637 + 0.0002537360414862633 ``` **outcome:** @@ -639,7 +639,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_write_file + ↳ Function: test_write_file -
✅ Test 2 @@ -648,7 +648,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0005024520214647055 + 0.0004862810019403696 ``` **outcome:** @@ -662,7 +662,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0003082759212702513 + 0.00029212585650384426 ``` **outcome:** @@ -676,7 +676,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00015172897838056087 + 0.00014290818944573402 ``` **outcome:** @@ -685,7 +685,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_write_file_readonly + ↳ Function: test_write_file_readonly -
✅ Test 9 @@ -694,7 +694,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.000756068853661418 + 0.0007142920512706041 ``` **outcome:** @@ -708,7 +708,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0009601230267435312 + 0.001015444053336978 ``` **outcome:** @@ -722,7 +722,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00016189506277441978 + 0.00017233891412615776 ``` **outcome:** @@ -734,9 +734,9 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive
-
- 📄 test_math_utils.py + 📄 test_math_utils.py - ↳ Function: test_addition_pass + ↳ Function: test_addition_pass -
✅ Test 13
(params: a=2, b=2, expected=4)
@@ -745,7 +745,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00036273710429668427 + 0.00032585300505161285 ``` **outcome:** @@ -759,7 +759,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001532949972897768 + 0.0001634808722883463 ``` **outcome:** @@ -773,7 +773,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00017221900634467602 + 0.00015774089843034744 ``` **outcome:** @@ -790,7 +790,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0002844491973519325 + 0.0002747410908341408 ``` **outcome:** @@ -804,7 +804,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001386650837957859 + 0.00013548205606639385 ``` **outcome:** @@ -818,7 +818,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013803690671920776 + 0.00014509703032672405 ``` **outcome:** @@ -835,7 +835,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0002601540181785822 + 0.0002529288176447153 ``` **outcome:** @@ -849,7 +849,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013089808635413647 + 0.00013421406038105488 ``` **outcome:** @@ -863,7 +863,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014615198597311974 + 0.0001374860294163227 ``` **outcome:** @@ -880,7 +880,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00023687095381319523 + 0.00023582903668284416 ``` **outcome:** @@ -894,7 +894,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012945802882313728 + 0.00013056606985628605 ``` **outcome:** @@ -908,7 +908,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001453279983252287 + 0.00013513397425413132 ``` **outcome:** @@ -925,7 +925,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00024129683151841164 + 0.00024592899717390537 ``` **outcome:** @@ -939,7 +939,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012711412273347378 + 0.00012610689736902714 ``` **outcome:** @@ -953,7 +953,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014471192844212055 + 0.00013228505849838257 ``` **outcome:** @@ -962,7 +962,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_addition_pass_id + ↳ Function: test_addition_pass_id -
✅ Test 18
(params: a=2, b=2, expected=4)
@@ -971,7 +971,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0002531129866838455 + 0.00023477408103644848 ``` **outcome:** @@ -985,7 +985,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001280789729207754 + 0.00012618605978786945 ``` **outcome:** @@ -999,7 +999,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014358898624777794 + 0.0001371761318296194 ``` **outcome:** @@ -1016,7 +1016,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0002494649961590767 + 0.00024573784321546555 ``` **outcome:** @@ -1030,7 +1030,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012943311594426632 + 0.0001256710384041071 ``` **outcome:** @@ -1044,7 +1044,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013888697139918804 + 0.00013288995251059532 ``` **outcome:** @@ -1061,7 +1061,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00023560202680528164 + 0.000244820024818182 ``` **outcome:** @@ -1075,7 +1075,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012493785470724106 + 0.0001287669874727726 ``` **outcome:** @@ -1089,7 +1089,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013893586583435535 + 0.0001340731978416443 ``` **outcome:** @@ -1101,9 +1101,9 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive
-
- 📄 test_param.py + 📄 test_param.py - ↳ Function: test_basic_ids + ↳ Function: test_basic_ids -
✅ Test 41
(params: x=1)
@@ -1112,7 +1112,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0002564608585089445 + 0.00024648592807352543 ``` **outcome:** @@ -1126,7 +1126,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001402630005031824 + 0.00013936497271060944 ``` **outcome:** @@ -1140,7 +1140,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012042699381709099 + 0.00012199999764561653 ``` **outcome:** @@ -1157,7 +1157,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00017943885177373886 + 0.00018452201038599014 ``` **outcome:** @@ -1171,7 +1171,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012480816803872585 + 0.0001278009731322527 ``` **outcome:** @@ -1185,7 +1185,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.000111074885353446 + 0.0001158041413873434 ``` **outcome:** @@ -1194,7 +1194,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_with_reason_and_marks + ↳ Function: test_with_reason_and_marks -
✅ Test 43
(params: x=10)
@@ -1203,7 +1203,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00016471394337713718 + 0.00016426085494458675 ``` **outcome:** @@ -1217,7 +1217,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013195187784731388 + 0.0001251788344234228 ``` **outcome:** @@ -1231,7 +1231,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00011302903294563293 + 0.00011022388935089111 ``` **outcome:** @@ -1240,7 +1240,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_multiple_positional_args + ↳ Function: test_multiple_positional_args -
✅ Test 45
(params: a=1, b=2)
@@ -1249,7 +1249,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00023756804876029491 + 0.00023832195438444614 ``` **outcome:** @@ -1263,7 +1263,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001380599569529295 + 0.00012902705930173397 ``` **outcome:** @@ -1277,7 +1277,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001255539245903492 + 0.0001266789622604847 ``` **outcome:** @@ -1294,7 +1294,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0002090800553560257 + 0.00021152803674340248 ``` **outcome:** @@ -1308,7 +1308,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012173294089734554 + 0.00012860819697380066 ``` **outcome:** @@ -1322,7 +1322,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012042606249451637 + 0.00012736395001411438 ``` **outcome:** @@ -1331,16 +1331,16 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_non_literal_with_id + ↳ Function: test_non_literal_with_id -
- ✅ Test 47
(params: data=(object object at 0x7f4c55c73960))
+ ✅ Test 47
(params: data=(object object at 0x7fe48be53960))
**_*Setup phase*_** **duration:** ```python - 0.0001510020811110735 + 0.00017059198580682278 ``` **outcome:** @@ -1354,7 +1354,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012608407996594906 + 0.00012141489423811436 ``` **outcome:** @@ -1368,7 +1368,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00011229491792619228 + 0.00011034705676138401 ``` **outcome:** @@ -1377,7 +1377,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_timedistance_v1 + ↳ Function: test_timedistance_v1 -
✅ Test 48
(params: a=2001-12-12 00:00:00, b=2001-12-11 00:00:00, expected=1 day, 0:00:00)
@@ -1386,7 +1386,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00024041789583861828 + 0.0002481809351593256 ``` **outcome:** @@ -1400,7 +1400,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012420094572007656 + 0.00012331386096775532 ``` **outcome:** @@ -1414,7 +1414,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001325008925050497 + 0.0001383849885314703 ``` **outcome:** @@ -1431,7 +1431,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00024350802414119244 + 0.000254862941801548 ``` **outcome:** @@ -1445,7 +1445,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013148109428584576 + 0.000124865910038352 ``` **outcome:** @@ -1459,7 +1459,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013739592395722866 + 0.00013261218555271626 ``` **outcome:** @@ -1468,7 +1468,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_dynamic + ↳ Function: test_dynamic -
✅ Test 51
(params: val=10)
@@ -1477,7 +1477,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00018908502534031868 + 0.00018024793826043606 ``` **outcome:** @@ -1491,7 +1491,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013100518845021725 + 0.00013278494589030743 ``` **outcome:** @@ -1505,7 +1505,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001158551312983036 + 0.00011739297769963741 ``` **outcome:** @@ -1522,7 +1522,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00016777310520410538 + 0.00016096699982881546 ``` **outcome:** @@ -1536,7 +1536,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001289830543100834 + 0.00012196903117001057 ``` **outcome:** @@ -1550,7 +1550,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00011578202247619629 + 0.00011925818398594856 ``` **outcome:** @@ -1567,7 +1567,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001735091209411621 + 0.0001843541394919157 ``` **outcome:** @@ -1581,7 +1581,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012175203301012516 + 0.00014753197319805622 ``` **outcome:** @@ -1595,7 +1595,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00010962388478219509 + 0.00013431580737233162 ``` **outcome:** @@ -1604,7 +1604,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_element_type + ↳ Function: test_element_type -
✅ Test 54
(params: element=fire)
@@ -1613,7 +1613,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00017884699627757072 + 0.00018815393559634686 ``` **outcome:** @@ -1627,7 +1627,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001248528715223074 + 0.00014288397505879402 ``` **outcome:** @@ -1641,7 +1641,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001101719681173563 + 0.000126637052744627 ``` **outcome:** @@ -1658,7 +1658,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00015679583884775639 + 0.00018169288523495197 ``` **outcome:** @@ -1672,7 +1672,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00011923210695385933 + 0.00014170887880027294 ``` **outcome:** @@ -1686,7 +1686,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00011029187589883804 + 0.00012704799883067608 ``` **outcome:** @@ -1703,7 +1703,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00015581399202346802 + 0.00018208217807114124 ``` **outcome:** @@ -1717,7 +1717,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013045081868767738 + 0.00014093401841819286 ``` **outcome:** @@ -1731,7 +1731,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001142991241067648 + 0.000129257095977664 ``` **outcome:** @@ -1740,7 +1740,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_combination + ↳ Function: test_combination -
✅ Test 57
(params: y=a, x=1)
@@ -1749,7 +1749,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00020695803686976433 + 0.00023418013006448746 ``` **outcome:** @@ -1763,7 +1763,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012479303404688835 + 0.00014371005818247795 ``` **outcome:** @@ -1777,7 +1777,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012275809422135353 + 0.00015111500397324562 ``` **outcome:** @@ -1794,7 +1794,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00019628996960818768 + 0.00022931210696697235 ``` **outcome:** @@ -1808,7 +1808,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012149196118116379 + 0.00014824303798377514 ``` **outcome:** @@ -1822,7 +1822,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012685800902545452 + 0.00014614802785217762 ``` **outcome:** @@ -1839,7 +1839,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0002017670776695013 + 0.00022961199283599854 ``` **outcome:** @@ -1853,7 +1853,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012160604819655418 + 0.0001437189057469368 ``` **outcome:** @@ -1867,7 +1867,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012005516327917576 + 0.0001438390463590622 ``` **outcome:** @@ -1884,7 +1884,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00020254612900316715 + 0.00022813212126493454 ``` **outcome:** @@ -1898,7 +1898,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012808199971914291 + 0.0001525520347058773 ``` **outcome:** @@ -1912,7 +1912,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013594003394246101 + 0.00014077592641115189 ``` **outcome:** @@ -1921,7 +1921,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_indirect_fixture + ↳ Function: test_indirect_fixture -
✅ Test 61
(params: complex_setup=1)
@@ -1930,7 +1930,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0002956269308924675 + 0.0003382971044629812 ``` **outcome:** @@ -1944,7 +1944,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013960804790258408 + 0.00014980812557041645 ``` **outcome:** @@ -1958,7 +1958,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012201815843582153 + 0.00012976606376469135 ``` **outcome:** @@ -1975,7 +1975,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00017007696442306042 + 0.00019439798779785633 ``` **outcome:** @@ -1989,7 +1989,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012628501281142235 + 0.00014423509128391743 ``` **outcome:** @@ -2003,7 +2003,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00011258595623075962 + 0.00012772902846336365 ``` **outcome:** @@ -2015,9 +2015,9 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive
-
- 📄 test_string_utils.py + 📄 test_string_utils.py - ↳ Function: test_uppercase_normal + ↳ Function: test_uppercase_normal -
✅ Test 64 @@ -2026,7 +2026,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012418907135725021 + 0.00014012213796377182 ``` **outcome:** @@ -2040,7 +2040,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014147115871310234 + 0.00016683898866176605 ``` **outcome:** @@ -2054,7 +2054,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 9.957514703273773e-05 + 0.00011661602184176445 ``` **outcome:** @@ -2063,7 +2063,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_reverse_string + ↳ Function: test_reverse_string -
✅ Test 66 @@ -2072,7 +2072,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001162099651992321 + 0.00012062117457389832 ``` **outcome:** @@ -2086,7 +2086,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00015760213136672974 + 0.00014070305041968822 ``` **outcome:** @@ -2100,7 +2100,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 9.953719563782215e-05 + 0.00010410300455987453 ``` **outcome:** @@ -2109,7 +2109,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_warning_emit + ↳ Function: test_warning_emit -
✅ Test 67 @@ -2118,7 +2118,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00010467902757227421 + 0.00010586204007267952 ``` **outcome:** @@ -2132,7 +2132,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014186184853315353 + 0.00015261489897966385 ``` **outcome:** @@ -2146,7 +2146,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 9.550992399454117e-05 + 0.00010772189125418663 ``` **outcome:** @@ -2155,7 +2155,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_import_warning + ↳ Function: test_import_warning -
✅ Test 70 @@ -2164,7 +2164,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012757186777889729 + 0.00012971390970051289 ``` **outcome:** @@ -2178,7 +2178,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013442197814583778 + 0.00014096801169216633 ``` **outcome:** @@ -2192,7 +2192,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 9.814510121941566e-05 + 0.00010313699021935463 ``` **outcome:** @@ -2201,7 +2201,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_keyboard_interrupt_direct + ↳ Function: test_keyboard_interrupt_direct -
✅ Test 72 @@ -2210,7 +2210,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012999307364225388 + 0.00011977995745837688 ``` **outcome:** @@ -2227,9 +2227,9 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive ❌ Failed (32) -
- 📄 test_io_utils.py + 📄 test_io_utils.py - ↳ Function: test_cause_io_error + ↳ Function: test_cause_io_error -
❌ Test 3 @@ -2238,7 +2238,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00011634896509349346 + 0.00011350912973284721 ``` **outcome:** @@ -2252,7 +2252,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00015770108439028263 + 0.00016173208132386208 ``` **outcome:** @@ -2302,7 +2302,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014807004481554031 + 0.00014455104246735573 ``` **outcome:** @@ -2311,7 +2311,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_file_not_found + ↳ Function: test_file_not_found -
❌ Test 4 @@ -2320,7 +2320,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012230011634528637 + 0.0001225059386342764 ``` **outcome:** @@ -2334,7 +2334,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00018097716383635998 + 0.00018438906408846378 ``` **outcome:** @@ -2386,7 +2386,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001414688304066658 + 0.0001413370482623577 ``` **outcome:** @@ -2395,7 +2395,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_permission_error + ↳ Function: test_permission_error -
❌ Test 5 @@ -2404,7 +2404,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00021795183420181274 + 0.00020894501358270645 ``` **outcome:** @@ -2418,7 +2418,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00017540506087243557 + 0.0001769110094755888 ``` **outcome:** @@ -2452,7 +2452,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **longrepr:** ```python - monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7f4c5582d8b0> + monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7fe48ba5c730> def test_permission_error(monkeypatch): # Patch open to raise PermissionError simulating access denial @@ -2481,7 +2481,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00017365510575473309 + 0.00016919593326747417 ``` **outcome:** @@ -2490,7 +2490,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_mock_open_error + ↳ Function: test_mock_open_error -
❌ Test 6 @@ -2499,7 +2499,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0002115289680659771 + 0.00018884195014834404 ``` **outcome:** @@ -2513,7 +2513,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.003329366911202669 + 0.003317840164527297 ``` **outcome:** @@ -2550,7 +2550,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **longrepr:** ```python - monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7f4c55de1430> + monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7fe48bf96580> def test_mock_open_error(monkeypatch): # Mock open() to raise IOError simulating read error @@ -2567,7 +2567,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive return self._execute_mock_call(*args, **kwargs) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - self = + self = args = ('file.txt', 'r'), kwargs = {}, effect = OSError('Mocked IOError') def _execute_mock_call(self, /, *args, **kwargs): @@ -2588,7 +2588,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0003329480532556772 + 0.0003249498549848795 ``` **outcome:** @@ -2597,7 +2597,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_file_handle_closed_error + ↳ Function: test_file_handle_closed_error -
❌ Test 7 @@ -2606,7 +2606,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00015738513320684433 + 0.0001420220360159874 ``` **outcome:** @@ -2620,7 +2620,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00019312603399157524 + 0.00019976194016635418 ``` **outcome:** @@ -2663,7 +2663,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00020414497703313828 + 0.00022178702056407928 ``` **outcome:** @@ -2672,7 +2672,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_os_error + ↳ Function: test_os_error -
❌ Test 8 @@ -2681,7 +2681,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0004144669510424137 + 0.0002899088431149721 ``` **outcome:** @@ -2695,7 +2695,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00035541201941668987 + 0.0002075729425996542 ``` **outcome:** @@ -2726,7 +2726,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **longrepr:** ```python - monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7f4c55af8df0> + monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7fe48bd63df0> def test_os_error(monkeypatch): # Patch os.remove to raise OSError simulating filesystem error @@ -2752,7 +2752,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0002219120506197214 + 0.00022788089700043201 ``` **outcome:** @@ -2761,7 +2761,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_file_not_found_error + ↳ Function: test_file_not_found_error -
❌ Test 10 @@ -2770,7 +2770,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012234714813530445 + 0.00012602703645825386 ``` **outcome:** @@ -2784,7 +2784,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001760418526828289 + 0.00017937691882252693 ``` **outcome:** @@ -2825,7 +2825,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014961999841034412 + 0.00015364610590040684 ``` **outcome:** @@ -2837,9 +2837,9 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive
-
- 📄 test_math_utils.py + 📄 test_math_utils.py - ↳ Function: test_broken + ↳ Function: test_broken -
❌ Test 11 @@ -2848,7 +2848,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013265199959278107 + 0.0001313758548349142 ``` **outcome:** @@ -2862,7 +2862,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001613690983504057 + 0.00018263398669660091 ``` **outcome:** @@ -2903,7 +2903,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013866997323930264 + 0.0001646790187805891 ``` **outcome:** @@ -2912,7 +2912,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_call_missing_function + ↳ Function: test_call_missing_function -
❌ Test 12 @@ -2921,7 +2921,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012383703142404556 + 0.0001314510591328144 ``` **outcome:** @@ -2935,7 +2935,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00016052485443651676 + 0.00016825087368488312 ``` **outcome:** @@ -2976,7 +2976,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00017554312944412231 + 0.00016052508726716042 ``` **outcome:** @@ -2985,7 +2985,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_addition_fail + ↳ Function: test_addition_fail -
❌ Test 21 @@ -2994,7 +2994,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00010590208694338799 + 0.00010233791545033455 ``` **outcome:** @@ -3008,7 +3008,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0005099500995129347 + 0.0005044790450483561 ``` **outcome:** @@ -3051,7 +3051,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014958903193473816 + 0.00015952112153172493 ``` **outcome:** @@ -3060,7 +3060,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_division_zero + ↳ Function: test_division_zero -
❌ Test 22 @@ -3069,7 +3069,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012248707935214043 + 0.00017586816102266312 ``` **outcome:** @@ -3083,7 +3083,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00016648508608341217 + 0.00029951496981084347 ``` **outcome:** @@ -3135,7 +3135,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00016888114623725414 + 0.00023273704573512077 ``` **outcome:** @@ -3144,7 +3144,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_runtime_error + ↳ Function: test_runtime_error -
❌ Test 24 @@ -3153,7 +3153,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012237997725605965 + 0.00021421699784696102 ``` **outcome:** @@ -3167,7 +3167,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00017202692106366158 + 0.0002854440826922655 ``` **outcome:** @@ -3208,7 +3208,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.000144279096275568 + 0.00023652613162994385 ``` **outcome:** @@ -3217,7 +3217,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_memory_error + ↳ Function: test_memory_error -
❌ Test 25 @@ -3226,7 +3226,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013360311277210712 + 0.00021091685630381107 ``` **outcome:** @@ -3240,7 +3240,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00017066486179828644 + 0.0002885309513658285 ``` **outcome:** @@ -3281,7 +3281,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00015691807493567467 + 0.0001832200214266777 ``` **outcome:** @@ -3290,7 +3290,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_timeout_error + ↳ Function: test_timeout_error -
❌ Test 26 @@ -3299,7 +3299,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013270904310047626 + 0.00017371098510921001 ``` **outcome:** @@ -3313,7 +3313,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00016988394781947136 + 0.00021384097635746002 ``` **outcome:** @@ -3354,7 +3354,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00015988294035196304 + 0.00017173890955746174 ``` **outcome:** @@ -3363,7 +3363,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_recursion_error + ↳ Function: test_recursion_error -
❌ Test 27 @@ -3372,7 +3372,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013546599075198174 + 0.00015650317072868347 ``` **outcome:** @@ -3386,7 +3386,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0009217811748385429 + 0.001101339003071189 ``` **outcome:** @@ -3441,7 +3441,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0002302350476384163 + 0.00014351005665957928 ``` **outcome:** @@ -3450,7 +3450,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_floating_point_error + ↳ Function: test_floating_point_error -
❌ Test 28 @@ -3459,7 +3459,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013321894221007824 + 0.00012473389506340027 ``` **outcome:** @@ -3473,7 +3473,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00016312208026647568 + 0.0001532940659672022 ``` **outcome:** @@ -3514,7 +3514,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001657288521528244 + 0.00014129886403679848 ``` **outcome:** @@ -3523,7 +3523,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_floating_point_overflow + ↳ Function: test_floating_point_overflow -
❌ Test 29 @@ -3532,7 +3532,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001321369782090187 + 0.00013295700773596764 ``` **outcome:** @@ -3546,7 +3546,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00017774594016373158 + 0.000159702030941844 ``` **outcome:** @@ -3587,7 +3587,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00016633793711662292 + 0.00013917102478444576 ``` **outcome:** @@ -3596,7 +3596,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_value_error + ↳ Function: test_value_error -
❌ Test 30 @@ -3605,7 +3605,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012943195179104805 + 0.00012867385521531105 ``` **outcome:** @@ -3619,7 +3619,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00017147394828498363 + 0.00016219611279666424 ``` **outcome:** @@ -3660,7 +3660,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00015998096205294132 + 0.0001484088134020567 ``` **outcome:** @@ -3669,7 +3669,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_wrong_argument_error + ↳ Function: test_wrong_argument_error -
❌ Test 31 @@ -3678,7 +3678,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001303709577769041 + 0.0001167571172118187 ``` **outcome:** @@ -3692,7 +3692,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001613700296729803 + 0.000151502201333642 ``` **outcome:** @@ -3733,7 +3733,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00015098880976438522 + 0.00013879919424653053 ``` **outcome:** @@ -3742,7 +3742,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_unhandled_exception + ↳ Function: test_unhandled_exception -
❌ Test 32 @@ -3751,7 +3751,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001305209007114172 + 0.00011623091995716095 ``` **outcome:** @@ -3765,7 +3765,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00017120898701250553 + 0.0001494050957262516 ``` **outcome:** @@ -3806,7 +3806,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014737690798938274 + 0.0001417580060660839 ``` **outcome:** @@ -3815,7 +3815,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_custom_error + ↳ Function: test_custom_error -
❌ Test 33 @@ -3824,7 +3824,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013022194616496563 + 0.00011655595153570175 ``` **outcome:** @@ -3838,7 +3838,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00015693786554038525 + 0.00015103002078831196 ``` **outcome:** @@ -3879,7 +3879,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001460961066186428 + 0.00014246907085180283 ``` **outcome:** @@ -3888,7 +3888,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_stop_iteration_direct + ↳ Function: test_stop_iteration_direct -
❌ Test 34 @@ -3897,7 +3897,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012335088104009628 + 0.00012304610572755337 ``` **outcome:** @@ -3911,7 +3911,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001588580198585987 + 0.0001640769187361002 ``` **outcome:** @@ -3979,7 +3979,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive The above exception was the direct cause of the following exception: cls = - func = . at 0x7f4c55fca700> + func = . at 0x7fe48be3c700> when = 'call' reraise = (, ) @@ -4046,7 +4046,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0002446169964969158 + 0.00025580497458577156 ``` **outcome:** @@ -4055,7 +4055,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_generator_exit_direct + ↳ Function: test_generator_exit_direct -
❌ Test 35 @@ -4064,7 +4064,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014816690236330032 + 0.00014240085147321224 ``` **outcome:** @@ -4078,7 +4078,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00016938988119363785 + 0.00020209909416735172 ``` **outcome:** @@ -4119,7 +4119,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00016369414515793324 + 0.00020958180539309978 ``` **outcome:** @@ -4128,7 +4128,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_malformed_code + ↳ Function: test_malformed_code -
❌ Test 36 @@ -4137,7 +4137,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012634415179491043 + 0.00012465519830584526 ``` **outcome:** @@ -4151,7 +4151,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001717607956379652 + 0.0001744660548865795 ``` **outcome:** @@ -4198,7 +4198,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00015626591630280018 + 0.0001511010341346264 ``` **outcome:** @@ -4207,7 +4207,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_sys_exit + ↳ Function: test_sys_exit -
❌ Test 37 @@ -4216,7 +4216,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012115598656237125 + 0.00012170104309916496 ``` **outcome:** @@ -4230,7 +4230,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014615105465054512 + 0.00015023606829345226 ``` **outcome:** @@ -4271,7 +4271,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013573304750025272 + 0.0001453729346394539 ``` **outcome:** @@ -4280,7 +4280,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_broken_function + ↳ Function: test_broken_function -
❌ Test 38 @@ -4289,7 +4289,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013293209485709667 + 0.00012337509542703629 ``` **outcome:** @@ -4303,7 +4303,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001556540373712778 + 0.00015427195467054844 ``` **outcome:** @@ -4357,7 +4357,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001439379993826151 + 0.00015054293908178806 ``` **outcome:** @@ -4366,7 +4366,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_import_error + ↳ Function: test_import_error -
❌ Test 39 @@ -4375,7 +4375,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001190828625112772 + 0.00011663511395454407 ``` **outcome:** @@ -4389,7 +4389,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001511040609329939 + 0.00015443307347595692 ``` **outcome:** @@ -4429,7 +4429,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013555004261434078 + 0.00014697294682264328 ``` **outcome:** @@ -4438,7 +4438,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_module_not_found_error + ↳ Function: test_module_not_found_error -
❌ Test 40 @@ -4447,7 +4447,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012307497672736645 + 0.00011754198931157589 ``` **outcome:** @@ -4461,7 +4461,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.000500907190144062 + 0.0005241041071712971 ``` **outcome:** @@ -4516,7 +4516,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ name = 'non_existent_module_xyz' - import_ = + import_ = > ??? E ModuleNotFoundError: No module named 'non_existent_module_xyz' @@ -4529,7 +4529,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014745700173079967 + 0.00015066401101648808 ``` **outcome:** @@ -4541,9 +4541,9 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive
-
- 📄 test_param.py + 📄 test_param.py - ↳ Function: test_addition + ↳ Function: test_addition -
❌ Test 63 @@ -4552,7 +4552,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00010890793055295944 + 0.0001362641341984272 ``` **outcome:** @@ -4566,7 +4566,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001427019014954567 + 0.00016373186372220516 ``` **outcome:** @@ -4609,7 +4609,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014391308650374413 + 0.0001544049009680748 ``` **outcome:** @@ -4621,9 +4621,9 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive
-
- 📄 test_string_utils.py + 📄 test_string_utils.py - ↳ Function: test_uppercase_type_error + ↳ Function: test_uppercase_type_error -
❌ Test 65 @@ -4632,7 +4632,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00010383501648902893 + 0.0001228500623255968 ``` **outcome:** @@ -4646,7 +4646,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014087790623307228 + 0.0001670739147812128 ``` **outcome:** @@ -4699,7 +4699,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013547600246965885 + 0.00014146394096314907 ``` **outcome:** @@ -4708,7 +4708,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_unicode_decode_error + ↳ Function: test_unicode_decode_error -
❌ Test 68 @@ -4717,7 +4717,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00011016312055289745 + 0.0001034389715641737 ``` **outcome:** @@ -4731,7 +4731,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014436710625886917 + 0.00014473404735326767 ``` **outcome:** @@ -4772,7 +4772,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0001314929686486721 + 0.00014453288167715073 ``` **outcome:** @@ -4781,7 +4781,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive passed ```
- ↳ Function: test_unicode_decode_surrogateescape + ↳ Function: test_unicode_decode_surrogateescape -
❌ Test 69 @@ -4790,7 +4790,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00011696713045239449 + 0.00011710496619343758 ``` **outcome:** @@ -4804,7 +4804,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014984910376369953 + 0.00015011103823781013 ``` **outcome:** @@ -4845,7 +4845,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013337191194295883 + 0.0001374951098114252 ``` **outcome:** @@ -4862,9 +4862,9 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive ❌ Xfailed (2) -
- 📄 test_math_utils.py + 📄 test_math_utils.py - ↳ Function: test_multiply_xfail + ↳ Function: test_multiply_xfail -
❌ Test 23 @@ -4873,7 +4873,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00014091609045863152 + 0.0002610699739307165 ``` **outcome:** @@ -4887,7 +4887,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0002776370383799076 + 0.000476679066196084 ``` **outcome:** @@ -4931,7 +4931,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013629603199660778 + 0.00022982200607657433 ``` **outcome:** @@ -4943,9 +4943,9 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive
-
- 📄 test_string_utils.py + 📄 test_string_utils.py - ↳ Function: test_xfail_uppercase_digits + ↳ Function: test_xfail_uppercase_digits -
❌ Test 71 @@ -4954,7 +4954,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00011624395847320557 + 0.00011595012620091438 ``` **outcome:** @@ -4968,7 +4968,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.0006171560380607843 + 0.000629462068900466 ``` **outcome:** @@ -5018,7 +5018,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013338192366063595 + 0.0001344778575003147 ``` **outcome:** @@ -5035,9 +5035,9 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive ❌ Skipped (1) -
- 📄 test_param.py + 📄 test_param.py - ↳ Function: test_with_reason_and_marks + ↳ Function: test_with_reason_and_marks -
❌ Test 44 @@ -5046,7 +5046,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00023666396737098694 + 0.0002290019765496254 ``` **outcome:** @@ -5066,7 +5066,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00010647205635905266 + 0.00011773500591516495 ``` **outcome:** @@ -5083,9 +5083,9 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive ❌ Error (1) -
- 📄 test_param.py + 📄 test_param.py - ↳ Function: TestDynamic + ↳ Function: TestDynamic -
❌ Test 50 @@ -5094,7 +5094,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00013801106251776218 + 0.00015152012929320335 ``` **outcome:** @@ -5120,7 +5120,7 @@ ERROR tests/test_param.py::TestDynamic::test_sum_positive **duration:** ```python - 0.00012780609540641308 + 0.0001243269070982933 ``` **outcome:** diff --git a/ci-reports/markdown/json-tree-view.txt b/ci-reports/markdown/json-tree-view.txt index a4f4f7045..bb0c13405 100644 --- a/ci-reports/markdown/json-tree-view.txt +++ b/ci-reports/markdown/json-tree-view.txt @@ -1,6 +1,6 @@ 📁 ci-reports/markdown/pytest-report.json -├── created: 1752948532.183237 -├── duration: 0.7940311431884766 +├── created: 1752948651.896282 +├── duration: 0.8480584621429443 ├── exitcode: 2 ├── root: /workspace/tligui_y/slic ├── environment @@ -523,13 +523,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0035927039571106434 +│ │ │ ├── duration: 0.003604339901357889 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.000526093877851963 +│ │ │ ├── duration: 0.0004480029456317425 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00026531191542744637 +│ │ ├── duration: 0.0002537360414862633 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_io_utils.py::test_write_file @@ -542,13 +542,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0005024520214647055 +│ │ │ ├── duration: 0.0004862810019403696 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0003082759212702513 +│ │ │ ├── duration: 0.00029212585650384426 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00015172897838056087 +│ │ ├── duration: 0.00014290818944573402 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_io_utils.py::test_cause_io_error @@ -561,10 +561,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00011634896509349346 +│ │ │ ├── duration: 0.00011350912973284721 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00015770108439028263 +│ │ │ ├── duration: 0.00016173208132386208 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/functions/io_utils.py @@ -593,7 +593,7 @@ │ │ │ │ │ │ functions/io_utils.py:10: OSError │ │ └── teardown -│ │ ├── duration: 0.00014807004481554031 +│ │ ├── duration: 0.00014455104246735573 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_io_utils.py::test_file_not_found @@ -606,10 +606,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00012230011634528637 +│ │ │ ├── duration: 0.0001225059386342764 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00018097716383635998 +│ │ │ ├── duration: 0.00018438906408846378 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/functions/io_utils.py @@ -642,7 +642,7 @@ │ │ │ │ │ │ functions/io_utils.py:2: FileNotFoundError │ │ └── teardown -│ │ ├── duration: 0.0001414688304066658 +│ │ ├── duration: 0.0001413370482623577 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_io_utils.py::test_permission_error @@ -655,10 +655,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00021795183420181274 +│ │ │ ├── duration: 0.00020894501358270645 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00017540506087243557 +│ │ │ ├── duration: 0.0001769110094755888 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_io_utils.py @@ -678,7 +678,7 @@ │ │ │ │ ├── lineno: 34 │ │ │ │ └── message: PermissionError │ │ │ └── longrepr: monkeypatch = <_pytest.monkeypatch.MonkeyPatch object -│ │ │ at 0x7f4c5582d8b0> +│ │ │ at 0x7fe48ba5c730> │ │ │ │ │ │ def test_permission_error(monkeypatch): │ │ │ # Patch open to raise PermissionError simulating access @@ -704,7 +704,7 @@ │ │ │ │ │ │ tests/test_io_utils.py:34: PermissionError │ │ └── teardown -│ │ ├── duration: 0.00017365510575473309 +│ │ ├── duration: 0.00016919593326747417 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_io_utils.py::test_mock_open_error @@ -717,10 +717,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0002115289680659771 +│ │ │ ├── duration: 0.00018884195014834404 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.003329366911202669 +│ │ │ ├── duration: 0.003317840164527297 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: @@ -746,7 +746,7 @@ │ │ │ │ ├── lineno: 1140 │ │ │ │ └── message: OSError │ │ │ └── longrepr: monkeypatch = <_pytest.monkeypatch.MonkeyPatch object -│ │ │ at 0x7f4c55de1430> +│ │ │ at 0x7fe48bf96580> │ │ │ │ │ │ def test_mock_open_error(monkeypatch): │ │ │ # Mock open() to raise IOError simulating read error @@ -768,7 +768,7 @@ │ │ │ _ _ _ _ _ _ _ _ │ │ │ │ │ │ self = +│ │ │ id='140619577648080'> │ │ │ args = ('file.txt', 'r'), kwargs = {}, effect = OSError('Mocked │ │ │ IOError') │ │ │ @@ -786,7 +786,7 @@ │ │ │ │ │ │ .pixi/envs/default/lib/python3.8/unittest/mock.py:1140: OSError │ │ └── teardown -│ │ ├── duration: 0.0003329480532556772 +│ │ ├── duration: 0.0003249498549848795 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_io_utils.py::test_file_handle_closed_error @@ -799,10 +799,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00015738513320684433 +│ │ │ ├── duration: 0.0001420220360159874 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00019312603399157524 +│ │ │ ├── duration: 0.00019976194016635418 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_io_utils.py @@ -822,7 +822,7 @@ │ │ │ │ │ │ tests/test_io_utils.py:50: ValueError │ │ └── teardown -│ │ ├── duration: 0.00020414497703313828 +│ │ ├── duration: 0.00022178702056407928 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_io_utils.py::test_os_error @@ -835,10 +835,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0004144669510424137 +│ │ │ ├── duration: 0.0002899088431149721 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00035541201941668987 +│ │ │ ├── duration: 0.0002075729425996542 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_io_utils.py @@ -854,7 +854,7 @@ │ │ │ │ ├── lineno: 55 │ │ │ │ └── message: OSError │ │ │ └── longrepr: monkeypatch = <_pytest.monkeypatch.MonkeyPatch object -│ │ │ at 0x7f4c55af8df0> +│ │ │ at 0x7fe48bd63df0> │ │ │ │ │ │ def test_os_error(monkeypatch): │ │ │ # Patch os.remove to raise OSError simulating filesystem @@ -876,7 +876,7 @@ │ │ │ │ │ │ tests/test_io_utils.py:55: OSError │ │ └── teardown -│ │ ├── duration: 0.0002219120506197214 +│ │ ├── duration: 0.00022788089700043201 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_io_utils.py::test_write_file_readonly @@ -889,13 +889,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.000756068853661418 +│ │ │ ├── duration: 0.0007142920512706041 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0009601230267435312 +│ │ │ ├── duration: 0.001015444053336978 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00016189506277441978 +│ │ ├── duration: 0.00017233891412615776 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_io_utils.py::test_file_not_found_error @@ -908,10 +908,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00012234714813530445 +│ │ │ ├── duration: 0.00012602703645825386 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001760418526828289 +│ │ │ ├── duration: 0.00017937691882252693 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_io_utils.py @@ -932,7 +932,7 @@ │ │ │ │ │ │ tests/test_io_utils.py:69: FileNotFoundError │ │ └── teardown -│ │ ├── duration: 0.00014961999841034412 +│ │ ├── duration: 0.00015364610590040684 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_broken @@ -945,10 +945,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00013265199959278107 +│ │ │ ├── duration: 0.0001313758548349142 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001613690983504057 +│ │ │ ├── duration: 0.00018263398669660091 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -968,7 +968,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:16: NameError │ │ └── teardown -│ │ ├── duration: 0.00013866997323930264 +│ │ ├── duration: 0.0001646790187805891 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_call_missing_function @@ -981,10 +981,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00012383703142404556 +│ │ │ ├── duration: 0.0001314510591328144 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00016052485443651676 +│ │ │ ├── duration: 0.00016825087368488312 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1005,7 +1005,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:20: AttributeError │ │ └── teardown -│ │ ├── duration: 0.00017554312944412231 +│ │ ├── duration: 0.00016052508726716042 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_addition_pass[2-2-4] @@ -1021,13 +1021,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00036273710429668427 +│ │ │ ├── duration: 0.00032585300505161285 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001532949972897768 +│ │ │ ├── duration: 0.0001634808722883463 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00017221900634467602 +│ │ ├── duration: 0.00015774089843034744 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_addition_pass[1-5-6] @@ -1043,13 +1043,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0002844491973519325 +│ │ │ ├── duration: 0.0002747410908341408 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001386650837957859 +│ │ │ ├── duration: 0.00013548205606639385 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00013803690671920776 +│ │ ├── duration: 0.00014509703032672405 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_addition_pass[3-4-7] @@ -1065,13 +1065,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0002601540181785822 +│ │ │ ├── duration: 0.0002529288176447153 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00013089808635413647 +│ │ │ ├── duration: 0.00013421406038105488 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00014615198597311974 +│ │ ├── duration: 0.0001374860294163227 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_addition_pass[3-5-8] @@ -1087,13 +1087,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00023687095381319523 +│ │ │ ├── duration: 0.00023582903668284416 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012945802882313728 +│ │ │ ├── duration: 0.00013056606985628605 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.0001453279983252287 +│ │ ├── duration: 0.00013513397425413132 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_addition_pass[3-6-9] @@ -1109,13 +1109,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00024129683151841164 +│ │ │ ├── duration: 0.00024592899717390537 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012711412273347378 +│ │ │ ├── duration: 0.00012610689736902714 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00014471192844212055 +│ │ ├── duration: 0.00013228505849838257 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_addition_pass_id @@ -1131,13 +1131,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0002531129866838455 +│ │ │ ├── duration: 0.00023477408103644848 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001280789729207754 +│ │ │ ├── duration: 0.00012618605978786945 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00014358898624777794 +│ │ ├── duration: 0.0001371761318296194 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_addition_pass_id @@ -1153,13 +1153,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0002494649961590767 +│ │ │ ├── duration: 0.00024573784321546555 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012943311594426632 +│ │ │ ├── duration: 0.0001256710384041071 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00013888697139918804 +│ │ ├── duration: 0.00013288995251059532 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_addition_pass_id @@ -1175,13 +1175,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00023560202680528164 +│ │ │ ├── duration: 0.000244820024818182 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012493785470724106 +│ │ │ ├── duration: 0.0001287669874727726 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00013893586583435535 +│ │ ├── duration: 0.0001340731978416443 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_addition_fail @@ -1194,10 +1194,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00010590208694338799 +│ │ │ ├── duration: 0.00010233791545033455 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0005099500995129347 +│ │ │ ├── duration: 0.0005044790450483561 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1217,7 +1217,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:51: AssertionError │ │ └── teardown -│ │ ├── duration: 0.00014958903193473816 +│ │ ├── duration: 0.00015952112153172493 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_division_zero @@ -1230,10 +1230,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00012248707935214043 +│ │ │ ├── duration: 0.00017586816102266312 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00016648508608341217 +│ │ │ ├── duration: 0.00029951496981084347 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/functions/math_utils.py @@ -1265,7 +1265,7 @@ │ │ │ │ │ │ functions/math_utils.py:5: ZeroDivisionError │ │ └── teardown -│ │ ├── duration: 0.00016888114623725414 +│ │ ├── duration: 0.00023273704573512077 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_multiply_xfail @@ -1280,10 +1280,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00014091609045863152 +│ │ │ ├── duration: 0.0002610699739307165 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0002776370383799076 +│ │ │ ├── duration: 0.000476679066196084 │ │ │ ├── outcome: skipped │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1305,7 +1305,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:60: AssertionError │ │ └── teardown -│ │ ├── duration: 0.00013629603199660778 +│ │ ├── duration: 0.00022982200607657433 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_runtime_error @@ -1318,10 +1318,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00012237997725605965 +│ │ │ ├── duration: 0.00021421699784696102 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00017202692106366158 +│ │ │ ├── duration: 0.0002854440826922655 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1339,7 +1339,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:64: RuntimeError │ │ └── teardown -│ │ ├── duration: 0.000144279096275568 +│ │ ├── duration: 0.00023652613162994385 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_memory_error @@ -1352,10 +1352,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00013360311277210712 +│ │ │ ├── duration: 0.00021091685630381107 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00017066486179828644 +│ │ │ ├── duration: 0.0002885309513658285 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1374,7 +1374,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:68: MemoryError │ │ └── teardown -│ │ ├── duration: 0.00015691807493567467 +│ │ ├── duration: 0.0001832200214266777 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_timeout_error @@ -1387,10 +1387,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00013270904310047626 +│ │ │ ├── duration: 0.00017371098510921001 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00016988394781947136 +│ │ │ ├── duration: 0.00021384097635746002 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1409,7 +1409,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:72: TimeoutError │ │ └── teardown -│ │ ├── duration: 0.00015988294035196304 +│ │ ├── duration: 0.00017173890955746174 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_recursion_error @@ -1422,10 +1422,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00013546599075198174 +│ │ │ ├── duration: 0.00015650317072868347 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0009217811748385429 +│ │ │ ├── duration: 0.001101339003071189 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1460,7 +1460,7 @@ │ │ │ E RecursionError: maximum recursion depth exceeded │ │ │ !!! Recursion detected (same locals & position) │ │ └── teardown -│ │ ├── duration: 0.0002302350476384163 +│ │ ├── duration: 0.00014351005665957928 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_floating_point_error @@ -1473,10 +1473,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00013321894221007824 +│ │ │ ├── duration: 0.00012473389506340027 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00016312208026647568 +│ │ │ ├── duration: 0.0001532940659672022 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1495,7 +1495,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:82: FloatingPointError │ │ └── teardown -│ │ ├── duration: 0.0001657288521528244 +│ │ ├── duration: 0.00014129886403679848 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_floating_point_overflow @@ -1508,10 +1508,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0001321369782090187 +│ │ │ ├── duration: 0.00013295700773596764 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00017774594016373158 +│ │ │ ├── duration: 0.000159702030941844 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1529,7 +1529,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:86: OverflowError │ │ └── teardown -│ │ ├── duration: 0.00016633793711662292 +│ │ ├── duration: 0.00013917102478444576 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_value_error @@ -1542,10 +1542,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00012943195179104805 +│ │ │ ├── duration: 0.00012867385521531105 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00017147394828498363 +│ │ │ ├── duration: 0.00016219611279666424 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1565,7 +1565,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:90: ValueError │ │ └── teardown -│ │ ├── duration: 0.00015998096205294132 +│ │ ├── duration: 0.0001484088134020567 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_wrong_argument_error @@ -1578,10 +1578,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0001303709577769041 +│ │ │ ├── duration: 0.0001167571172118187 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001613700296729803 +│ │ │ ├── duration: 0.000151502201333642 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1599,7 +1599,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:94: TypeError │ │ └── teardown -│ │ ├── duration: 0.00015098880976438522 +│ │ ├── duration: 0.00013879919424653053 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_unhandled_exception @@ -1612,10 +1612,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0001305209007114172 +│ │ │ ├── duration: 0.00011623091995716095 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00017120898701250553 +│ │ │ ├── duration: 0.0001494050957262516 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1633,7 +1633,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:98: Exception │ │ └── teardown -│ │ ├── duration: 0.00014737690798938274 +│ │ ├── duration: 0.0001417580060660839 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_custom_error @@ -1646,10 +1646,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00013022194616496563 +│ │ │ ├── duration: 0.00011655595153570175 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00015693786554038525 +│ │ │ ├── duration: 0.00015103002078831196 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1668,7 +1668,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:102: CustomError │ │ └── teardown -│ │ ├── duration: 0.0001460961066186428 +│ │ ├── duration: 0.00014246907085180283 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_stop_iteration_direct @@ -1681,10 +1681,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00012335088104009628 +│ │ │ ├── duration: 0.00012304610572755337 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001588580198585987 +│ │ │ ├── duration: 0.0001640769187361002 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: @@ -1771,7 +1771,7 @@ │ │ │ │ │ │ cls = │ │ │ func = . at -│ │ │ 0x7f4c55fca700> +│ │ │ 0x7fe48be3c700> │ │ │ when = 'call' │ │ │ reraise = (, ) @@ -1854,7 +1854,7 @@ │ │ │ .pixi/envs/default/lib/python3.8/site-packages/_pytest/capture.p │ │ │ y:880: RuntimeError │ │ └── teardown -│ │ ├── duration: 0.0002446169964969158 +│ │ ├── duration: 0.00025580497458577156 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_generator_exit_direct @@ -1867,10 +1867,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00014816690236330032 +│ │ │ ├── duration: 0.00014240085147321224 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00016938988119363785 +│ │ │ ├── duration: 0.00020209909416735172 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1888,7 +1888,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:110: GeneratorExit │ │ └── teardown -│ │ ├── duration: 0.00016369414515793324 +│ │ ├── duration: 0.00020958180539309978 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_malformed_code @@ -1901,10 +1901,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00012634415179491043 +│ │ │ ├── duration: 0.00012465519830584526 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001717607956379652 +│ │ │ ├── duration: 0.0001744660548865795 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1928,7 +1928,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:114: SyntaxError │ │ └── teardown -│ │ ├── duration: 0.00015626591630280018 +│ │ ├── duration: 0.0001511010341346264 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_sys_exit @@ -1941,10 +1941,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00012115598656237125 +│ │ │ ├── duration: 0.00012170104309916496 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00014615105465054512 +│ │ │ ├── duration: 0.00015023606829345226 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -1962,7 +1962,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:118: SystemExit │ │ └── teardown -│ │ ├── duration: 0.00013573304750025272 +│ │ ├── duration: 0.0001453729346394539 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_broken_function @@ -1975,10 +1975,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00013293209485709667 +│ │ │ ├── duration: 0.00012337509542703629 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001556540373712778 +│ │ │ ├── duration: 0.00015427195467054844 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -2011,7 +2011,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:123: TypeError │ │ └── teardown -│ │ ├── duration: 0.0001439379993826151 +│ │ ├── duration: 0.00015054293908178806 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_import_error @@ -2024,10 +2024,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0001190828625112772 +│ │ │ ├── duration: 0.00011663511395454407 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001511040609329939 +│ │ │ ├── duration: 0.00015443307347595692 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py @@ -2044,7 +2044,7 @@ │ │ │ │ │ │ tests/test_math_utils.py:127: ImportError │ │ └── teardown -│ │ ├── duration: 0.00013555004261434078 +│ │ ├── duration: 0.00014697294682264328 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_math_utils.py::test_module_not_found_error @@ -2057,10 +2057,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00012307497672736645 +│ │ │ ├── duration: 0.00011754198931157589 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.000500907190144062 +│ │ │ ├── duration: 0.0005241041071712971 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: @@ -2108,7 +2108,7 @@ │ │ │ _ _ _ _ _ _ _ _ │ │ │ │ │ │ name = 'non_existent_module_xyz' -│ │ │ import_ = +│ │ │ import_ = │ │ │ │ │ │ > ??? │ │ │ E ModuleNotFoundError: No module named @@ -2116,7 +2116,7 @@ │ │ │ │ │ │ :973: ModuleNotFoundError │ │ └── teardown -│ │ ├── duration: 0.00014745700173079967 +│ │ ├── duration: 0.00015066401101648808 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_basic_ids @@ -2132,13 +2132,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0002564608585089445 +│ │ │ ├── duration: 0.00024648592807352543 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001402630005031824 +│ │ │ ├── duration: 0.00013936497271060944 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00012042699381709099 +│ │ ├── duration: 0.00012199999764561653 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_basic_ids @@ -2154,13 +2154,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00017943885177373886 +│ │ │ ├── duration: 0.00018452201038599014 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012480816803872585 +│ │ │ ├── duration: 0.0001278009731322527 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.000111074885353446 +│ │ ├── duration: 0.0001158041413873434 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_with_reason_and_marks @@ -2176,13 +2176,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00016471394337713718 +│ │ │ ├── duration: 0.00016426085494458675 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00013195187784731388 +│ │ │ ├── duration: 0.0001251788344234228 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00011302903294563293 +│ │ ├── duration: 0.00011022388935089111 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_with_reason_and_marks @@ -2199,12 +2199,12 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00023666396737098694 +│ │ │ ├── duration: 0.0002290019765496254 │ │ │ ├── outcome: skipped │ │ │ └── longrepr: ('/workspace/tligui_y/slic/tests/test_param.py', 12, │ │ │ 'Skipped: nope') │ │ └── teardown -│ │ ├── duration: 0.00010647205635905266 +│ │ ├── duration: 0.00011773500591516495 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_multiple_positional_args[1-2] @@ -2220,13 +2220,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00023756804876029491 +│ │ │ ├── duration: 0.00023832195438444614 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001380599569529295 +│ │ │ ├── duration: 0.00012902705930173397 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.0001255539245903492 +│ │ ├── duration: 0.0001266789622604847 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_multiple_positional_args[3-4] @@ -2242,13 +2242,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0002090800553560257 +│ │ │ ├── duration: 0.00021152803674340248 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012173294089734554 +│ │ │ ├── duration: 0.00012860819697380066 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00012042606249451637 +│ │ ├── duration: 0.00012736395001411438 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_non_literal_with_id @@ -2264,13 +2264,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0001510020811110735 +│ │ │ ├── duration: 0.00017059198580682278 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012608407996594906 +│ │ │ ├── duration: 0.00012141489423811436 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00011229491792619228 +│ │ ├── duration: 0.00011034705676138401 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_timedistance_v1 @@ -2286,13 +2286,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00024041789583861828 +│ │ │ ├── duration: 0.0002481809351593256 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012420094572007656 +│ │ │ ├── duration: 0.00012331386096775532 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.0001325008925050497 +│ │ ├── duration: 0.0001383849885314703 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_timedistance_v1 @@ -2308,13 +2308,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00024350802414119244 +│ │ │ ├── duration: 0.000254862941801548 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00013148109428584576 +│ │ │ ├── duration: 0.000124865910038352 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00013739592395722866 +│ │ ├── duration: 0.00013261218555271626 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::TestDynamic::test_sum_positive @@ -2328,7 +2328,7 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00013801106251776218 +│ │ │ ├── duration: 0.00015152012929320335 │ │ │ ├── outcome: failed │ │ │ └── longrepr: file /workspace/tligui_y/slic/tests/test_param.py, │ │ │ line 71 @@ -2345,7 +2345,7 @@ │ │ │ │ │ │ /workspace/tligui_y/slic/tests/test_param.py:71 │ │ └── teardown -│ │ ├── duration: 0.00012780609540641308 +│ │ ├── duration: 0.0001243269070982933 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_dynamic @@ -2359,13 +2359,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00018908502534031868 +│ │ │ ├── duration: 0.00018024793826043606 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00013100518845021725 +│ │ │ ├── duration: 0.00013278494589030743 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.0001158551312983036 +│ │ ├── duration: 0.00011739297769963741 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_dynamic @@ -2379,13 +2379,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00016777310520410538 +│ │ │ ├── duration: 0.00016096699982881546 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001289830543100834 +│ │ │ ├── duration: 0.00012196903117001057 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00011578202247619629 +│ │ ├── duration: 0.00011925818398594856 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_dynamic @@ -2399,13 +2399,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0001735091209411621 +│ │ │ ├── duration: 0.0001843541394919157 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012175203301012516 +│ │ │ ├── duration: 0.00014753197319805622 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00010962388478219509 +│ │ ├── duration: 0.00013431580737233162 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_element_type[\U0001f525] @@ -2419,13 +2419,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00017884699627757072 +│ │ │ ├── duration: 0.00018815393559634686 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001248528715223074 +│ │ │ ├── duration: 0.00014288397505879402 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.0001101719681173563 +│ │ ├── duration: 0.000126637052744627 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_element_type[\U0001f4a7] @@ -2439,13 +2439,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00015679583884775639 +│ │ │ ├── duration: 0.00018169288523495197 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00011923210695385933 +│ │ │ ├── duration: 0.00014170887880027294 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00011029187589883804 +│ │ ├── duration: 0.00012704799883067608 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_element_type[\U0001f30d] @@ -2459,13 +2459,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00015581399202346802 +│ │ │ ├── duration: 0.00018208217807114124 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00013045081868767738 +│ │ │ ├── duration: 0.00014093401841819286 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.0001142991241067648 +│ │ ├── duration: 0.000129257095977664 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_combination @@ -2481,13 +2481,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00020695803686976433 +│ │ │ ├── duration: 0.00023418013006448746 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012479303404688835 +│ │ │ ├── duration: 0.00014371005818247795 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00012275809422135353 +│ │ ├── duration: 0.00015111500397324562 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_combination @@ -2503,13 +2503,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00019628996960818768 +│ │ │ ├── duration: 0.00022931210696697235 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012149196118116379 +│ │ │ ├── duration: 0.00014824303798377514 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00012685800902545452 +│ │ ├── duration: 0.00014614802785217762 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_combination @@ -2525,13 +2525,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0002017670776695013 +│ │ │ ├── duration: 0.00022961199283599854 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012160604819655418 +│ │ │ ├── duration: 0.0001437189057469368 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00012005516327917576 +│ │ ├── duration: 0.0001438390463590622 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_combination @@ -2547,13 +2547,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00020254612900316715 +│ │ │ ├── duration: 0.00022813212126493454 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012808199971914291 +│ │ │ ├── duration: 0.0001525520347058773 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00013594003394246101 +│ │ ├── duration: 0.00014077592641115189 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_indirect_fixture[1] @@ -2569,13 +2569,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0002956269308924675 +│ │ │ ├── duration: 0.0003382971044629812 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00013960804790258408 +│ │ │ ├── duration: 0.00014980812557041645 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00012201815843582153 +│ │ ├── duration: 0.00012976606376469135 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_indirect_fixture[2] @@ -2591,13 +2591,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00017007696442306042 +│ │ │ ├── duration: 0.00019439798779785633 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00012628501281142235 +│ │ │ ├── duration: 0.00014423509128391743 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 0.00011258595623075962 +│ │ ├── duration: 0.00012772902846336365 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_param.py::test_addition @@ -2610,10 +2610,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00010890793055295944 +│ │ │ ├── duration: 0.0001362641341984272 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0001427019014954567 +│ │ │ ├── duration: 0.00016373186372220516 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_param.py @@ -2633,7 +2633,7 @@ │ │ │ │ │ │ tests/test_param.py:107: NameError │ │ └── teardown -│ │ ├── duration: 0.00014391308650374413 +│ │ ├── duration: 0.0001544049009680748 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_string_utils.py::test_uppercase_normal @@ -2646,13 +2646,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00012418907135725021 +│ │ │ ├── duration: 0.00014012213796377182 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00014147115871310234 +│ │ │ ├── duration: 0.00016683898866176605 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 9.957514703273773e-05 +│ │ ├── duration: 0.00011661602184176445 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_string_utils.py::test_uppercase_type_error @@ -2665,10 +2665,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00010383501648902893 +│ │ │ ├── duration: 0.0001228500623255968 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00014087790623307228 +│ │ │ ├── duration: 0.0001670739147812128 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/functions/string_utils.py @@ -2700,7 +2700,7 @@ │ │ │ │ │ │ functions/string_utils.py:3: TypeError │ │ └── teardown -│ │ ├── duration: 0.00013547600246965885 +│ │ ├── duration: 0.00014146394096314907 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_string_utils.py::test_reverse_string @@ -2713,13 +2713,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.0001162099651992321 +│ │ │ ├── duration: 0.00012062117457389832 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00015760213136672974 +│ │ │ ├── duration: 0.00014070305041968822 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 9.953719563782215e-05 +│ │ ├── duration: 0.00010410300455987453 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_string_utils.py::test_warning_emit @@ -2732,13 +2732,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00010467902757227421 +│ │ │ ├── duration: 0.00010586204007267952 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00014186184853315353 +│ │ │ ├── duration: 0.00015261489897966385 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 9.550992399454117e-05 +│ │ ├── duration: 0.00010772189125418663 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_string_utils.py::test_unicode_decode_error @@ -2751,10 +2751,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00011016312055289745 +│ │ │ ├── duration: 0.0001034389715641737 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00014436710625886917 +│ │ │ ├── duration: 0.00014473404735326767 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_string_utils.py @@ -2774,7 +2774,7 @@ │ │ │ │ │ │ tests/test_string_utils.py:28: UnicodeDecodeError │ │ └── teardown -│ │ ├── duration: 0.0001314929686486721 +│ │ ├── duration: 0.00014453288167715073 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: @@ -2788,10 +2788,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00011696713045239449 +│ │ │ ├── duration: 0.00011710496619343758 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00014984910376369953 +│ │ │ ├── duration: 0.00015011103823781013 │ │ │ ├── outcome: failed │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_string_utils.py @@ -2812,7 +2812,7 @@ │ │ │ │ │ │ tests/test_string_utils.py:32: UnicodeDecodeError │ │ └── teardown -│ │ ├── duration: 0.00013337191194295883 +│ │ ├── duration: 0.0001374951098114252 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_string_utils.py::test_import_warning @@ -2825,13 +2825,13 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00012757186777889729 +│ │ │ ├── duration: 0.00012971390970051289 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.00013442197814583778 +│ │ │ ├── duration: 0.00014096801169216633 │ │ │ └── outcome: passed │ │ └── teardown -│ │ ├── duration: 9.814510121941566e-05 +│ │ ├── duration: 0.00010313699021935463 │ │ └── outcome: passed │ ├── - │ │ ├── nodeid: tests/test_string_utils.py::test_xfail_uppercase_digits @@ -2846,10 +2846,10 @@ │ │ │ ├── slic │ │ │ └── │ │ ├── setup -│ │ │ ├── duration: 0.00011624395847320557 +│ │ │ ├── duration: 0.00011595012620091438 │ │ │ └── outcome: passed │ │ ├── call -│ │ │ ├── duration: 0.0006171560380607843 +│ │ │ ├── duration: 0.000629462068900466 │ │ │ ├── outcome: skipped │ │ │ ├── crash │ │ │ │ ├── path: /workspace/tligui_y/slic/tests/test_string_utils.py @@ -2878,7 +2878,7 @@ │ │ │ │ │ │ tests/test_string_utils.py:41: AssertionError │ │ └── teardown -│ │ ├── duration: 0.00013338192366063595 +│ │ ├── duration: 0.0001344778575003147 │ │ └── outcome: passed │ └── - │ ├── nodeid: tests/test_string_utils.py::test_keyboard_interrupt_direct @@ -2891,7 +2891,7 @@ │ │ ├── slic │ │ └── │ └── setup -│ ├── duration: 0.00012999307364225388 +│ ├── duration: 0.00011977995745837688 │ └── outcome: passed └── warnings └── - diff --git a/ci-reports/markdown/pytest-report.json b/ci-reports/markdown/pytest-report.json index 2d8c7e9ac..5123d0185 100644 --- a/ci-reports/markdown/pytest-report.json +++ b/ci-reports/markdown/pytest-report.json @@ -1 +1 @@ -{"created": 1752948532.183237, "duration": 0.7940311431884766, "exitcode": 2, "root": "/workspace/tligui_y/slic", "environment": {}, "summary": {"passed": 36, "failed": 32, "xfailed": 2, "skipped": 1, "error": 1, "total": 72, "collected": 72}, "collectors": [{"nodeid": "", "outcome": "passed", "result": [{"nodeid": ".", "type": "Dir"}]}, {"nodeid": "ci-reports/allure/data", "outcome": "passed", "result": []}, {"nodeid": "ci-reports/allure/export", "outcome": "passed", "result": []}, {"nodeid": "ci-reports/allure/history", "outcome": "passed", "result": []}, {"nodeid": "ci-reports/allure/plugin/behaviors", "outcome": "passed", "result": []}, {"nodeid": "ci-reports/allure/plugin/packages", "outcome": "passed", "result": []}, {"nodeid": "ci-reports/allure/plugin/screen-diff", "outcome": "passed", "result": []}, {"nodeid": "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"}]}, {"nodeid": "ci-reports/allure/widgets", "outcome": "passed", "result": []}, {"nodeid": "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"}]}, {"nodeid": "ci-reports/coverage", "outcome": "passed", "result": []}, {"nodeid": "ci-reports/markdown", "outcome": "passed", "result": []}, {"nodeid": "ci-reports", "outcome": "passed", "result": [{"nodeid": "ci-reports/allure", "type": "Dir"}, {"nodeid": "ci-reports/coverage", "type": "Dir"}, {"nodeid": "ci-reports/markdown", "type": "Dir"}]}, {"nodeid": "functions", "outcome": "passed", "result": []}, {"nodeid": "tests/test_broken_fct.py", "outcome": "failed", "result": [], "longrepr": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/python.py:493: in importtestmodule\n mod = import_path(\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/pathlib.py:587: in import_path\n importlib.import_module(module_name)\n.pixi/envs/default/lib/python3.8/importlib/__init__.py:127: in import_module\n return _bootstrap._gcd_import(name[level:], package, level)\n:1014: in _gcd_import\n ???\n:991: in _find_and_load\n ???\n:975: in _find_and_load_unlocked\n ???\n:671: in _load_unlocked\n ???\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/assertion/rewrite.py:175: in exec_module\n source_stat, co = _rewrite_test(fn, self.config)\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/assertion/rewrite.py:355: in _rewrite_test\n tree = ast.parse(source, filename=strfn)\n.pixi/envs/default/lib/python3.8/ast.py:47: in parse\n return compile(source, filename, mode, flags,\nE File \"/workspace/tligui_y/slic/tests/test_broken_fct.py\", line 8\nE def test_valid_2():\nE ^\nE SyntaxError: invalid syntax"}, {"nodeid": "tests/test_collector_error.py", "outcome": "failed", "result": [], "longrepr": "ImportError while importing test module '/workspace/tligui_y/slic/tests/test_collector_error.py'.\nHint: make sure your test modules/packages have valid Python names.\nTraceback:\n.pixi/envs/default/lib/python3.8/importlib/__init__.py:127: in import_module\n return _bootstrap._gcd_import(name[level:], package, level)\ntests/test_collector_error.py:1: in \n from no_existing_module.math_utils import *\nE ModuleNotFoundError: No module named 'no_existing_module'"}, {"nodeid": "tests/test_io_utils.py", "outcome": "passed", "result": [{"nodeid": "tests/test_io_utils.py::test_read_file", "type": "Function", "lineno": 9}, {"nodeid": "tests/test_io_utils.py::test_write_file", "type": "Function", "lineno": 16}, {"nodeid": "tests/test_io_utils.py::test_cause_io_error", "type": "Function", "lineno": 22}, {"nodeid": "tests/test_io_utils.py::test_file_not_found", "type": "Function", "lineno": 26}, {"nodeid": "tests/test_io_utils.py::test_permission_error", "type": "Function", "lineno": 30}, {"nodeid": "tests/test_io_utils.py::test_mock_open_error", "type": "Function", "lineno": 37}, {"nodeid": "tests/test_io_utils.py::test_file_handle_closed_error", "type": "Function", "lineno": 45}, {"nodeid": "tests/test_io_utils.py::test_os_error", "type": "Function", "lineno": 51}, {"nodeid": "tests/test_io_utils.py::test_write_file_readonly", "type": "Function", "lineno": 58}, {"nodeid": "tests/test_io_utils.py::test_file_not_found_error", "type": "Function", "lineno": 66}]}, {"nodeid": "tests/test_math_utils.py", "outcome": "passed", "result": [{"nodeid": "tests/test_math_utils.py::test_broken", "type": "Function", "lineno": 13}, {"nodeid": "tests/test_math_utils.py::test_call_missing_function", "type": "Function", "lineno": 17}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[2-2-4]", "type": "Function", "lineno": 22}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[1-5-6]", "type": "Function", "lineno": 22}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[3-4-7]", "type": "Function", "lineno": 22}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[3-5-8]", "type": "Function", "lineno": 22}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[3-6-9]", "type": "Function", "lineno": 22}, {"nodeid": "tests/test_math_utils.py::test_addition_pass_id[a=2,b=2,expected=4]", "type": "Function", "lineno": 36}, {"nodeid": "tests/test_math_utils.py::test_addition_pass_id[a=1,b=5,expected=6]", "type": "Function", "lineno": 36}, {"nodeid": "tests/test_math_utils.py::test_addition_pass_id[a=3,b=4,expected=7]", "type": "Function", "lineno": 36}, {"nodeid": "tests/test_math_utils.py::test_addition_fail", "type": "Function", "lineno": 48}, {"nodeid": "tests/test_math_utils.py::test_division_zero", "type": "Function", "lineno": 52}, {"nodeid": "tests/test_math_utils.py::test_multiply_xfail", "type": "Function", "lineno": 56}, {"nodeid": "tests/test_math_utils.py::test_runtime_error", "type": "Function", "lineno": 61}, {"nodeid": "tests/test_math_utils.py::test_memory_error", "type": "Function", "lineno": 65}, {"nodeid": "tests/test_math_utils.py::test_timeout_error", "type": "Function", "lineno": 69}, {"nodeid": "tests/test_math_utils.py::test_recursion_error", "type": "Function", "lineno": 73}, {"nodeid": "tests/test_math_utils.py::test_floating_point_error", "type": "Function", "lineno": 79}, {"nodeid": "tests/test_math_utils.py::test_floating_point_overflow", "type": "Function", "lineno": 83}, {"nodeid": "tests/test_math_utils.py::test_value_error", "type": "Function", "lineno": 87}, {"nodeid": "tests/test_math_utils.py::test_wrong_argument_error", "type": "Function", "lineno": 91}, {"nodeid": "tests/test_math_utils.py::test_unhandled_exception", "type": "Function", "lineno": 95}, {"nodeid": "tests/test_math_utils.py::test_custom_error", "type": "Function", "lineno": 99}, {"nodeid": "tests/test_math_utils.py::test_stop_iteration_direct", "type": "Function", "lineno": 103}, {"nodeid": "tests/test_math_utils.py::test_generator_exit_direct", "type": "Function", "lineno": 107}, {"nodeid": "tests/test_math_utils.py::test_malformed_code", "type": "Function", "lineno": 111}, {"nodeid": "tests/test_math_utils.py::test_sys_exit", "type": "Function", "lineno": 115}, {"nodeid": "tests/test_math_utils.py::test_broken_function", "type": "Function", "lineno": 119}, {"nodeid": "tests/test_math_utils.py::test_import_error", "type": "Function", "lineno": 125}, {"nodeid": "tests/test_math_utils.py::test_module_not_found_error", "type": "Function", "lineno": 128}]}, {"nodeid": "tests/test_param.py::TestDynamic", "outcome": "passed", "result": [{"nodeid": "tests/test_param.py::TestDynamic::test_sum_positive", "type": "Function", "lineno": 70}]}, {"nodeid": "tests/test_param.py", "outcome": "passed", "result": [{"nodeid": "tests/test_param.py::test_basic_ids[one]", "type": "Function", "lineno": 3}, {"nodeid": "tests/test_param.py::test_basic_ids[two]", "type": "Function", "lineno": 3}, {"nodeid": "tests/test_param.py::test_with_reason_and_marks[ten]", "type": "Function", "lineno": 11}, {"nodeid": "tests/test_param.py::test_with_reason_and_marks[twenty]", "type": "Function", "lineno": 11}, {"nodeid": "tests/test_param.py::test_multiple_positional_args[1-2]", "type": "Function", "lineno": 19}, {"nodeid": "tests/test_param.py::test_multiple_positional_args[3-4]", "type": "Function", "lineno": 19}, {"nodeid": "tests/test_param.py::test_non_literal_with_id[custom-obj]", "type": "Function", "lineno": 27}, {"nodeid": "tests/test_param.py::test_timedistance_v1[a0-b0-expected0]", "type": "Function", "lineno": 40}, {"nodeid": "tests/test_param.py::test_timedistance_v1[a1-b1-expected1]", "type": "Function", "lineno": 40}, {"nodeid": "tests/test_param.py::TestDynamic", "type": "Class"}, {"nodeid": "tests/test_param.py::test_dynamic[ten]", "type": "Function", "lineno": 78}, {"nodeid": "tests/test_param.py::test_dynamic[twenty]", "type": "Function", "lineno": 78}, {"nodeid": "tests/test_param.py::test_dynamic[thirty]", "type": "Function", "lineno": 78}, {"nodeid": "tests/test_param.py::test_element_type[\\U0001f525]", "type": "Function", "lineno": 87}, {"nodeid": "tests/test_param.py::test_element_type[\\U0001f4a7]", "type": "Function", "lineno": 87}, {"nodeid": "tests/test_param.py::test_element_type[\\U0001f30d]", "type": "Function", "lineno": 87}, {"nodeid": "tests/test_param.py::test_combination[a-1]", "type": "Function", "lineno": 90}, {"nodeid": "tests/test_param.py::test_combination[a-2]", "type": "Function", "lineno": 90}, {"nodeid": "tests/test_param.py::test_combination[b-1]", "type": "Function", "lineno": 90}, {"nodeid": "tests/test_param.py::test_combination[b-2]", "type": "Function", "lineno": 90}, {"nodeid": "tests/test_param.py::test_indirect_fixture[1]", "type": "Function", "lineno": 100}, {"nodeid": "tests/test_param.py::test_indirect_fixture[2]", "type": "Function", "lineno": 100}, {"nodeid": "tests/test_param.py::test_addition", "type": "Function", "lineno": 104}]}, {"nodeid": "tests/test_string_utils.py", "outcome": "passed", "result": [{"nodeid": "tests/test_string_utils.py::test_uppercase_normal", "type": "Function", "lineno": 9}, {"nodeid": "tests/test_string_utils.py::test_uppercase_type_error", "type": "Function", "lineno": 13}, {"nodeid": "tests/test_string_utils.py::test_reverse_string", "type": "Function", "lineno": 17}, {"nodeid": "tests/test_string_utils.py::test_warning_emit", "type": "Function", "lineno": 21}, {"nodeid": "tests/test_string_utils.py::test_unicode_decode_error", "type": "Function", "lineno": 25}, {"nodeid": "tests/test_string_utils.py::test_unicode_decode_surrogateescape", "type": "Function", "lineno": 29}, {"nodeid": "tests/test_string_utils.py::test_import_warning", "type": "Function", "lineno": 33}, {"nodeid": "tests/test_string_utils.py::test_xfail_uppercase_digits", "type": "Function", "lineno": 37}, {"nodeid": "tests/test_string_utils.py::test_keyboard_interrupt_direct", "type": "Function", "lineno": 49}]}, {"nodeid": "tests", "outcome": "passed", "result": [{"nodeid": "tests/test_broken_fct.py", "type": "Module"}, {"nodeid": "tests/test_collector_error.py", "type": "Module"}, {"nodeid": "tests/test_io_utils.py", "type": "Module"}, {"nodeid": "tests/test_math_utils.py", "type": "Module"}, {"nodeid": "tests/test_param.py", "type": "Module"}, {"nodeid": "tests/test_string_utils.py", "type": "Module"}]}, {"nodeid": ".", "outcome": "passed", "result": [{"nodeid": "ci-reports", "type": "Dir"}, {"nodeid": "functions", "type": "Package"}, {"nodeid": "tests", "type": "Dir"}]}], "tests": [{"nodeid": "tests/test_io_utils.py::test_read_file", "lineno": 9, "outcome": "passed", "keywords": ["test_read_file", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0035927039571106434, "outcome": "passed"}, "call": {"duration": 0.000526093877851963, "outcome": "passed"}, "teardown": {"duration": 0.00026531191542744637, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_write_file", "lineno": 16, "outcome": "passed", "keywords": ["test_write_file", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0005024520214647055, "outcome": "passed"}, "call": {"duration": 0.0003082759212702513, "outcome": "passed"}, "teardown": {"duration": 0.00015172897838056087, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_cause_io_error", "lineno": 22, "outcome": "failed", "keywords": ["test_cause_io_error", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00011634896509349346, "outcome": "passed"}, "call": {"duration": 0.00015770108439028263, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/functions/io_utils.py", "lineno": 10, "message": "OSError: Forced IO Error for testing"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 25, "message": ""}, {"path": "functions/io_utils.py", "lineno": 10, "message": "OSError"}], "longrepr": "def test_cause_io_error():\n # Raises manual IOError to simulate IO failure\n> cause_io_error()\n\ntests/test_io_utils.py:25: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\n def cause_io_error():\n> raise IOError(\"Forced IO Error for testing\")\nE OSError: Forced IO Error for testing\n\nfunctions/io_utils.py:10: OSError"}, "teardown": {"duration": 0.00014807004481554031, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_file_not_found", "lineno": 26, "outcome": "failed", "keywords": ["test_file_not_found", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012230011634528637, "outcome": "passed"}, "call": {"duration": 0.00018097716383635998, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/functions/io_utils.py", "lineno": 2, "message": "FileNotFoundError: [Errno 2] No such file or directory: 'nonexistent.file'"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 29, "message": ""}, {"path": "functions/io_utils.py", "lineno": 2, "message": "FileNotFoundError"}], "longrepr": "def test_file_not_found():\n # Reading non-existing file raises FileNotFoundError\n> read_file(\"nonexistent.file\")\n\ntests/test_io_utils.py:29: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\npath = 'nonexistent.file'\n\n def read_file(path):\n> with open(path, \"r\", encoding=\"utf-8\") as f:\nE FileNotFoundError: [Errno 2] No such file or directory: 'nonexistent.file'\n\nfunctions/io_utils.py:2: FileNotFoundError"}, "teardown": {"duration": 0.0001414688304066658, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_permission_error", "lineno": 30, "outcome": "failed", "keywords": ["test_permission_error", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00021795183420181274, "outcome": "passed"}, "call": {"duration": 0.00017540506087243557, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_io_utils.py", "lineno": 34, "message": "PermissionError: Permission denied"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 36, "message": ""}, {"path": "functions/io_utils.py", "lineno": 2, "message": "in read_file"}, {"path": "tests/test_io_utils.py", "lineno": 34, "message": "PermissionError"}], "longrepr": "monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7f4c5582d8b0>\n\n def test_permission_error(monkeypatch):\n # Patch open to raise PermissionError simulating access denial\n def raise_perm_error(*args, **kwargs):\n raise PermissionError(\"Permission denied\")\n monkeypatch.setattr(\"builtins.open\", raise_perm_error)\n> read_file(\"anyfile.txt\")\n\ntests/test_io_utils.py:36: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \nfunctions/io_utils.py:2: in read_file\n with open(path, \"r\", encoding=\"utf-8\") as f:\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\nargs = ('anyfile.txt', 'r'), kwargs = {'encoding': 'utf-8'}\n\n def raise_perm_error(*args, **kwargs):\n> raise PermissionError(\"Permission denied\")\nE PermissionError: Permission denied\n\ntests/test_io_utils.py:34: PermissionError"}, "teardown": {"duration": 0.00017365510575473309, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_mock_open_error", "lineno": 37, "outcome": "failed", "keywords": ["test_mock_open_error", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0002115289680659771, "outcome": "passed"}, "call": {"duration": 0.003329366911202669, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/unittest/mock.py", "lineno": 1140, "message": "OSError: Mocked IOError"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 43, "message": ""}, {"path": ".pixi/envs/default/lib/python3.8/unittest/mock.py", "lineno": 1081, "message": "in __call__"}, {"path": ".pixi/envs/default/lib/python3.8/unittest/mock.py", "lineno": 1085, "message": "in _mock_call"}, {"path": ".pixi/envs/default/lib/python3.8/unittest/mock.py", "lineno": 1140, "message": "OSError"}], "longrepr": "monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7f4c55de1430>\n\n def test_mock_open_error(monkeypatch):\n # Mock open() to raise IOError simulating read error\n mocked_open = mock.mock_open()\n mocked_open.side_effect = IOError(\"Mocked IOError\")\n monkeypatch.setattr(\"builtins.open\", mocked_open)\n> with open(\"file.txt\", \"r\") as f:\n\ntests/test_io_utils.py:43: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n.pixi/envs/default/lib/python3.8/unittest/mock.py:1081: in __call__\n return self._mock_call(*args, **kwargs)\n.pixi/envs/default/lib/python3.8/unittest/mock.py:1085: in _mock_call\n return self._execute_mock_call(*args, **kwargs)\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\nself = \nargs = ('file.txt', 'r'), kwargs = {}, effect = OSError('Mocked IOError')\n\n def _execute_mock_call(self, /, *args, **kwargs):\n # separate from _increment_mock_call so that awaited functions are\n # executed separately from their call, also AsyncMock overrides this method\n \n effect = self.side_effect\n if effect is not None:\n if _is_exception(effect):\n> raise effect\nE OSError: Mocked IOError\n\n.pixi/envs/default/lib/python3.8/unittest/mock.py:1140: OSError"}, "teardown": {"duration": 0.0003329480532556772, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_file_handle_closed_error", "lineno": 45, "outcome": "failed", "keywords": ["test_file_handle_closed_error", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00015738513320684433, "outcome": "passed"}, "call": {"duration": 0.00019312603399157524, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_io_utils.py", "lineno": 50, "message": "ValueError: I/O operation on closed file"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 50, "message": "ValueError"}], "longrepr": "def test_file_handle_closed_error():\n # Accessing closed file raises ValueError\n f = io.StringIO(\"content\")\n f.close()\n> f.read()\nE ValueError: I/O operation on closed file\n\ntests/test_io_utils.py:50: ValueError"}, "teardown": {"duration": 0.00020414497703313828, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_os_error", "lineno": 51, "outcome": "failed", "keywords": ["test_os_error", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0004144669510424137, "outcome": "passed"}, "call": {"duration": 0.00035541201941668987, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_io_utils.py", "lineno": 55, "message": "OSError: Simulated OSError"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 57, "message": ""}, {"path": "tests/test_io_utils.py", "lineno": 55, "message": "OSError"}], "longrepr": "monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7f4c55af8df0>\n\n def test_os_error(monkeypatch):\n # Patch os.remove to raise OSError simulating filesystem error\n def raise_os_error(path):\n raise OSError(\"Simulated OSError\")\n monkeypatch.setattr(\"os.remove\", raise_os_error)\n> os.remove(\"file.txt\")\n\ntests/test_io_utils.py:57: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\npath = 'file.txt'\n\n def raise_os_error(path):\n> raise OSError(\"Simulated OSError\")\nE OSError: Simulated OSError\n\ntests/test_io_utils.py:55: OSError"}, "teardown": {"duration": 0.0002219120506197214, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_write_file_readonly", "lineno": 58, "outcome": "passed", "keywords": ["test_write_file_readonly", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.000756068853661418, "outcome": "passed"}, "call": {"duration": 0.0009601230267435312, "outcome": "passed"}, "teardown": {"duration": 0.00016189506277441978, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_file_not_found_error", "lineno": 66, "outcome": "failed", "keywords": ["test_file_not_found_error", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012234714813530445, "outcome": "passed"}, "call": {"duration": 0.0001760418526828289, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_io_utils.py", "lineno": 69, "message": "FileNotFoundError: [Errno 2] No such file or directory: 'no_such_file.txt'"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 69, "message": "FileNotFoundError"}], "longrepr": "def test_file_not_found_error():\n # Raises FileNotFoundError when opening a non-existent file\n> open(\"no_such_file.txt\", \"r\")\nE FileNotFoundError: [Errno 2] No such file or directory: 'no_such_file.txt'\n\ntests/test_io_utils.py:69: FileNotFoundError"}, "teardown": {"duration": 0.00014961999841034412, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_broken", "lineno": 13, "outcome": "failed", "keywords": ["test_broken", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00013265199959278107, "outcome": "passed"}, "call": {"duration": 0.0001613690983504057, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 16, "message": "NameError: name 'want_the_test_to_fail' is not defined"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 16, "message": "NameError"}], "longrepr": "def test_broken():\n # simulating a broken or faulty test implementation that will cause the test to error\n> want_the_test_to_fail\nE NameError: name 'want_the_test_to_fail' is not defined\n\ntests/test_math_utils.py:16: NameError"}, "teardown": {"duration": 0.00013866997323930264, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_call_missing_function", "lineno": 17, "outcome": "failed", "keywords": ["test_call_missing_function", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012383703142404556, "outcome": "passed"}, "call": {"duration": 0.00016052485443651676, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 20, "message": "AttributeError: module 'functions.math_utils' has no attribute 'non_existent_function'"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 20, "message": "AttributeError"}], "longrepr": "def test_call_missing_function():\n # Accessing a missing function attribute raises AttributeError\n> getattr(math_utils, \"non_existent_function\")()\nE AttributeError: module 'functions.math_utils' has no attribute 'non_existent_function'\n\ntests/test_math_utils.py:20: AttributeError"}, "teardown": {"duration": 0.00017554312944412231, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[2-2-4]", "lineno": 22, "outcome": "passed", "keywords": ["test_addition_pass[2-2-4]", "parametrize", "pytestmark", "2-2-4", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00036273710429668427, "outcome": "passed"}, "call": {"duration": 0.0001532949972897768, "outcome": "passed"}, "teardown": {"duration": 0.00017221900634467602, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[1-5-6]", "lineno": 22, "outcome": "passed", "keywords": ["test_addition_pass[1-5-6]", "parametrize", "pytestmark", "1-5-6", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0002844491973519325, "outcome": "passed"}, "call": {"duration": 0.0001386650837957859, "outcome": "passed"}, "teardown": {"duration": 0.00013803690671920776, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[3-4-7]", "lineno": 22, "outcome": "passed", "keywords": ["test_addition_pass[3-4-7]", "parametrize", "pytestmark", "3-4-7", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0002601540181785822, "outcome": "passed"}, "call": {"duration": 0.00013089808635413647, "outcome": "passed"}, "teardown": {"duration": 0.00014615198597311974, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[3-5-8]", "lineno": 22, "outcome": "passed", "keywords": ["test_addition_pass[3-5-8]", "parametrize", "pytestmark", "3-5-8", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00023687095381319523, "outcome": "passed"}, "call": {"duration": 0.00012945802882313728, "outcome": "passed"}, "teardown": {"duration": 0.0001453279983252287, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[3-6-9]", "lineno": 22, "outcome": "passed", "keywords": ["test_addition_pass[3-6-9]", "parametrize", "pytestmark", "3-6-9", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00024129683151841164, "outcome": "passed"}, "call": {"duration": 0.00012711412273347378, "outcome": "passed"}, "teardown": {"duration": 0.00014471192844212055, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass_id[a=2,b=2,expected=4]", "lineno": 36, "outcome": "passed", "keywords": ["test_addition_pass_id[a=2,b=2,expected=4]", "parametrize", "pytestmark", "a=2,b=2,expected=4", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0002531129866838455, "outcome": "passed"}, "call": {"duration": 0.0001280789729207754, "outcome": "passed"}, "teardown": {"duration": 0.00014358898624777794, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass_id[a=1,b=5,expected=6]", "lineno": 36, "outcome": "passed", "keywords": ["test_addition_pass_id[a=1,b=5,expected=6]", "parametrize", "pytestmark", "a=1,b=5,expected=6", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0002494649961590767, "outcome": "passed"}, "call": {"duration": 0.00012943311594426632, "outcome": "passed"}, "teardown": {"duration": 0.00013888697139918804, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass_id[a=3,b=4,expected=7]", "lineno": 36, "outcome": "passed", "keywords": ["test_addition_pass_id[a=3,b=4,expected=7]", "parametrize", "pytestmark", "a=3,b=4,expected=7", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00023560202680528164, "outcome": "passed"}, "call": {"duration": 0.00012493785470724106, "outcome": "passed"}, "teardown": {"duration": 0.00013893586583435535, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_fail", "lineno": 48, "outcome": "failed", "keywords": ["test_addition_fail", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00010590208694338799, "outcome": "passed"}, "call": {"duration": 0.0005099500995129347, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 51, "message": "assert 4 == 5\n + where 4 = addition(2, 2)"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 51, "message": "AssertionError"}], "longrepr": "def test_addition_fail():\n # Assertion failure: expected incorrect result\n> assert addition(2, 2) == 5\nE assert 4 == 5\nE + where 4 = addition(2, 2)\n\ntests/test_math_utils.py:51: AssertionError"}, "teardown": {"duration": 0.00014958903193473816, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_division_zero", "lineno": 52, "outcome": "failed", "keywords": ["test_division_zero", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012248707935214043, "outcome": "passed"}, "call": {"duration": 0.00016648508608341217, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/functions/math_utils.py", "lineno": 5, "message": "ZeroDivisionError: division by zero"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 55, "message": ""}, {"path": "functions/math_utils.py", "lineno": 5, "message": "ZeroDivisionError"}], "longrepr": "def test_division_zero():\n # Will raise ZeroDivisionError if not handled in division\n> division(1, 0)\n\ntests/test_math_utils.py:55: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\na = 1, b = 0\n\n def division(a, b):\n> return a / b\nE ZeroDivisionError: division by zero\n\nfunctions/math_utils.py:5: ZeroDivisionError"}, "teardown": {"duration": 0.00016888114623725414, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_multiply_xfail", "lineno": 56, "outcome": "xfailed", "keywords": ["test_multiply_xfail", "xfail", "pytestmark", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00014091609045863152, "outcome": "passed"}, "call": {"duration": 0.0002776370383799076, "outcome": "skipped", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 60, "message": "assert 4 == 5\n + where 4 = multiply(2, 2)"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 60, "message": "AssertionError"}], "longrepr": "@pytest.mark.xfail(reason=\"Expected failure\")\n def test_multiply_xfail():\n # Expected fail test (xfail): incorrect expected multiply result\n> assert multiply(2, 2) == 5\nE assert 4 == 5\nE + where 4 = multiply(2, 2)\n\ntests/test_math_utils.py:60: AssertionError"}, "teardown": {"duration": 0.00013629603199660778, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_runtime_error", "lineno": 61, "outcome": "failed", "keywords": ["test_runtime_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012237997725605965, "outcome": "passed"}, "call": {"duration": 0.00017202692106366158, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 64, "message": "RuntimeError: Forced runtime error"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 64, "message": "RuntimeError"}], "longrepr": "def test_runtime_error():\n # Test raises an uncaught RuntimeError\n> raise RuntimeError(\"Forced runtime error\")\nE RuntimeError: Forced runtime error\n\ntests/test_math_utils.py:64: RuntimeError"}, "teardown": {"duration": 0.000144279096275568, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_memory_error", "lineno": 65, "outcome": "failed", "keywords": ["test_memory_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00013360311277210712, "outcome": "passed"}, "call": {"duration": 0.00017066486179828644, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 68, "message": "MemoryError: Simulated memory error"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 68, "message": "MemoryError"}], "longrepr": "def test_memory_error():\n # Manually raise MemoryError to simulate out-of-memory condition\n> raise MemoryError(\"Simulated memory error\")\nE MemoryError: Simulated memory error\n\ntests/test_math_utils.py:68: MemoryError"}, "teardown": {"duration": 0.00015691807493567467, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_timeout_error", "lineno": 69, "outcome": "failed", "keywords": ["test_timeout_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00013270904310047626, "outcome": "passed"}, "call": {"duration": 0.00016988394781947136, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 72, "message": "TimeoutError: Simulated timeout error"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 72, "message": "TimeoutError"}], "longrepr": "def test_timeout_error():\n # Manually raise TimeoutError simulating timeout conditions\n> raise TimeoutError(\"Simulated timeout error\")\nE TimeoutError: Simulated timeout error\n\ntests/test_math_utils.py:72: TimeoutError"}, "teardown": {"duration": 0.00015988294035196304, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_recursion_error", "lineno": 73, "outcome": "failed", "keywords": ["test_recursion_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00013546599075198174, "outcome": "passed"}, "call": {"duration": 0.0009217811748385429, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 77, "message": "RecursionError: maximum recursion depth exceeded"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 78, "message": ""}, {"path": "tests/test_math_utils.py", "lineno": 77, "message": "in recursive"}, {"path": "tests/test_math_utils.py", "lineno": 77, "message": "in recursive"}], "longrepr": "def test_recursion_error():\n # Infinite recursion triggers RecursionError\n def recursive():\n return recursive()\n> recursive()\n\ntests/test_math_utils.py:78: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \ntests/test_math_utils.py:77: in recursive\n return recursive()\ntests/test_math_utils.py:77: in recursive\n return recursive()\nE RecursionError: maximum recursion depth exceeded\n!!! Recursion detected (same locals & position)"}, "teardown": {"duration": 0.0002302350476384163, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_floating_point_error", "lineno": 79, "outcome": "failed", "keywords": ["test_floating_point_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00013321894221007824, "outcome": "passed"}, "call": {"duration": 0.00016312208026647568, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 82, "message": "FloatingPointError: Simulated floating point error"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 82, "message": "FloatingPointError"}], "longrepr": "def test_floating_point_error():\n # Manually raise FloatingPointError\n> raise FloatingPointError(\"Simulated floating point error\")\nE FloatingPointError: Simulated floating point error\n\ntests/test_math_utils.py:82: FloatingPointError"}, "teardown": {"duration": 0.0001657288521528244, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_floating_point_overflow", "lineno": 83, "outcome": "failed", "keywords": ["test_floating_point_overflow", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0001321369782090187, "outcome": "passed"}, "call": {"duration": 0.00017774594016373158, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 86, "message": "OverflowError: math range error"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 86, "message": "OverflowError"}], "longrepr": "def test_floating_point_overflow():\n # Exponential overflow triggers OverflowError\n> math.exp(1000)\nE OverflowError: math range error\n\ntests/test_math_utils.py:86: OverflowError"}, "teardown": {"duration": 0.00016633793711662292, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_value_error", "lineno": 87, "outcome": "failed", "keywords": ["test_value_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012943195179104805, "outcome": "passed"}, "call": {"duration": 0.00017147394828498363, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 90, "message": "ValueError: invalid literal for int() with base 10: 'invalid'"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 90, "message": "ValueError"}], "longrepr": "def test_value_error():\n # ValueError on invalid integer conversion\n> int(\"invalid\")\nE ValueError: invalid literal for int() with base 10: 'invalid'\n\ntests/test_math_utils.py:90: ValueError"}, "teardown": {"duration": 0.00015998096205294132, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_wrong_argument_error", "lineno": 91, "outcome": "failed", "keywords": ["test_wrong_argument_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0001303709577769041, "outcome": "passed"}, "call": {"duration": 0.0001613700296729803, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 94, "message": "TypeError: 'int' object is not iterable"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 94, "message": "TypeError"}], "longrepr": "def test_wrong_argument_error():\n # TypeError when passing wrong argument type to sum\n> sum(5)\nE TypeError: 'int' object is not iterable\n\ntests/test_math_utils.py:94: TypeError"}, "teardown": {"duration": 0.00015098880976438522, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_unhandled_exception", "lineno": 95, "outcome": "failed", "keywords": ["test_unhandled_exception", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0001305209007114172, "outcome": "passed"}, "call": {"duration": 0.00017120898701250553, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 98, "message": "Exception: Generic unhandled exception"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 98, "message": "Exception"}], "longrepr": "def test_unhandled_exception():\n # Raises generic unhandled Exception\n> raise Exception(\"Generic unhandled exception\")\nE Exception: Generic unhandled exception\n\ntests/test_math_utils.py:98: Exception"}, "teardown": {"duration": 0.00014737690798938274, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_custom_error", "lineno": 99, "outcome": "failed", "keywords": ["test_custom_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00013022194616496563, "outcome": "passed"}, "call": {"duration": 0.00015693786554038525, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 102, "message": "test_math_utils.CustomError: Custom error simulation"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 102, "message": "CustomError"}], "longrepr": "def test_custom_error():\n # Raises user-defined CustomError exception\n> raise CustomError(\"Custom error simulation\")\nE test_math_utils.CustomError: Custom error simulation\n\ntests/test_math_utils.py:102: CustomError"}, "teardown": {"duration": 0.0001460961066186428, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_stop_iteration_direct", "lineno": 103, "outcome": "failed", "keywords": ["test_stop_iteration_direct", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012335088104009628, "outcome": "passed"}, "call": {"duration": 0.0001588580198585987, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/_pytest/capture.py", "lineno": 880, "message": "RuntimeError: generator raised StopIteration"}, "traceback": [{"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/runner.py", "lineno": 341, "message": ""}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/runner.py", "lineno": 242, "message": "in "}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/pluggy/_hooks.py", "lineno": 513, "message": "in __call__"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/pluggy/_manager.py", "lineno": 120, "message": "in _hookexec"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/threadexception.py", "lineno": 92, "message": "in pytest_runtest_call"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/threadexception.py", "lineno": 68, "message": "in thread_exception_runtest_hook"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/unraisableexception.py", "lineno": 95, "message": "in pytest_runtest_call"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/unraisableexception.py", "lineno": 70, "message": "in unraisable_exception_runtest_hook"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/logging.py", "lineno": 846, "message": "in pytest_runtest_call"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/logging.py", "lineno": 829, "message": "in _runtest_for"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/capture.py", "lineno": 880, "message": "RuntimeError"}], "longrepr": "def test_stop_iteration_direct():\n # Directly raise StopIteration exception\n> raise StopIteration()\nE StopIteration\n\ntests/test_math_utils.py:106: StopIteration\n\nThe above exception was the direct cause of the following exception:\n\ncls = \nfunc = . at 0x7f4c55fca700>\nwhen = 'call'\nreraise = (, )\n\n @classmethod\n def from_call(\n cls,\n func: Callable[[], TResult],\n when: Literal[\"collect\", \"setup\", \"call\", \"teardown\"],\n reraise: type[BaseException] | tuple[type[BaseException], ...] | None = None,\n ) -> CallInfo[TResult]:\n \"\"\"Call func, wrapping the result in a CallInfo.\n \n :param func:\n The function to call. Called without arguments.\n :type func: Callable[[], _pytest.runner.TResult]\n :param when:\n The phase in which the function is called.\n :param reraise:\n Exception or exceptions that shall propagate if raised by the\n function, instead of being wrapped in the CallInfo.\n \"\"\"\n excinfo = None\n start = timing.time()\n precise_start = timing.perf_counter()\n try:\n> result: TResult | None = func()\n\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/runner.py:341: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n.pixi/envs/default/lib/python3.8/site-packages/_pytest/runner.py:242: in \n lambda: runtest_hook(item=item, **kwds), when=when, reraise=reraise\n.pixi/envs/default/lib/python3.8/site-packages/pluggy/_hooks.py:513: in __call__\n return self._hookexec(self.name, self._hookimpls.copy(), kwargs, firstresult)\n.pixi/envs/default/lib/python3.8/site-packages/pluggy/_manager.py:120: in _hookexec\n return self._inner_hookexec(hook_name, methods, kwargs, firstresult)\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/threadexception.py:92: in pytest_runtest_call\n yield from thread_exception_runtest_hook()\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/threadexception.py:68: in thread_exception_runtest_hook\n yield\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/unraisableexception.py:95: in pytest_runtest_call\n yield from unraisable_exception_runtest_hook()\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/unraisableexception.py:70: in unraisable_exception_runtest_hook\n yield\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/logging.py:846: in pytest_runtest_call\n yield from self._runtest_for(item, \"call\")\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/logging.py:829: in _runtest_for\n yield\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\nself = _capture_fixture=None>\nitem = \n\n @hookimpl(wrapper=True)\n def pytest_runtest_call(self, item: Item) -> Generator[None]:\n with self.item_capture(\"call\", item):\n> return (yield)\nE RuntimeError: generator raised StopIteration\n\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/capture.py:880: RuntimeError"}, "teardown": {"duration": 0.0002446169964969158, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_generator_exit_direct", "lineno": 107, "outcome": "failed", "keywords": ["test_generator_exit_direct", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00014816690236330032, "outcome": "passed"}, "call": {"duration": 0.00016938988119363785, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 110, "message": "GeneratorExit"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 110, "message": "GeneratorExit"}], "longrepr": "def test_generator_exit_direct():\n # Directly raise GeneratorExit exception\n> raise GeneratorExit()\nE GeneratorExit\n\ntests/test_math_utils.py:110: GeneratorExit"}, "teardown": {"duration": 0.00016369414515793324, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_malformed_code", "lineno": 111, "outcome": "failed", "keywords": ["test_malformed_code", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012634415179491043, "outcome": "passed"}, "call": {"duration": 0.0001717607956379652, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 114, "message": " File \"\", line 1\n def bad(:\n ^\nSyntaxError: invalid syntax"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 114, "message": "SyntaxError"}], "longrepr": "def test_malformed_code():\n # SyntaxError when executing malformed Python code\n> exec(\"def bad(:\\n pass\")\nE File \"\", line 1\nE def bad(:\nE ^\nE SyntaxError: invalid syntax\n\ntests/test_math_utils.py:114: SyntaxError"}, "teardown": {"duration": 0.00015626591630280018, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_sys_exit", "lineno": 115, "outcome": "failed", "keywords": ["test_sys_exit", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012115598656237125, "outcome": "passed"}, "call": {"duration": 0.00014615105465054512, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 118, "message": "SystemExit: 1"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 118, "message": "SystemExit"}], "longrepr": "def test_sys_exit():\n # Simulate SystemExit via sys.exit\n> sys.exit(1)\nE SystemExit: 1\n\ntests/test_math_utils.py:118: SystemExit"}, "teardown": {"duration": 0.00013573304750025272, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_broken_function", "lineno": 119, "outcome": "failed", "keywords": ["test_broken_function", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00013293209485709667, "outcome": "passed"}, "call": {"duration": 0.0001556540373712778, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 123, "message": "TypeError: Broken function"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 124, "message": ""}, {"path": "tests/test_math_utils.py", "lineno": 123, "message": "TypeError"}], "longrepr": "def test_broken_function():\n # Simulate broken function raising TypeError\n def broken_func(*args, **kwargs):\n raise TypeError(\"Broken function\")\n> broken_func()\n\ntests/test_math_utils.py:124: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\nargs = (), kwargs = {}\n\n def broken_func(*args, **kwargs):\n> raise TypeError(\"Broken function\")\nE TypeError: Broken function\n\ntests/test_math_utils.py:123: TypeError"}, "teardown": {"duration": 0.0001439379993826151, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_import_error", "lineno": 125, "outcome": "failed", "keywords": ["test_import_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0001190828625112772, "outcome": "passed"}, "call": {"duration": 0.0001511040609329939, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 127, "message": "ImportError: Simulated ImportError"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 127, "message": "ImportError"}], "longrepr": "def test_import_error():\n> raise ImportError(\"Simulated ImportError\")\nE ImportError: Simulated ImportError\n\ntests/test_math_utils.py:127: ImportError"}, "teardown": {"duration": 0.00013555004261434078, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_module_not_found_error", "lineno": 128, "outcome": "failed", "keywords": ["test_module_not_found_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012307497672736645, "outcome": "passed"}, "call": {"duration": 0.000500907190144062, "outcome": "failed", "crash": {"path": "", "lineno": 973, "message": "ModuleNotFoundError: No module named 'non_existent_module_xyz'"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 131, "message": ""}, {"path": ".pixi/envs/default/lib/python3.8/importlib/__init__.py", "lineno": 127, "message": "in import_module"}, {"path": "", "lineno": 1014, "message": "in _gcd_import"}, {"path": "", "lineno": 991, "message": "in _find_and_load"}, {"path": "", "lineno": 973, "message": "ModuleNotFoundError"}], "longrepr": "def test_module_not_found_error():\n # Raises ModuleNotFoundError (subclass of ImportError) for missing module\n> importlib.import_module(\"non_existent_module_xyz\")\n\ntests/test_math_utils.py:131: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n.pixi/envs/default/lib/python3.8/importlib/__init__.py:127: in import_module\n return _bootstrap._gcd_import(name[level:], package, level)\n:1014: in _gcd_import\n ???\n:991: in _find_and_load\n ???\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\nname = 'non_existent_module_xyz'\nimport_ = \n\n> ???\nE ModuleNotFoundError: No module named 'non_existent_module_xyz'\n\n:973: ModuleNotFoundError"}, "teardown": {"duration": 0.00014745700173079967, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_basic_ids[one]", "lineno": 3, "outcome": "passed", "keywords": ["test_basic_ids[one]", "parametrize", "pytestmark", "one", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.0002564608585089445, "outcome": "passed"}, "call": {"duration": 0.0001402630005031824, "outcome": "passed"}, "teardown": {"duration": 0.00012042699381709099, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_basic_ids[two]", "lineno": 3, "outcome": "passed", "keywords": ["test_basic_ids[two]", "parametrize", "pytestmark", "two", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00017943885177373886, "outcome": "passed"}, "call": {"duration": 0.00012480816803872585, "outcome": "passed"}, "teardown": {"duration": 0.000111074885353446, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_with_reason_and_marks[ten]", "lineno": 11, "outcome": "passed", "keywords": ["test_with_reason_and_marks[ten]", "parametrize", "pytestmark", "ten", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00016471394337713718, "outcome": "passed"}, "call": {"duration": 0.00013195187784731388, "outcome": "passed"}, "teardown": {"duration": 0.00011302903294563293, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_with_reason_and_marks[twenty]", "lineno": 11, "outcome": "skipped", "keywords": ["test_with_reason_and_marks[twenty]", "parametrize", "skip", "pytestmark", "twenty", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00023666396737098694, "outcome": "skipped", "longrepr": "('/workspace/tligui_y/slic/tests/test_param.py', 12, 'Skipped: nope')"}, "teardown": {"duration": 0.00010647205635905266, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_multiple_positional_args[1-2]", "lineno": 19, "outcome": "passed", "keywords": ["test_multiple_positional_args[1-2]", "parametrize", "pytestmark", "1-2", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00023756804876029491, "outcome": "passed"}, "call": {"duration": 0.0001380599569529295, "outcome": "passed"}, "teardown": {"duration": 0.0001255539245903492, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_multiple_positional_args[3-4]", "lineno": 19, "outcome": "passed", "keywords": ["test_multiple_positional_args[3-4]", "parametrize", "pytestmark", "3-4", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.0002090800553560257, "outcome": "passed"}, "call": {"duration": 0.00012173294089734554, "outcome": "passed"}, "teardown": {"duration": 0.00012042606249451637, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_non_literal_with_id[custom-obj]", "lineno": 27, "outcome": "passed", "keywords": ["test_non_literal_with_id[custom-obj]", "parametrize", "pytestmark", "custom-obj", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.0001510020811110735, "outcome": "passed"}, "call": {"duration": 0.00012608407996594906, "outcome": "passed"}, "teardown": {"duration": 0.00011229491792619228, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_timedistance_v1[a0-b0-expected0]", "lineno": 40, "outcome": "passed", "keywords": ["test_timedistance_v1[a0-b0-expected0]", "parametrize", "pytestmark", "a0-b0-expected0", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00024041789583861828, "outcome": "passed"}, "call": {"duration": 0.00012420094572007656, "outcome": "passed"}, "teardown": {"duration": 0.0001325008925050497, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_timedistance_v1[a1-b1-expected1]", "lineno": 40, "outcome": "passed", "keywords": ["test_timedistance_v1[a1-b1-expected1]", "parametrize", "pytestmark", "a1-b1-expected1", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00024350802414119244, "outcome": "passed"}, "call": {"duration": 0.00013148109428584576, "outcome": "passed"}, "teardown": {"duration": 0.00013739592395722866, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::TestDynamic::test_sum_positive", "lineno": 70, "outcome": "error", "keywords": ["test_sum_positive", "TestDynamic", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00013801106251776218, "outcome": "failed", "longrepr": "file /workspace/tligui_y/slic/tests/test_param.py, line 71\n def test_sum_positive(self, x, y):\nE fixture 'x' not found\n> available fixtures: cache, capfd, capfdbinary, caplog, capsys, capsysbinary, complex_setup, cov, doctest_namespace, element, extra, extras, include_metadata_in_junit_xml, json_metadata, metadata, monkeypatch, no_cover, pytestconfig, record_property, record_testsuite_property, record_xml_attribute, recwarn, tmp_path, tmp_path_factory, tmpdir, tmpdir_factory\n> use 'pytest --fixtures [testpath]' for help on them.\n\n/workspace/tligui_y/slic/tests/test_param.py:71"}, "teardown": {"duration": 0.00012780609540641308, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_dynamic[ten]", "lineno": 78, "outcome": "passed", "keywords": ["test_dynamic[ten]", "ten", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00018908502534031868, "outcome": "passed"}, "call": {"duration": 0.00013100518845021725, "outcome": "passed"}, "teardown": {"duration": 0.0001158551312983036, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_dynamic[twenty]", "lineno": 78, "outcome": "passed", "keywords": ["test_dynamic[twenty]", "twenty", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00016777310520410538, "outcome": "passed"}, "call": {"duration": 0.0001289830543100834, "outcome": "passed"}, "teardown": {"duration": 0.00011578202247619629, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_dynamic[thirty]", "lineno": 78, "outcome": "passed", "keywords": ["test_dynamic[thirty]", "thirty", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.0001735091209411621, "outcome": "passed"}, "call": {"duration": 0.00012175203301012516, "outcome": "passed"}, "teardown": {"duration": 0.00010962388478219509, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_element_type[\\U0001f525]", "lineno": 87, "outcome": "passed", "keywords": ["test_element_type[\\U0001f525]", "\\U0001f525", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00017884699627757072, "outcome": "passed"}, "call": {"duration": 0.0001248528715223074, "outcome": "passed"}, "teardown": {"duration": 0.0001101719681173563, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_element_type[\\U0001f4a7]", "lineno": 87, "outcome": "passed", "keywords": ["test_element_type[\\U0001f4a7]", "\\U0001f4a7", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00015679583884775639, "outcome": "passed"}, "call": {"duration": 0.00011923210695385933, "outcome": "passed"}, "teardown": {"duration": 0.00011029187589883804, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_element_type[\\U0001f30d]", "lineno": 87, "outcome": "passed", "keywords": ["test_element_type[\\U0001f30d]", "\\U0001f30d", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00015581399202346802, "outcome": "passed"}, "call": {"duration": 0.00013045081868767738, "outcome": "passed"}, "teardown": {"duration": 0.0001142991241067648, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_combination[a-1]", "lineno": 90, "outcome": "passed", "keywords": ["test_combination[a-1]", "parametrize", "pytestmark", "a-1", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00020695803686976433, "outcome": "passed"}, "call": {"duration": 0.00012479303404688835, "outcome": "passed"}, "teardown": {"duration": 0.00012275809422135353, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_combination[a-2]", "lineno": 90, "outcome": "passed", "keywords": ["test_combination[a-2]", "parametrize", "pytestmark", "a-2", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00019628996960818768, "outcome": "passed"}, "call": {"duration": 0.00012149196118116379, "outcome": "passed"}, "teardown": {"duration": 0.00012685800902545452, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_combination[b-1]", "lineno": 90, "outcome": "passed", "keywords": ["test_combination[b-1]", "parametrize", "pytestmark", "b-1", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.0002017670776695013, "outcome": "passed"}, "call": {"duration": 0.00012160604819655418, "outcome": "passed"}, "teardown": {"duration": 0.00012005516327917576, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_combination[b-2]", "lineno": 90, "outcome": "passed", "keywords": ["test_combination[b-2]", "parametrize", "pytestmark", "b-2", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00020254612900316715, "outcome": "passed"}, "call": {"duration": 0.00012808199971914291, "outcome": "passed"}, "teardown": {"duration": 0.00013594003394246101, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_indirect_fixture[1]", "lineno": 100, "outcome": "passed", "keywords": ["test_indirect_fixture[1]", "parametrize", "pytestmark", "1", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.0002956269308924675, "outcome": "passed"}, "call": {"duration": 0.00013960804790258408, "outcome": "passed"}, "teardown": {"duration": 0.00012201815843582153, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_indirect_fixture[2]", "lineno": 100, "outcome": "passed", "keywords": ["test_indirect_fixture[2]", "parametrize", "pytestmark", "2", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00017007696442306042, "outcome": "passed"}, "call": {"duration": 0.00012628501281142235, "outcome": "passed"}, "teardown": {"duration": 0.00011258595623075962, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_addition", "lineno": 104, "outcome": "failed", "keywords": ["test_addition", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00010890793055295944, "outcome": "passed"}, "call": {"duration": 0.0001427019014954567, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_param.py", "lineno": 107, "message": "NameError: name 'addition' is not defined"}, "traceback": [{"path": "tests/test_param.py", "lineno": 107, "message": "NameError"}], "longrepr": "a = 5, b = 5, expected = 10\n\n def test_addition(a = 5, b = 5, expected = 10):\n # Has to pass\n> assert addition(a, b) == expected\nE NameError: name 'addition' is not defined\n\ntests/test_param.py:107: NameError"}, "teardown": {"duration": 0.00014391308650374413, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_uppercase_normal", "lineno": 9, "outcome": "passed", "keywords": ["test_uppercase_normal", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012418907135725021, "outcome": "passed"}, "call": {"duration": 0.00014147115871310234, "outcome": "passed"}, "teardown": {"duration": 9.957514703273773e-05, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_uppercase_type_error", "lineno": 13, "outcome": "failed", "keywords": ["test_uppercase_type_error", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00010383501648902893, "outcome": "passed"}, "call": {"duration": 0.00014087790623307228, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/functions/string_utils.py", "lineno": 3, "message": "TypeError: Input cannot be None"}, "traceback": [{"path": "tests/test_string_utils.py", "lineno": 16, "message": ""}, {"path": "functions/string_utils.py", "lineno": 3, "message": "TypeError"}], "longrepr": "def test_uppercase_type_error():\n # TypeError when input is None (invalid input)\n> uppercase(None)\n\ntests/test_string_utils.py:16: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\ns = None\n\n def uppercase(s):\n if s is None:\n> raise TypeError(\"Input cannot be None\")\nE TypeError: Input cannot be None\n\nfunctions/string_utils.py:3: TypeError"}, "teardown": {"duration": 0.00013547600246965885, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_reverse_string", "lineno": 17, "outcome": "passed", "keywords": ["test_reverse_string", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0001162099651992321, "outcome": "passed"}, "call": {"duration": 0.00015760213136672974, "outcome": "passed"}, "teardown": {"duration": 9.953719563782215e-05, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_warning_emit", "lineno": 21, "outcome": "passed", "keywords": ["test_warning_emit", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00010467902757227421, "outcome": "passed"}, "call": {"duration": 0.00014186184853315353, "outcome": "passed"}, "teardown": {"duration": 9.550992399454117e-05, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_unicode_decode_error", "lineno": 25, "outcome": "failed", "keywords": ["test_unicode_decode_error", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00011016312055289745, "outcome": "passed"}, "call": {"duration": 0.00014436710625886917, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_string_utils.py", "lineno": 28, "message": "UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte"}, "traceback": [{"path": "tests/test_string_utils.py", "lineno": 28, "message": "UnicodeDecodeError"}], "longrepr": "def test_unicode_decode_error():\n # UnicodeDecodeError when decoding invalid byte sequence\n> b'\\xff'.decode('utf-8')\nE UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte\n\ntests/test_string_utils.py:28: UnicodeDecodeError"}, "teardown": {"duration": 0.0001314929686486721, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_unicode_decode_surrogateescape", "lineno": 29, "outcome": "failed", "keywords": ["test_unicode_decode_surrogateescape", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00011696713045239449, "outcome": "passed"}, "call": {"duration": 0.00014984910376369953, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_string_utils.py", "lineno": 32, "message": "UnicodeDecodeError: 'utf-8' codec can't decode byte 0x80 in position 0: invalid start byte"}, "traceback": [{"path": "tests/test_string_utils.py", "lineno": 32, "message": "UnicodeDecodeError"}], "longrepr": "def test_unicode_decode_surrogateescape():\n # UnicodeDecodeError with strict error handler on invalid byte\n> b\"\\x80\".decode(\"utf-8\", errors=\"strict\")\nE UnicodeDecodeError: 'utf-8' codec can't decode byte 0x80 in position 0: invalid start byte\n\ntests/test_string_utils.py:32: UnicodeDecodeError"}, "teardown": {"duration": 0.00013337191194295883, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_import_warning", "lineno": 33, "outcome": "passed", "keywords": ["test_import_warning", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012757186777889729, "outcome": "passed"}, "call": {"duration": 0.00013442197814583778, "outcome": "passed"}, "teardown": {"duration": 9.814510121941566e-05, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_xfail_uppercase_digits", "lineno": 37, "outcome": "xfailed", "keywords": ["test_xfail_uppercase_digits", "xfail", "pytestmark", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00011624395847320557, "outcome": "passed"}, "call": {"duration": 0.0006171560380607843, "outcome": "skipped", "crash": {"path": "/workspace/tligui_y/slic/tests/test_string_utils.py", "lineno": 41, "message": "AssertionError: assert 'ABC123' == 'ABC1234'\n \n - ABC1234\n ? -\n + ABC123"}, "traceback": [{"path": "tests/test_string_utils.py", "lineno": 41, "message": "AssertionError"}], "longrepr": "@pytest.mark.xfail(reason=\"Expected failure: uppercase does not handle digits\")\n def test_xfail_uppercase_digits():\n # Expected fail test because uppercase won't change digits\n> assert uppercase(\"abc123\") == \"ABC1234\"\nE AssertionError: assert 'ABC123' == 'ABC1234'\nE \nE - ABC1234\nE ? -\nE + ABC123\n\ntests/test_string_utils.py:41: AssertionError"}, "teardown": {"duration": 0.00013338192366063595, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_keyboard_interrupt_direct", "lineno": 49, "outcome": "passed", "keywords": ["test_keyboard_interrupt_direct", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012999307364225388, "outcome": "passed"}}], "warnings": [{"message": "Test warning", "category": "UserWarning", "when": "runtest", "filename": "/workspace/tligui_y/slic/tests/test_string_utils.py", "lineno": 24}]} \ No newline at end of file +{"created": 1752948651.896282, "duration": 0.8480584621429443, "exitcode": 2, "root": "/workspace/tligui_y/slic", "environment": {}, "summary": {"passed": 36, "failed": 32, "xfailed": 2, "skipped": 1, "error": 1, "total": 72, "collected": 72}, "collectors": [{"nodeid": "", "outcome": "passed", "result": [{"nodeid": ".", "type": "Dir"}]}, {"nodeid": "ci-reports/allure/data", "outcome": "passed", "result": []}, {"nodeid": "ci-reports/allure/export", "outcome": "passed", "result": []}, {"nodeid": "ci-reports/allure/history", "outcome": "passed", "result": []}, {"nodeid": "ci-reports/allure/plugin/behaviors", "outcome": "passed", "result": []}, {"nodeid": "ci-reports/allure/plugin/packages", "outcome": "passed", "result": []}, {"nodeid": "ci-reports/allure/plugin/screen-diff", "outcome": "passed", "result": []}, {"nodeid": "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"}]}, {"nodeid": "ci-reports/allure/widgets", "outcome": "passed", "result": []}, {"nodeid": "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"}]}, {"nodeid": "ci-reports/coverage", "outcome": "passed", "result": []}, {"nodeid": "ci-reports/markdown", "outcome": "passed", "result": []}, {"nodeid": "ci-reports", "outcome": "passed", "result": [{"nodeid": "ci-reports/allure", "type": "Dir"}, {"nodeid": "ci-reports/coverage", "type": "Dir"}, {"nodeid": "ci-reports/markdown", "type": "Dir"}]}, {"nodeid": "functions", "outcome": "passed", "result": []}, {"nodeid": "tests/test_broken_fct.py", "outcome": "failed", "result": [], "longrepr": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/python.py:493: in importtestmodule\n mod = import_path(\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/pathlib.py:587: in import_path\n importlib.import_module(module_name)\n.pixi/envs/default/lib/python3.8/importlib/__init__.py:127: in import_module\n return _bootstrap._gcd_import(name[level:], package, level)\n:1014: in _gcd_import\n ???\n:991: in _find_and_load\n ???\n:975: in _find_and_load_unlocked\n ???\n:671: in _load_unlocked\n ???\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/assertion/rewrite.py:175: in exec_module\n source_stat, co = _rewrite_test(fn, self.config)\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/assertion/rewrite.py:355: in _rewrite_test\n tree = ast.parse(source, filename=strfn)\n.pixi/envs/default/lib/python3.8/ast.py:47: in parse\n return compile(source, filename, mode, flags,\nE File \"/workspace/tligui_y/slic/tests/test_broken_fct.py\", line 8\nE def test_valid_2():\nE ^\nE SyntaxError: invalid syntax"}, {"nodeid": "tests/test_collector_error.py", "outcome": "failed", "result": [], "longrepr": "ImportError while importing test module '/workspace/tligui_y/slic/tests/test_collector_error.py'.\nHint: make sure your test modules/packages have valid Python names.\nTraceback:\n.pixi/envs/default/lib/python3.8/importlib/__init__.py:127: in import_module\n return _bootstrap._gcd_import(name[level:], package, level)\ntests/test_collector_error.py:1: in \n from no_existing_module.math_utils import *\nE ModuleNotFoundError: No module named 'no_existing_module'"}, {"nodeid": "tests/test_io_utils.py", "outcome": "passed", "result": [{"nodeid": "tests/test_io_utils.py::test_read_file", "type": "Function", "lineno": 9}, {"nodeid": "tests/test_io_utils.py::test_write_file", "type": "Function", "lineno": 16}, {"nodeid": "tests/test_io_utils.py::test_cause_io_error", "type": "Function", "lineno": 22}, {"nodeid": "tests/test_io_utils.py::test_file_not_found", "type": "Function", "lineno": 26}, {"nodeid": "tests/test_io_utils.py::test_permission_error", "type": "Function", "lineno": 30}, {"nodeid": "tests/test_io_utils.py::test_mock_open_error", "type": "Function", "lineno": 37}, {"nodeid": "tests/test_io_utils.py::test_file_handle_closed_error", "type": "Function", "lineno": 45}, {"nodeid": "tests/test_io_utils.py::test_os_error", "type": "Function", "lineno": 51}, {"nodeid": "tests/test_io_utils.py::test_write_file_readonly", "type": "Function", "lineno": 58}, {"nodeid": "tests/test_io_utils.py::test_file_not_found_error", "type": "Function", "lineno": 66}]}, {"nodeid": "tests/test_math_utils.py", "outcome": "passed", "result": [{"nodeid": "tests/test_math_utils.py::test_broken", "type": "Function", "lineno": 13}, {"nodeid": "tests/test_math_utils.py::test_call_missing_function", "type": "Function", "lineno": 17}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[2-2-4]", "type": "Function", "lineno": 22}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[1-5-6]", "type": "Function", "lineno": 22}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[3-4-7]", "type": "Function", "lineno": 22}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[3-5-8]", "type": "Function", "lineno": 22}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[3-6-9]", "type": "Function", "lineno": 22}, {"nodeid": "tests/test_math_utils.py::test_addition_pass_id[a=2,b=2,expected=4]", "type": "Function", "lineno": 36}, {"nodeid": "tests/test_math_utils.py::test_addition_pass_id[a=1,b=5,expected=6]", "type": "Function", "lineno": 36}, {"nodeid": "tests/test_math_utils.py::test_addition_pass_id[a=3,b=4,expected=7]", "type": "Function", "lineno": 36}, {"nodeid": "tests/test_math_utils.py::test_addition_fail", "type": "Function", "lineno": 48}, {"nodeid": "tests/test_math_utils.py::test_division_zero", "type": "Function", "lineno": 52}, {"nodeid": "tests/test_math_utils.py::test_multiply_xfail", "type": "Function", "lineno": 56}, {"nodeid": "tests/test_math_utils.py::test_runtime_error", "type": "Function", "lineno": 61}, {"nodeid": "tests/test_math_utils.py::test_memory_error", "type": "Function", "lineno": 65}, {"nodeid": "tests/test_math_utils.py::test_timeout_error", "type": "Function", "lineno": 69}, {"nodeid": "tests/test_math_utils.py::test_recursion_error", "type": "Function", "lineno": 73}, {"nodeid": "tests/test_math_utils.py::test_floating_point_error", "type": "Function", "lineno": 79}, {"nodeid": "tests/test_math_utils.py::test_floating_point_overflow", "type": "Function", "lineno": 83}, {"nodeid": "tests/test_math_utils.py::test_value_error", "type": "Function", "lineno": 87}, {"nodeid": "tests/test_math_utils.py::test_wrong_argument_error", "type": "Function", "lineno": 91}, {"nodeid": "tests/test_math_utils.py::test_unhandled_exception", "type": "Function", "lineno": 95}, {"nodeid": "tests/test_math_utils.py::test_custom_error", "type": "Function", "lineno": 99}, {"nodeid": "tests/test_math_utils.py::test_stop_iteration_direct", "type": "Function", "lineno": 103}, {"nodeid": "tests/test_math_utils.py::test_generator_exit_direct", "type": "Function", "lineno": 107}, {"nodeid": "tests/test_math_utils.py::test_malformed_code", "type": "Function", "lineno": 111}, {"nodeid": "tests/test_math_utils.py::test_sys_exit", "type": "Function", "lineno": 115}, {"nodeid": "tests/test_math_utils.py::test_broken_function", "type": "Function", "lineno": 119}, {"nodeid": "tests/test_math_utils.py::test_import_error", "type": "Function", "lineno": 125}, {"nodeid": "tests/test_math_utils.py::test_module_not_found_error", "type": "Function", "lineno": 128}]}, {"nodeid": "tests/test_param.py::TestDynamic", "outcome": "passed", "result": [{"nodeid": "tests/test_param.py::TestDynamic::test_sum_positive", "type": "Function", "lineno": 70}]}, {"nodeid": "tests/test_param.py", "outcome": "passed", "result": [{"nodeid": "tests/test_param.py::test_basic_ids[one]", "type": "Function", "lineno": 3}, {"nodeid": "tests/test_param.py::test_basic_ids[two]", "type": "Function", "lineno": 3}, {"nodeid": "tests/test_param.py::test_with_reason_and_marks[ten]", "type": "Function", "lineno": 11}, {"nodeid": "tests/test_param.py::test_with_reason_and_marks[twenty]", "type": "Function", "lineno": 11}, {"nodeid": "tests/test_param.py::test_multiple_positional_args[1-2]", "type": "Function", "lineno": 19}, {"nodeid": "tests/test_param.py::test_multiple_positional_args[3-4]", "type": "Function", "lineno": 19}, {"nodeid": "tests/test_param.py::test_non_literal_with_id[custom-obj]", "type": "Function", "lineno": 27}, {"nodeid": "tests/test_param.py::test_timedistance_v1[a0-b0-expected0]", "type": "Function", "lineno": 40}, {"nodeid": "tests/test_param.py::test_timedistance_v1[a1-b1-expected1]", "type": "Function", "lineno": 40}, {"nodeid": "tests/test_param.py::TestDynamic", "type": "Class"}, {"nodeid": "tests/test_param.py::test_dynamic[ten]", "type": "Function", "lineno": 78}, {"nodeid": "tests/test_param.py::test_dynamic[twenty]", "type": "Function", "lineno": 78}, {"nodeid": "tests/test_param.py::test_dynamic[thirty]", "type": "Function", "lineno": 78}, {"nodeid": "tests/test_param.py::test_element_type[\\U0001f525]", "type": "Function", "lineno": 87}, {"nodeid": "tests/test_param.py::test_element_type[\\U0001f4a7]", "type": "Function", "lineno": 87}, {"nodeid": "tests/test_param.py::test_element_type[\\U0001f30d]", "type": "Function", "lineno": 87}, {"nodeid": "tests/test_param.py::test_combination[a-1]", "type": "Function", "lineno": 90}, {"nodeid": "tests/test_param.py::test_combination[a-2]", "type": "Function", "lineno": 90}, {"nodeid": "tests/test_param.py::test_combination[b-1]", "type": "Function", "lineno": 90}, {"nodeid": "tests/test_param.py::test_combination[b-2]", "type": "Function", "lineno": 90}, {"nodeid": "tests/test_param.py::test_indirect_fixture[1]", "type": "Function", "lineno": 100}, {"nodeid": "tests/test_param.py::test_indirect_fixture[2]", "type": "Function", "lineno": 100}, {"nodeid": "tests/test_param.py::test_addition", "type": "Function", "lineno": 104}]}, {"nodeid": "tests/test_string_utils.py", "outcome": "passed", "result": [{"nodeid": "tests/test_string_utils.py::test_uppercase_normal", "type": "Function", "lineno": 9}, {"nodeid": "tests/test_string_utils.py::test_uppercase_type_error", "type": "Function", "lineno": 13}, {"nodeid": "tests/test_string_utils.py::test_reverse_string", "type": "Function", "lineno": 17}, {"nodeid": "tests/test_string_utils.py::test_warning_emit", "type": "Function", "lineno": 21}, {"nodeid": "tests/test_string_utils.py::test_unicode_decode_error", "type": "Function", "lineno": 25}, {"nodeid": "tests/test_string_utils.py::test_unicode_decode_surrogateescape", "type": "Function", "lineno": 29}, {"nodeid": "tests/test_string_utils.py::test_import_warning", "type": "Function", "lineno": 33}, {"nodeid": "tests/test_string_utils.py::test_xfail_uppercase_digits", "type": "Function", "lineno": 37}, {"nodeid": "tests/test_string_utils.py::test_keyboard_interrupt_direct", "type": "Function", "lineno": 49}]}, {"nodeid": "tests", "outcome": "passed", "result": [{"nodeid": "tests/test_broken_fct.py", "type": "Module"}, {"nodeid": "tests/test_collector_error.py", "type": "Module"}, {"nodeid": "tests/test_io_utils.py", "type": "Module"}, {"nodeid": "tests/test_math_utils.py", "type": "Module"}, {"nodeid": "tests/test_param.py", "type": "Module"}, {"nodeid": "tests/test_string_utils.py", "type": "Module"}]}, {"nodeid": ".", "outcome": "passed", "result": [{"nodeid": "ci-reports", "type": "Dir"}, {"nodeid": "functions", "type": "Package"}, {"nodeid": "tests", "type": "Dir"}]}], "tests": [{"nodeid": "tests/test_io_utils.py::test_read_file", "lineno": 9, "outcome": "passed", "keywords": ["test_read_file", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.003604339901357889, "outcome": "passed"}, "call": {"duration": 0.0004480029456317425, "outcome": "passed"}, "teardown": {"duration": 0.0002537360414862633, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_write_file", "lineno": 16, "outcome": "passed", "keywords": ["test_write_file", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0004862810019403696, "outcome": "passed"}, "call": {"duration": 0.00029212585650384426, "outcome": "passed"}, "teardown": {"duration": 0.00014290818944573402, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_cause_io_error", "lineno": 22, "outcome": "failed", "keywords": ["test_cause_io_error", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00011350912973284721, "outcome": "passed"}, "call": {"duration": 0.00016173208132386208, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/functions/io_utils.py", "lineno": 10, "message": "OSError: Forced IO Error for testing"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 25, "message": ""}, {"path": "functions/io_utils.py", "lineno": 10, "message": "OSError"}], "longrepr": "def test_cause_io_error():\n # Raises manual IOError to simulate IO failure\n> cause_io_error()\n\ntests/test_io_utils.py:25: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\n def cause_io_error():\n> raise IOError(\"Forced IO Error for testing\")\nE OSError: Forced IO Error for testing\n\nfunctions/io_utils.py:10: OSError"}, "teardown": {"duration": 0.00014455104246735573, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_file_not_found", "lineno": 26, "outcome": "failed", "keywords": ["test_file_not_found", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0001225059386342764, "outcome": "passed"}, "call": {"duration": 0.00018438906408846378, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/functions/io_utils.py", "lineno": 2, "message": "FileNotFoundError: [Errno 2] No such file or directory: 'nonexistent.file'"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 29, "message": ""}, {"path": "functions/io_utils.py", "lineno": 2, "message": "FileNotFoundError"}], "longrepr": "def test_file_not_found():\n # Reading non-existing file raises FileNotFoundError\n> read_file(\"nonexistent.file\")\n\ntests/test_io_utils.py:29: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\npath = 'nonexistent.file'\n\n def read_file(path):\n> with open(path, \"r\", encoding=\"utf-8\") as f:\nE FileNotFoundError: [Errno 2] No such file or directory: 'nonexistent.file'\n\nfunctions/io_utils.py:2: FileNotFoundError"}, "teardown": {"duration": 0.0001413370482623577, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_permission_error", "lineno": 30, "outcome": "failed", "keywords": ["test_permission_error", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00020894501358270645, "outcome": "passed"}, "call": {"duration": 0.0001769110094755888, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_io_utils.py", "lineno": 34, "message": "PermissionError: Permission denied"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 36, "message": ""}, {"path": "functions/io_utils.py", "lineno": 2, "message": "in read_file"}, {"path": "tests/test_io_utils.py", "lineno": 34, "message": "PermissionError"}], "longrepr": "monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7fe48ba5c730>\n\n def test_permission_error(monkeypatch):\n # Patch open to raise PermissionError simulating access denial\n def raise_perm_error(*args, **kwargs):\n raise PermissionError(\"Permission denied\")\n monkeypatch.setattr(\"builtins.open\", raise_perm_error)\n> read_file(\"anyfile.txt\")\n\ntests/test_io_utils.py:36: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \nfunctions/io_utils.py:2: in read_file\n with open(path, \"r\", encoding=\"utf-8\") as f:\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\nargs = ('anyfile.txt', 'r'), kwargs = {'encoding': 'utf-8'}\n\n def raise_perm_error(*args, **kwargs):\n> raise PermissionError(\"Permission denied\")\nE PermissionError: Permission denied\n\ntests/test_io_utils.py:34: PermissionError"}, "teardown": {"duration": 0.00016919593326747417, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_mock_open_error", "lineno": 37, "outcome": "failed", "keywords": ["test_mock_open_error", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00018884195014834404, "outcome": "passed"}, "call": {"duration": 0.003317840164527297, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/unittest/mock.py", "lineno": 1140, "message": "OSError: Mocked IOError"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 43, "message": ""}, {"path": ".pixi/envs/default/lib/python3.8/unittest/mock.py", "lineno": 1081, "message": "in __call__"}, {"path": ".pixi/envs/default/lib/python3.8/unittest/mock.py", "lineno": 1085, "message": "in _mock_call"}, {"path": ".pixi/envs/default/lib/python3.8/unittest/mock.py", "lineno": 1140, "message": "OSError"}], "longrepr": "monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7fe48bf96580>\n\n def test_mock_open_error(monkeypatch):\n # Mock open() to raise IOError simulating read error\n mocked_open = mock.mock_open()\n mocked_open.side_effect = IOError(\"Mocked IOError\")\n monkeypatch.setattr(\"builtins.open\", mocked_open)\n> with open(\"file.txt\", \"r\") as f:\n\ntests/test_io_utils.py:43: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n.pixi/envs/default/lib/python3.8/unittest/mock.py:1081: in __call__\n return self._mock_call(*args, **kwargs)\n.pixi/envs/default/lib/python3.8/unittest/mock.py:1085: in _mock_call\n return self._execute_mock_call(*args, **kwargs)\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\nself = \nargs = ('file.txt', 'r'), kwargs = {}, effect = OSError('Mocked IOError')\n\n def _execute_mock_call(self, /, *args, **kwargs):\n # separate from _increment_mock_call so that awaited functions are\n # executed separately from their call, also AsyncMock overrides this method\n \n effect = self.side_effect\n if effect is not None:\n if _is_exception(effect):\n> raise effect\nE OSError: Mocked IOError\n\n.pixi/envs/default/lib/python3.8/unittest/mock.py:1140: OSError"}, "teardown": {"duration": 0.0003249498549848795, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_file_handle_closed_error", "lineno": 45, "outcome": "failed", "keywords": ["test_file_handle_closed_error", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0001420220360159874, "outcome": "passed"}, "call": {"duration": 0.00019976194016635418, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_io_utils.py", "lineno": 50, "message": "ValueError: I/O operation on closed file"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 50, "message": "ValueError"}], "longrepr": "def test_file_handle_closed_error():\n # Accessing closed file raises ValueError\n f = io.StringIO(\"content\")\n f.close()\n> f.read()\nE ValueError: I/O operation on closed file\n\ntests/test_io_utils.py:50: ValueError"}, "teardown": {"duration": 0.00022178702056407928, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_os_error", "lineno": 51, "outcome": "failed", "keywords": ["test_os_error", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0002899088431149721, "outcome": "passed"}, "call": {"duration": 0.0002075729425996542, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_io_utils.py", "lineno": 55, "message": "OSError: Simulated OSError"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 57, "message": ""}, {"path": "tests/test_io_utils.py", "lineno": 55, "message": "OSError"}], "longrepr": "monkeypatch = <_pytest.monkeypatch.MonkeyPatch object at 0x7fe48bd63df0>\n\n def test_os_error(monkeypatch):\n # Patch os.remove to raise OSError simulating filesystem error\n def raise_os_error(path):\n raise OSError(\"Simulated OSError\")\n monkeypatch.setattr(\"os.remove\", raise_os_error)\n> os.remove(\"file.txt\")\n\ntests/test_io_utils.py:57: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\npath = 'file.txt'\n\n def raise_os_error(path):\n> raise OSError(\"Simulated OSError\")\nE OSError: Simulated OSError\n\ntests/test_io_utils.py:55: OSError"}, "teardown": {"duration": 0.00022788089700043201, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_write_file_readonly", "lineno": 58, "outcome": "passed", "keywords": ["test_write_file_readonly", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0007142920512706041, "outcome": "passed"}, "call": {"duration": 0.001015444053336978, "outcome": "passed"}, "teardown": {"duration": 0.00017233891412615776, "outcome": "passed"}}, {"nodeid": "tests/test_io_utils.py::test_file_not_found_error", "lineno": 66, "outcome": "failed", "keywords": ["test_file_not_found_error", "test_io_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012602703645825386, "outcome": "passed"}, "call": {"duration": 0.00017937691882252693, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_io_utils.py", "lineno": 69, "message": "FileNotFoundError: [Errno 2] No such file or directory: 'no_such_file.txt'"}, "traceback": [{"path": "tests/test_io_utils.py", "lineno": 69, "message": "FileNotFoundError"}], "longrepr": "def test_file_not_found_error():\n # Raises FileNotFoundError when opening a non-existent file\n> open(\"no_such_file.txt\", \"r\")\nE FileNotFoundError: [Errno 2] No such file or directory: 'no_such_file.txt'\n\ntests/test_io_utils.py:69: FileNotFoundError"}, "teardown": {"duration": 0.00015364610590040684, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_broken", "lineno": 13, "outcome": "failed", "keywords": ["test_broken", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0001313758548349142, "outcome": "passed"}, "call": {"duration": 0.00018263398669660091, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 16, "message": "NameError: name 'want_the_test_to_fail' is not defined"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 16, "message": "NameError"}], "longrepr": "def test_broken():\n # simulating a broken or faulty test implementation that will cause the test to error\n> want_the_test_to_fail\nE NameError: name 'want_the_test_to_fail' is not defined\n\ntests/test_math_utils.py:16: NameError"}, "teardown": {"duration": 0.0001646790187805891, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_call_missing_function", "lineno": 17, "outcome": "failed", "keywords": ["test_call_missing_function", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0001314510591328144, "outcome": "passed"}, "call": {"duration": 0.00016825087368488312, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 20, "message": "AttributeError: module 'functions.math_utils' has no attribute 'non_existent_function'"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 20, "message": "AttributeError"}], "longrepr": "def test_call_missing_function():\n # Accessing a missing function attribute raises AttributeError\n> getattr(math_utils, \"non_existent_function\")()\nE AttributeError: module 'functions.math_utils' has no attribute 'non_existent_function'\n\ntests/test_math_utils.py:20: AttributeError"}, "teardown": {"duration": 0.00016052508726716042, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[2-2-4]", "lineno": 22, "outcome": "passed", "keywords": ["test_addition_pass[2-2-4]", "parametrize", "pytestmark", "2-2-4", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00032585300505161285, "outcome": "passed"}, "call": {"duration": 0.0001634808722883463, "outcome": "passed"}, "teardown": {"duration": 0.00015774089843034744, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[1-5-6]", "lineno": 22, "outcome": "passed", "keywords": ["test_addition_pass[1-5-6]", "parametrize", "pytestmark", "1-5-6", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0002747410908341408, "outcome": "passed"}, "call": {"duration": 0.00013548205606639385, "outcome": "passed"}, "teardown": {"duration": 0.00014509703032672405, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[3-4-7]", "lineno": 22, "outcome": "passed", "keywords": ["test_addition_pass[3-4-7]", "parametrize", "pytestmark", "3-4-7", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0002529288176447153, "outcome": "passed"}, "call": {"duration": 0.00013421406038105488, "outcome": "passed"}, "teardown": {"duration": 0.0001374860294163227, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[3-5-8]", "lineno": 22, "outcome": "passed", "keywords": ["test_addition_pass[3-5-8]", "parametrize", "pytestmark", "3-5-8", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00023582903668284416, "outcome": "passed"}, "call": {"duration": 0.00013056606985628605, "outcome": "passed"}, "teardown": {"duration": 0.00013513397425413132, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass[3-6-9]", "lineno": 22, "outcome": "passed", "keywords": ["test_addition_pass[3-6-9]", "parametrize", "pytestmark", "3-6-9", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00024592899717390537, "outcome": "passed"}, "call": {"duration": 0.00012610689736902714, "outcome": "passed"}, "teardown": {"duration": 0.00013228505849838257, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass_id[a=2,b=2,expected=4]", "lineno": 36, "outcome": "passed", "keywords": ["test_addition_pass_id[a=2,b=2,expected=4]", "parametrize", "pytestmark", "a=2,b=2,expected=4", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00023477408103644848, "outcome": "passed"}, "call": {"duration": 0.00012618605978786945, "outcome": "passed"}, "teardown": {"duration": 0.0001371761318296194, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass_id[a=1,b=5,expected=6]", "lineno": 36, "outcome": "passed", "keywords": ["test_addition_pass_id[a=1,b=5,expected=6]", "parametrize", "pytestmark", "a=1,b=5,expected=6", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00024573784321546555, "outcome": "passed"}, "call": {"duration": 0.0001256710384041071, "outcome": "passed"}, "teardown": {"duration": 0.00013288995251059532, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_pass_id[a=3,b=4,expected=7]", "lineno": 36, "outcome": "passed", "keywords": ["test_addition_pass_id[a=3,b=4,expected=7]", "parametrize", "pytestmark", "a=3,b=4,expected=7", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.000244820024818182, "outcome": "passed"}, "call": {"duration": 0.0001287669874727726, "outcome": "passed"}, "teardown": {"duration": 0.0001340731978416443, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_addition_fail", "lineno": 48, "outcome": "failed", "keywords": ["test_addition_fail", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00010233791545033455, "outcome": "passed"}, "call": {"duration": 0.0005044790450483561, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 51, "message": "assert 4 == 5\n + where 4 = addition(2, 2)"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 51, "message": "AssertionError"}], "longrepr": "def test_addition_fail():\n # Assertion failure: expected incorrect result\n> assert addition(2, 2) == 5\nE assert 4 == 5\nE + where 4 = addition(2, 2)\n\ntests/test_math_utils.py:51: AssertionError"}, "teardown": {"duration": 0.00015952112153172493, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_division_zero", "lineno": 52, "outcome": "failed", "keywords": ["test_division_zero", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00017586816102266312, "outcome": "passed"}, "call": {"duration": 0.00029951496981084347, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/functions/math_utils.py", "lineno": 5, "message": "ZeroDivisionError: division by zero"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 55, "message": ""}, {"path": "functions/math_utils.py", "lineno": 5, "message": "ZeroDivisionError"}], "longrepr": "def test_division_zero():\n # Will raise ZeroDivisionError if not handled in division\n> division(1, 0)\n\ntests/test_math_utils.py:55: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\na = 1, b = 0\n\n def division(a, b):\n> return a / b\nE ZeroDivisionError: division by zero\n\nfunctions/math_utils.py:5: ZeroDivisionError"}, "teardown": {"duration": 0.00023273704573512077, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_multiply_xfail", "lineno": 56, "outcome": "xfailed", "keywords": ["test_multiply_xfail", "xfail", "pytestmark", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0002610699739307165, "outcome": "passed"}, "call": {"duration": 0.000476679066196084, "outcome": "skipped", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 60, "message": "assert 4 == 5\n + where 4 = multiply(2, 2)"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 60, "message": "AssertionError"}], "longrepr": "@pytest.mark.xfail(reason=\"Expected failure\")\n def test_multiply_xfail():\n # Expected fail test (xfail): incorrect expected multiply result\n> assert multiply(2, 2) == 5\nE assert 4 == 5\nE + where 4 = multiply(2, 2)\n\ntests/test_math_utils.py:60: AssertionError"}, "teardown": {"duration": 0.00022982200607657433, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_runtime_error", "lineno": 61, "outcome": "failed", "keywords": ["test_runtime_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00021421699784696102, "outcome": "passed"}, "call": {"duration": 0.0002854440826922655, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 64, "message": "RuntimeError: Forced runtime error"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 64, "message": "RuntimeError"}], "longrepr": "def test_runtime_error():\n # Test raises an uncaught RuntimeError\n> raise RuntimeError(\"Forced runtime error\")\nE RuntimeError: Forced runtime error\n\ntests/test_math_utils.py:64: RuntimeError"}, "teardown": {"duration": 0.00023652613162994385, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_memory_error", "lineno": 65, "outcome": "failed", "keywords": ["test_memory_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00021091685630381107, "outcome": "passed"}, "call": {"duration": 0.0002885309513658285, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 68, "message": "MemoryError: Simulated memory error"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 68, "message": "MemoryError"}], "longrepr": "def test_memory_error():\n # Manually raise MemoryError to simulate out-of-memory condition\n> raise MemoryError(\"Simulated memory error\")\nE MemoryError: Simulated memory error\n\ntests/test_math_utils.py:68: MemoryError"}, "teardown": {"duration": 0.0001832200214266777, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_timeout_error", "lineno": 69, "outcome": "failed", "keywords": ["test_timeout_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00017371098510921001, "outcome": "passed"}, "call": {"duration": 0.00021384097635746002, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 72, "message": "TimeoutError: Simulated timeout error"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 72, "message": "TimeoutError"}], "longrepr": "def test_timeout_error():\n # Manually raise TimeoutError simulating timeout conditions\n> raise TimeoutError(\"Simulated timeout error\")\nE TimeoutError: Simulated timeout error\n\ntests/test_math_utils.py:72: TimeoutError"}, "teardown": {"duration": 0.00017173890955746174, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_recursion_error", "lineno": 73, "outcome": "failed", "keywords": ["test_recursion_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00015650317072868347, "outcome": "passed"}, "call": {"duration": 0.001101339003071189, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 77, "message": "RecursionError: maximum recursion depth exceeded"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 78, "message": ""}, {"path": "tests/test_math_utils.py", "lineno": 77, "message": "in recursive"}, {"path": "tests/test_math_utils.py", "lineno": 77, "message": "in recursive"}], "longrepr": "def test_recursion_error():\n # Infinite recursion triggers RecursionError\n def recursive():\n return recursive()\n> recursive()\n\ntests/test_math_utils.py:78: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \ntests/test_math_utils.py:77: in recursive\n return recursive()\ntests/test_math_utils.py:77: in recursive\n return recursive()\nE RecursionError: maximum recursion depth exceeded\n!!! Recursion detected (same locals & position)"}, "teardown": {"duration": 0.00014351005665957928, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_floating_point_error", "lineno": 79, "outcome": "failed", "keywords": ["test_floating_point_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012473389506340027, "outcome": "passed"}, "call": {"duration": 0.0001532940659672022, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 82, "message": "FloatingPointError: Simulated floating point error"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 82, "message": "FloatingPointError"}], "longrepr": "def test_floating_point_error():\n # Manually raise FloatingPointError\n> raise FloatingPointError(\"Simulated floating point error\")\nE FloatingPointError: Simulated floating point error\n\ntests/test_math_utils.py:82: FloatingPointError"}, "teardown": {"duration": 0.00014129886403679848, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_floating_point_overflow", "lineno": 83, "outcome": "failed", "keywords": ["test_floating_point_overflow", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00013295700773596764, "outcome": "passed"}, "call": {"duration": 0.000159702030941844, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 86, "message": "OverflowError: math range error"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 86, "message": "OverflowError"}], "longrepr": "def test_floating_point_overflow():\n # Exponential overflow triggers OverflowError\n> math.exp(1000)\nE OverflowError: math range error\n\ntests/test_math_utils.py:86: OverflowError"}, "teardown": {"duration": 0.00013917102478444576, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_value_error", "lineno": 87, "outcome": "failed", "keywords": ["test_value_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012867385521531105, "outcome": "passed"}, "call": {"duration": 0.00016219611279666424, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 90, "message": "ValueError: invalid literal for int() with base 10: 'invalid'"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 90, "message": "ValueError"}], "longrepr": "def test_value_error():\n # ValueError on invalid integer conversion\n> int(\"invalid\")\nE ValueError: invalid literal for int() with base 10: 'invalid'\n\ntests/test_math_utils.py:90: ValueError"}, "teardown": {"duration": 0.0001484088134020567, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_wrong_argument_error", "lineno": 91, "outcome": "failed", "keywords": ["test_wrong_argument_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0001167571172118187, "outcome": "passed"}, "call": {"duration": 0.000151502201333642, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 94, "message": "TypeError: 'int' object is not iterable"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 94, "message": "TypeError"}], "longrepr": "def test_wrong_argument_error():\n # TypeError when passing wrong argument type to sum\n> sum(5)\nE TypeError: 'int' object is not iterable\n\ntests/test_math_utils.py:94: TypeError"}, "teardown": {"duration": 0.00013879919424653053, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_unhandled_exception", "lineno": 95, "outcome": "failed", "keywords": ["test_unhandled_exception", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00011623091995716095, "outcome": "passed"}, "call": {"duration": 0.0001494050957262516, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 98, "message": "Exception: Generic unhandled exception"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 98, "message": "Exception"}], "longrepr": "def test_unhandled_exception():\n # Raises generic unhandled Exception\n> raise Exception(\"Generic unhandled exception\")\nE Exception: Generic unhandled exception\n\ntests/test_math_utils.py:98: Exception"}, "teardown": {"duration": 0.0001417580060660839, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_custom_error", "lineno": 99, "outcome": "failed", "keywords": ["test_custom_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00011655595153570175, "outcome": "passed"}, "call": {"duration": 0.00015103002078831196, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 102, "message": "test_math_utils.CustomError: Custom error simulation"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 102, "message": "CustomError"}], "longrepr": "def test_custom_error():\n # Raises user-defined CustomError exception\n> raise CustomError(\"Custom error simulation\")\nE test_math_utils.CustomError: Custom error simulation\n\ntests/test_math_utils.py:102: CustomError"}, "teardown": {"duration": 0.00014246907085180283, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_stop_iteration_direct", "lineno": 103, "outcome": "failed", "keywords": ["test_stop_iteration_direct", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012304610572755337, "outcome": "passed"}, "call": {"duration": 0.0001640769187361002, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/site-packages/_pytest/capture.py", "lineno": 880, "message": "RuntimeError: generator raised StopIteration"}, "traceback": [{"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/runner.py", "lineno": 341, "message": ""}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/runner.py", "lineno": 242, "message": "in "}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/pluggy/_hooks.py", "lineno": 513, "message": "in __call__"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/pluggy/_manager.py", "lineno": 120, "message": "in _hookexec"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/threadexception.py", "lineno": 92, "message": "in pytest_runtest_call"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/threadexception.py", "lineno": 68, "message": "in thread_exception_runtest_hook"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/unraisableexception.py", "lineno": 95, "message": "in pytest_runtest_call"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/unraisableexception.py", "lineno": 70, "message": "in unraisable_exception_runtest_hook"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/logging.py", "lineno": 846, "message": "in pytest_runtest_call"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/logging.py", "lineno": 829, "message": "in _runtest_for"}, {"path": ".pixi/envs/default/lib/python3.8/site-packages/_pytest/capture.py", "lineno": 880, "message": "RuntimeError"}], "longrepr": "def test_stop_iteration_direct():\n # Directly raise StopIteration exception\n> raise StopIteration()\nE StopIteration\n\ntests/test_math_utils.py:106: StopIteration\n\nThe above exception was the direct cause of the following exception:\n\ncls = \nfunc = . at 0x7fe48be3c700>\nwhen = 'call'\nreraise = (, )\n\n @classmethod\n def from_call(\n cls,\n func: Callable[[], TResult],\n when: Literal[\"collect\", \"setup\", \"call\", \"teardown\"],\n reraise: type[BaseException] | tuple[type[BaseException], ...] | None = None,\n ) -> CallInfo[TResult]:\n \"\"\"Call func, wrapping the result in a CallInfo.\n \n :param func:\n The function to call. Called without arguments.\n :type func: Callable[[], _pytest.runner.TResult]\n :param when:\n The phase in which the function is called.\n :param reraise:\n Exception or exceptions that shall propagate if raised by the\n function, instead of being wrapped in the CallInfo.\n \"\"\"\n excinfo = None\n start = timing.time()\n precise_start = timing.perf_counter()\n try:\n> result: TResult | None = func()\n\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/runner.py:341: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n.pixi/envs/default/lib/python3.8/site-packages/_pytest/runner.py:242: in \n lambda: runtest_hook(item=item, **kwds), when=when, reraise=reraise\n.pixi/envs/default/lib/python3.8/site-packages/pluggy/_hooks.py:513: in __call__\n return self._hookexec(self.name, self._hookimpls.copy(), kwargs, firstresult)\n.pixi/envs/default/lib/python3.8/site-packages/pluggy/_manager.py:120: in _hookexec\n return self._inner_hookexec(hook_name, methods, kwargs, firstresult)\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/threadexception.py:92: in pytest_runtest_call\n yield from thread_exception_runtest_hook()\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/threadexception.py:68: in thread_exception_runtest_hook\n yield\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/unraisableexception.py:95: in pytest_runtest_call\n yield from unraisable_exception_runtest_hook()\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/unraisableexception.py:70: in unraisable_exception_runtest_hook\n yield\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/logging.py:846: in pytest_runtest_call\n yield from self._runtest_for(item, \"call\")\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/logging.py:829: in _runtest_for\n yield\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\nself = _capture_fixture=None>\nitem = \n\n @hookimpl(wrapper=True)\n def pytest_runtest_call(self, item: Item) -> Generator[None]:\n with self.item_capture(\"call\", item):\n> return (yield)\nE RuntimeError: generator raised StopIteration\n\n.pixi/envs/default/lib/python3.8/site-packages/_pytest/capture.py:880: RuntimeError"}, "teardown": {"duration": 0.00025580497458577156, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_generator_exit_direct", "lineno": 107, "outcome": "failed", "keywords": ["test_generator_exit_direct", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00014240085147321224, "outcome": "passed"}, "call": {"duration": 0.00020209909416735172, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 110, "message": "GeneratorExit"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 110, "message": "GeneratorExit"}], "longrepr": "def test_generator_exit_direct():\n # Directly raise GeneratorExit exception\n> raise GeneratorExit()\nE GeneratorExit\n\ntests/test_math_utils.py:110: GeneratorExit"}, "teardown": {"duration": 0.00020958180539309978, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_malformed_code", "lineno": 111, "outcome": "failed", "keywords": ["test_malformed_code", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012465519830584526, "outcome": "passed"}, "call": {"duration": 0.0001744660548865795, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 114, "message": " File \"\", line 1\n def bad(:\n ^\nSyntaxError: invalid syntax"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 114, "message": "SyntaxError"}], "longrepr": "def test_malformed_code():\n # SyntaxError when executing malformed Python code\n> exec(\"def bad(:\\n pass\")\nE File \"\", line 1\nE def bad(:\nE ^\nE SyntaxError: invalid syntax\n\ntests/test_math_utils.py:114: SyntaxError"}, "teardown": {"duration": 0.0001511010341346264, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_sys_exit", "lineno": 115, "outcome": "failed", "keywords": ["test_sys_exit", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012170104309916496, "outcome": "passed"}, "call": {"duration": 0.00015023606829345226, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 118, "message": "SystemExit: 1"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 118, "message": "SystemExit"}], "longrepr": "def test_sys_exit():\n # Simulate SystemExit via sys.exit\n> sys.exit(1)\nE SystemExit: 1\n\ntests/test_math_utils.py:118: SystemExit"}, "teardown": {"duration": 0.0001453729346394539, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_broken_function", "lineno": 119, "outcome": "failed", "keywords": ["test_broken_function", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012337509542703629, "outcome": "passed"}, "call": {"duration": 0.00015427195467054844, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 123, "message": "TypeError: Broken function"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 124, "message": ""}, {"path": "tests/test_math_utils.py", "lineno": 123, "message": "TypeError"}], "longrepr": "def test_broken_function():\n # Simulate broken function raising TypeError\n def broken_func(*args, **kwargs):\n raise TypeError(\"Broken function\")\n> broken_func()\n\ntests/test_math_utils.py:124: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\nargs = (), kwargs = {}\n\n def broken_func(*args, **kwargs):\n> raise TypeError(\"Broken function\")\nE TypeError: Broken function\n\ntests/test_math_utils.py:123: TypeError"}, "teardown": {"duration": 0.00015054293908178806, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_import_error", "lineno": 125, "outcome": "failed", "keywords": ["test_import_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00011663511395454407, "outcome": "passed"}, "call": {"duration": 0.00015443307347595692, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_math_utils.py", "lineno": 127, "message": "ImportError: Simulated ImportError"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 127, "message": "ImportError"}], "longrepr": "def test_import_error():\n> raise ImportError(\"Simulated ImportError\")\nE ImportError: Simulated ImportError\n\ntests/test_math_utils.py:127: ImportError"}, "teardown": {"duration": 0.00014697294682264328, "outcome": "passed"}}, {"nodeid": "tests/test_math_utils.py::test_module_not_found_error", "lineno": 128, "outcome": "failed", "keywords": ["test_module_not_found_error", "test_math_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00011754198931157589, "outcome": "passed"}, "call": {"duration": 0.0005241041071712971, "outcome": "failed", "crash": {"path": "", "lineno": 973, "message": "ModuleNotFoundError: No module named 'non_existent_module_xyz'"}, "traceback": [{"path": "tests/test_math_utils.py", "lineno": 131, "message": ""}, {"path": ".pixi/envs/default/lib/python3.8/importlib/__init__.py", "lineno": 127, "message": "in import_module"}, {"path": "", "lineno": 1014, "message": "in _gcd_import"}, {"path": "", "lineno": 991, "message": "in _find_and_load"}, {"path": "", "lineno": 973, "message": "ModuleNotFoundError"}], "longrepr": "def test_module_not_found_error():\n # Raises ModuleNotFoundError (subclass of ImportError) for missing module\n> importlib.import_module(\"non_existent_module_xyz\")\n\ntests/test_math_utils.py:131: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n.pixi/envs/default/lib/python3.8/importlib/__init__.py:127: in import_module\n return _bootstrap._gcd_import(name[level:], package, level)\n:1014: in _gcd_import\n ???\n:991: in _find_and_load\n ???\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\nname = 'non_existent_module_xyz'\nimport_ = \n\n> ???\nE ModuleNotFoundError: No module named 'non_existent_module_xyz'\n\n:973: ModuleNotFoundError"}, "teardown": {"duration": 0.00015066401101648808, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_basic_ids[one]", "lineno": 3, "outcome": "passed", "keywords": ["test_basic_ids[one]", "parametrize", "pytestmark", "one", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00024648592807352543, "outcome": "passed"}, "call": {"duration": 0.00013936497271060944, "outcome": "passed"}, "teardown": {"duration": 0.00012199999764561653, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_basic_ids[two]", "lineno": 3, "outcome": "passed", "keywords": ["test_basic_ids[two]", "parametrize", "pytestmark", "two", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00018452201038599014, "outcome": "passed"}, "call": {"duration": 0.0001278009731322527, "outcome": "passed"}, "teardown": {"duration": 0.0001158041413873434, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_with_reason_and_marks[ten]", "lineno": 11, "outcome": "passed", "keywords": ["test_with_reason_and_marks[ten]", "parametrize", "pytestmark", "ten", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00016426085494458675, "outcome": "passed"}, "call": {"duration": 0.0001251788344234228, "outcome": "passed"}, "teardown": {"duration": 0.00011022388935089111, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_with_reason_and_marks[twenty]", "lineno": 11, "outcome": "skipped", "keywords": ["test_with_reason_and_marks[twenty]", "parametrize", "skip", "pytestmark", "twenty", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.0002290019765496254, "outcome": "skipped", "longrepr": "('/workspace/tligui_y/slic/tests/test_param.py', 12, 'Skipped: nope')"}, "teardown": {"duration": 0.00011773500591516495, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_multiple_positional_args[1-2]", "lineno": 19, "outcome": "passed", "keywords": ["test_multiple_positional_args[1-2]", "parametrize", "pytestmark", "1-2", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00023832195438444614, "outcome": "passed"}, "call": {"duration": 0.00012902705930173397, "outcome": "passed"}, "teardown": {"duration": 0.0001266789622604847, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_multiple_positional_args[3-4]", "lineno": 19, "outcome": "passed", "keywords": ["test_multiple_positional_args[3-4]", "parametrize", "pytestmark", "3-4", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00021152803674340248, "outcome": "passed"}, "call": {"duration": 0.00012860819697380066, "outcome": "passed"}, "teardown": {"duration": 0.00012736395001411438, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_non_literal_with_id[custom-obj]", "lineno": 27, "outcome": "passed", "keywords": ["test_non_literal_with_id[custom-obj]", "parametrize", "pytestmark", "custom-obj", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00017059198580682278, "outcome": "passed"}, "call": {"duration": 0.00012141489423811436, "outcome": "passed"}, "teardown": {"duration": 0.00011034705676138401, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_timedistance_v1[a0-b0-expected0]", "lineno": 40, "outcome": "passed", "keywords": ["test_timedistance_v1[a0-b0-expected0]", "parametrize", "pytestmark", "a0-b0-expected0", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.0002481809351593256, "outcome": "passed"}, "call": {"duration": 0.00012331386096775532, "outcome": "passed"}, "teardown": {"duration": 0.0001383849885314703, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_timedistance_v1[a1-b1-expected1]", "lineno": 40, "outcome": "passed", "keywords": ["test_timedistance_v1[a1-b1-expected1]", "parametrize", "pytestmark", "a1-b1-expected1", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.000254862941801548, "outcome": "passed"}, "call": {"duration": 0.000124865910038352, "outcome": "passed"}, "teardown": {"duration": 0.00013261218555271626, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::TestDynamic::test_sum_positive", "lineno": 70, "outcome": "error", "keywords": ["test_sum_positive", "TestDynamic", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00015152012929320335, "outcome": "failed", "longrepr": "file /workspace/tligui_y/slic/tests/test_param.py, line 71\n def test_sum_positive(self, x, y):\nE fixture 'x' not found\n> available fixtures: cache, capfd, capfdbinary, caplog, capsys, capsysbinary, complex_setup, cov, doctest_namespace, element, extra, extras, include_metadata_in_junit_xml, json_metadata, metadata, monkeypatch, no_cover, pytestconfig, record_property, record_testsuite_property, record_xml_attribute, recwarn, tmp_path, tmp_path_factory, tmpdir, tmpdir_factory\n> use 'pytest --fixtures [testpath]' for help on them.\n\n/workspace/tligui_y/slic/tests/test_param.py:71"}, "teardown": {"duration": 0.0001243269070982933, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_dynamic[ten]", "lineno": 78, "outcome": "passed", "keywords": ["test_dynamic[ten]", "ten", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00018024793826043606, "outcome": "passed"}, "call": {"duration": 0.00013278494589030743, "outcome": "passed"}, "teardown": {"duration": 0.00011739297769963741, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_dynamic[twenty]", "lineno": 78, "outcome": "passed", "keywords": ["test_dynamic[twenty]", "twenty", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00016096699982881546, "outcome": "passed"}, "call": {"duration": 0.00012196903117001057, "outcome": "passed"}, "teardown": {"duration": 0.00011925818398594856, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_dynamic[thirty]", "lineno": 78, "outcome": "passed", "keywords": ["test_dynamic[thirty]", "thirty", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.0001843541394919157, "outcome": "passed"}, "call": {"duration": 0.00014753197319805622, "outcome": "passed"}, "teardown": {"duration": 0.00013431580737233162, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_element_type[\\U0001f525]", "lineno": 87, "outcome": "passed", "keywords": ["test_element_type[\\U0001f525]", "\\U0001f525", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00018815393559634686, "outcome": "passed"}, "call": {"duration": 0.00014288397505879402, "outcome": "passed"}, "teardown": {"duration": 0.000126637052744627, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_element_type[\\U0001f4a7]", "lineno": 87, "outcome": "passed", "keywords": ["test_element_type[\\U0001f4a7]", "\\U0001f4a7", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00018169288523495197, "outcome": "passed"}, "call": {"duration": 0.00014170887880027294, "outcome": "passed"}, "teardown": {"duration": 0.00012704799883067608, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_element_type[\\U0001f30d]", "lineno": 87, "outcome": "passed", "keywords": ["test_element_type[\\U0001f30d]", "\\U0001f30d", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00018208217807114124, "outcome": "passed"}, "call": {"duration": 0.00014093401841819286, "outcome": "passed"}, "teardown": {"duration": 0.000129257095977664, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_combination[a-1]", "lineno": 90, "outcome": "passed", "keywords": ["test_combination[a-1]", "parametrize", "pytestmark", "a-1", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00023418013006448746, "outcome": "passed"}, "call": {"duration": 0.00014371005818247795, "outcome": "passed"}, "teardown": {"duration": 0.00015111500397324562, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_combination[a-2]", "lineno": 90, "outcome": "passed", "keywords": ["test_combination[a-2]", "parametrize", "pytestmark", "a-2", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00022931210696697235, "outcome": "passed"}, "call": {"duration": 0.00014824303798377514, "outcome": "passed"}, "teardown": {"duration": 0.00014614802785217762, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_combination[b-1]", "lineno": 90, "outcome": "passed", "keywords": ["test_combination[b-1]", "parametrize", "pytestmark", "b-1", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00022961199283599854, "outcome": "passed"}, "call": {"duration": 0.0001437189057469368, "outcome": "passed"}, "teardown": {"duration": 0.0001438390463590622, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_combination[b-2]", "lineno": 90, "outcome": "passed", "keywords": ["test_combination[b-2]", "parametrize", "pytestmark", "b-2", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00022813212126493454, "outcome": "passed"}, "call": {"duration": 0.0001525520347058773, "outcome": "passed"}, "teardown": {"duration": 0.00014077592641115189, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_indirect_fixture[1]", "lineno": 100, "outcome": "passed", "keywords": ["test_indirect_fixture[1]", "parametrize", "pytestmark", "1", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.0003382971044629812, "outcome": "passed"}, "call": {"duration": 0.00014980812557041645, "outcome": "passed"}, "teardown": {"duration": 0.00012976606376469135, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_indirect_fixture[2]", "lineno": 100, "outcome": "passed", "keywords": ["test_indirect_fixture[2]", "parametrize", "pytestmark", "2", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.00019439798779785633, "outcome": "passed"}, "call": {"duration": 0.00014423509128391743, "outcome": "passed"}, "teardown": {"duration": 0.00012772902846336365, "outcome": "passed"}}, {"nodeid": "tests/test_param.py::test_addition", "lineno": 104, "outcome": "failed", "keywords": ["test_addition", "test_param.py", "tests", "slic", ""], "setup": {"duration": 0.0001362641341984272, "outcome": "passed"}, "call": {"duration": 0.00016373186372220516, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_param.py", "lineno": 107, "message": "NameError: name 'addition' is not defined"}, "traceback": [{"path": "tests/test_param.py", "lineno": 107, "message": "NameError"}], "longrepr": "a = 5, b = 5, expected = 10\n\n def test_addition(a = 5, b = 5, expected = 10):\n # Has to pass\n> assert addition(a, b) == expected\nE NameError: name 'addition' is not defined\n\ntests/test_param.py:107: NameError"}, "teardown": {"duration": 0.0001544049009680748, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_uppercase_normal", "lineno": 9, "outcome": "passed", "keywords": ["test_uppercase_normal", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00014012213796377182, "outcome": "passed"}, "call": {"duration": 0.00016683898866176605, "outcome": "passed"}, "teardown": {"duration": 0.00011661602184176445, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_uppercase_type_error", "lineno": 13, "outcome": "failed", "keywords": ["test_uppercase_type_error", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0001228500623255968, "outcome": "passed"}, "call": {"duration": 0.0001670739147812128, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/functions/string_utils.py", "lineno": 3, "message": "TypeError: Input cannot be None"}, "traceback": [{"path": "tests/test_string_utils.py", "lineno": 16, "message": ""}, {"path": "functions/string_utils.py", "lineno": 3, "message": "TypeError"}], "longrepr": "def test_uppercase_type_error():\n # TypeError when input is None (invalid input)\n> uppercase(None)\n\ntests/test_string_utils.py:16: \n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\ns = None\n\n def uppercase(s):\n if s is None:\n> raise TypeError(\"Input cannot be None\")\nE TypeError: Input cannot be None\n\nfunctions/string_utils.py:3: TypeError"}, "teardown": {"duration": 0.00014146394096314907, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_reverse_string", "lineno": 17, "outcome": "passed", "keywords": ["test_reverse_string", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012062117457389832, "outcome": "passed"}, "call": {"duration": 0.00014070305041968822, "outcome": "passed"}, "teardown": {"duration": 0.00010410300455987453, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_warning_emit", "lineno": 21, "outcome": "passed", "keywords": ["test_warning_emit", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00010586204007267952, "outcome": "passed"}, "call": {"duration": 0.00015261489897966385, "outcome": "passed"}, "teardown": {"duration": 0.00010772189125418663, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_unicode_decode_error", "lineno": 25, "outcome": "failed", "keywords": ["test_unicode_decode_error", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.0001034389715641737, "outcome": "passed"}, "call": {"duration": 0.00014473404735326767, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_string_utils.py", "lineno": 28, "message": "UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte"}, "traceback": [{"path": "tests/test_string_utils.py", "lineno": 28, "message": "UnicodeDecodeError"}], "longrepr": "def test_unicode_decode_error():\n # UnicodeDecodeError when decoding invalid byte sequence\n> b'\\xff'.decode('utf-8')\nE UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte\n\ntests/test_string_utils.py:28: UnicodeDecodeError"}, "teardown": {"duration": 0.00014453288167715073, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_unicode_decode_surrogateescape", "lineno": 29, "outcome": "failed", "keywords": ["test_unicode_decode_surrogateescape", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00011710496619343758, "outcome": "passed"}, "call": {"duration": 0.00015011103823781013, "outcome": "failed", "crash": {"path": "/workspace/tligui_y/slic/tests/test_string_utils.py", "lineno": 32, "message": "UnicodeDecodeError: 'utf-8' codec can't decode byte 0x80 in position 0: invalid start byte"}, "traceback": [{"path": "tests/test_string_utils.py", "lineno": 32, "message": "UnicodeDecodeError"}], "longrepr": "def test_unicode_decode_surrogateescape():\n # UnicodeDecodeError with strict error handler on invalid byte\n> b\"\\x80\".decode(\"utf-8\", errors=\"strict\")\nE UnicodeDecodeError: 'utf-8' codec can't decode byte 0x80 in position 0: invalid start byte\n\ntests/test_string_utils.py:32: UnicodeDecodeError"}, "teardown": {"duration": 0.0001374951098114252, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_import_warning", "lineno": 33, "outcome": "passed", "keywords": ["test_import_warning", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00012971390970051289, "outcome": "passed"}, "call": {"duration": 0.00014096801169216633, "outcome": "passed"}, "teardown": {"duration": 0.00010313699021935463, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_xfail_uppercase_digits", "lineno": 37, "outcome": "xfailed", "keywords": ["test_xfail_uppercase_digits", "xfail", "pytestmark", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00011595012620091438, "outcome": "passed"}, "call": {"duration": 0.000629462068900466, "outcome": "skipped", "crash": {"path": "/workspace/tligui_y/slic/tests/test_string_utils.py", "lineno": 41, "message": "AssertionError: assert 'ABC123' == 'ABC1234'\n \n - ABC1234\n ? -\n + ABC123"}, "traceback": [{"path": "tests/test_string_utils.py", "lineno": 41, "message": "AssertionError"}], "longrepr": "@pytest.mark.xfail(reason=\"Expected failure: uppercase does not handle digits\")\n def test_xfail_uppercase_digits():\n # Expected fail test because uppercase won't change digits\n> assert uppercase(\"abc123\") == \"ABC1234\"\nE AssertionError: assert 'ABC123' == 'ABC1234'\nE \nE - ABC1234\nE ? -\nE + ABC123\n\ntests/test_string_utils.py:41: AssertionError"}, "teardown": {"duration": 0.0001344778575003147, "outcome": "passed"}}, {"nodeid": "tests/test_string_utils.py::test_keyboard_interrupt_direct", "lineno": 49, "outcome": "passed", "keywords": ["test_keyboard_interrupt_direct", "test_string_utils.py", "tests", "slic", ""], "setup": {"duration": 0.00011977995745837688, "outcome": "passed"}}], "warnings": [{"message": "Test warning", "category": "UserWarning", "when": "runtest", "filename": "/workspace/tligui_y/slic/tests/test_string_utils.py", "lineno": 24}]} \ No newline at end of file diff --git a/ci-reports/markdown/runtime_params.json b/ci-reports/markdown/runtime_params.json index ca098a7cd..db3f245f8 100644 --- a/ci-reports/markdown/runtime_params.json +++ b/ci-reports/markdown/runtime_params.json @@ -266,7 +266,7 @@ "nodeid": "tests/test_param.py::test_non_literal_with_id[custom-obj]", "callspec": { "params": { - "data": "" + "data": "" }, "id": "custom-obj" }