📁 ci-reports/markdown/pytest-report.json
├── created: 1753186596.1935027
├── duration: 0.7543473243713379
├── exitcode: 2
├── root: /workspace/tligui_y/slic
├── environment
├── summary
│   ├── passed: 38
│   ├── failed: 33
│   ├── xfailed: 2
│   ├── skipped: 1
│   ├── error: 1
│   ├── total: 75
│   └── collected: 75
├── 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
│   │           mod = import_path(
│   │       .pixi/envs/default/lib/python3.8/site-packages/_pytest/pathlib.py:58
│   │       7: in import_path
│   │           importlib.import_module(module_name)
│   │       .pixi/envs/default/lib/python3.8/importlib/__init__.py:127: in 
│   │       import_module
│   │           return _bootstrap._gcd_import(name, package, level)
│   │       <frozen importlib._bootstrap>:1014: in _gcd_import
│   │           ???
│   │       <frozen importlib._bootstrap>:991: in _find_and_load
│   │           ???
│   │       <frozen importlib._bootstrap>:975: in _find_and_load_unlocked
│   │           ???
│   │       <frozen importlib._bootstrap>:671: in _load_unlocked
│   │           ???
│   │       .pixi/envs/default/lib/python3.8/site-packages/_pytest/assertion/rew
│   │       rite.py:175: in exec_module
│   │           source_stat, co = _rewrite_test(fn, self.config)
│   │       .pixi/envs/default/lib/python3.8/site-packages/_pytest/assertion/rew
│   │       rite.py:355: in _rewrite_test
│   │           tree = ast.parse(source, filename=strfn)
│   │       .pixi/envs/default/lib/python3.8/ast.py:47: in parse
│   │           return compile(source, filename, mode, flags,
│   │       E     File "/workspace/tligui_y/slic/tests/test_broken_fct.py", line
│   │       8
│   │       E       def test_valid_2():
│   │       E       ^
│   │       E   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'.
│   │       Hint: make sure your test modules/packages have valid Python names.
│   │       Traceback:
│   │       .pixi/envs/default/lib/python3.8/importlib/__init__.py:127: in 
│   │       import_module
│   │           return _bootstrap._gcd_import(name, package, level)
│   │       tests/test_collector_error.py:1: in <module>
│   │           from no_existing_module.math_utils import *
│   │       E   ModuleNotFoundError: No module named 'no_existing_module'
│   ├── -
│   │   ├── nodeid: tests/test_io_utils.py
│   │   ├── outcome: passed
│   │   └── result
│   │       ├── -
│   │       │   ├── nodeid: tests/test_io_utils.py::test_write_file
│   │       │   ├── type: Function
│   │       │   └── lineno: 9
│   │       ├── -
│   │       │   ├── nodeid: tests/test_io_utils.py::test_read_file
│   │       │   ├── type: Function
│   │       │   └── lineno: 15
│   │       ├── -
│   │       │   ├── 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_in_readonly_mode
│   │       │   ├── type: Function
│   │       │   └── lineno: 58
│   │       └── -
│   │           ├── nodeid: tests/test_io_utils.py::test_file_not_found_error
│   │           ├── type: Function
│   │           └── lineno: 67
│   ├── -
│   │   ├── 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
│   │       │   ├── type: Function
│   │       │   └── lineno: 36
│   │       ├── -
│   │       │   ├── nodeid: tests/test_math_utils.py::test_addition_pass_id
│   │       │   ├── type: Function
│   │       │   └── lineno: 36
│   │       ├── -
│   │       │   ├── nodeid: tests/test_math_utils.py::test_addition_pass_id
│   │       │   ├── 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: 129
│   ├── -
│   │   ├── nodeid: tests/test_param.py
│   │   ├── outcome: passed
│   │   └── result
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_basic_ids
│   │       │   ├── type: Function
│   │       │   └── lineno: 3
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_basic_ids
│   │       │   ├── type: Function
│   │       │   └── lineno: 3
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_with_reason_and_marks
│   │       │   ├── type: Function
│   │       │   └── lineno: 11
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_with_reason_and_marks
│   │       │   ├── 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
│   │       │   ├── type: Function
│   │       │   └── lineno: 27
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_timedistance_v1
│   │       │   ├── type: Function
│   │       │   └── lineno: 43
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_timedistance_v1
│   │       │   ├── type: Function
│   │       │   └── lineno: 43
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_sum_positive
│   │       │   ├── type: Function
│   │       │   └── lineno: 55
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_sum_positive
│   │       │   ├── type: Function
│   │       │   └── lineno: 55
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_sum_positive
│   │       │   ├── type: Function
│   │       │   └── lineno: 55
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_dynamic
│   │       │   ├── type: Function
│   │       │   └── lineno: 65
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_dynamic
│   │       │   ├── type: Function
│   │       │   └── lineno: 65
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_dynamic
│   │       │   ├── type: Function
│   │       │   └── lineno: 65
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_element_type[\U0001f525]
│   │       │   ├── type: Function
│   │       │   └── lineno: 74
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_element_type[\U0001f4a7]
│   │       │   ├── type: Function
│   │       │   └── lineno: 74
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_element_type[\U0001f30d]
│   │       │   ├── type: Function
│   │       │   └── lineno: 74
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_combination
│   │       │   ├── type: Function
│   │       │   └── lineno: 78
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_combination
│   │       │   ├── type: Function
│   │       │   └── lineno: 78
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_combination
│   │       │   ├── type: Function
│   │       │   └── lineno: 78
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_combination
│   │       │   ├── type: Function
│   │       │   └── lineno: 78
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_indirect_fixture[1]
│   │       │   ├── type: Function
│   │       │   └── lineno: 89
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_indirect_fixture[2]
│   │       │   ├── type: Function
│   │       │   └── lineno: 89
│   │       ├── -
│   │       │   ├── nodeid: tests/test_param.py::test_addition
│   │       │   ├── type: Function
│   │       │   └── lineno: 94
│   │       └── -
│   │           ├── nodeid: tests/test_param.py::test_basic_error
│   │           ├── type: Function
│   │           └── lineno: 99
│   ├── -
│   │   ├── 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_surrogateesc
│   │       │   │   ape
│   │       │   ├── type: Function
│   │       │   └── lineno: 29
│   │       ├── -
│   │       │   ├── nodeid: tests/test_string_utils.py::test_syntax_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_write_file
│   │   ├── lineno: 9
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_write_file
│   │   │   ├── test_io_utils.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.003127171192318201
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.000460044015198946
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00023637502454221249
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_io_utils.py::test_read_file
│   │   ├── lineno: 15
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_read_file
│   │   │   ├── test_io_utils.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00045256479643285275
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00029500690288841724
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00014071795158088207
│   │       └── 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.00011181505396962166
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00016287202015519142
│   │   │   ├── 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():
│   │   │               # Raises manual IOError to simulate IO failure
│   │   │       >       cause_io_error()
│   │   │       
│   │   │       tests/test_io_utils.py:25: 
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       
│   │   │           def cause_io_error():
│   │   │       >       raise IOError("Forced IO Error for testing")
│   │   │       E       OSError: Forced IO Error for testing
│   │   │       
│   │   │       functions/io_utils.py:10: OSError
│   │   └── teardown
│   │       ├── duration: 0.00013995193876326084
│   │       └── 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.00012210989370942116
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00018649897538125515
│   │   │   ├── 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():
│   │   │               # Reading non-existing file raises FileNotFoundError
│   │   │       >       read_file("nonexistent.file")
│   │   │       
│   │   │       tests/test_io_utils.py:29: 
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       
│   │   │       path = 'nonexistent.file'
│   │   │       
│   │   │           def read_file(path):
│   │   │       >       with open(path, "r", encoding="utf-8") as f:
│   │   │       E       FileNotFoundError: [Errno 2] No such file or directory: 
│   │   │       'nonexistent.file'
│   │   │       
│   │   │       functions/io_utils.py:2: FileNotFoundError
│   │   └── teardown
│   │       ├── duration: 0.00013819406740367413
│   │       └── 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.000188145088031888
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00016653095372021198
│   │   │   ├── 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 0x7f4653b9f460>
│   │   │       
│   │   │           def test_permission_error(monkeypatch):
│   │   │               # Patch open to raise PermissionError simulating access 
│   │   │       denial
│   │   │               def raise_perm_error(*args, **kwargs):
│   │   │                   raise PermissionError("Permission denied")
│   │   │               monkeypatch.setattr("builtins.open", raise_perm_error)
│   │   │       >       read_file("anyfile.txt")
│   │   │       
│   │   │       tests/test_io_utils.py:36: 
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       functions/io_utils.py:2: in read_file
│   │   │           with open(path, "r", encoding="utf-8") as f:
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       
│   │   │       args = ('anyfile.txt', 'r'), kwargs = {'encoding': 'utf-8'}
│   │   │       
│   │   │           def raise_perm_error(*args, **kwargs):
│   │   │       >       raise PermissionError("Permission denied")
│   │   │       E       PermissionError: Permission denied
│   │   │       
│   │   │       tests/test_io_utils.py:34: PermissionError
│   │   └── teardown
│   │       ├── duration: 0.00015965220518410206
│   │       └── 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.0001903099473565817
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.003129048040136695
│   │   │   ├── outcome: failed
│   │   │   ├── crash
│   │   │   │   ├── path: 
│   │   │   │   │   /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/un
│   │   │   │   │   ittest/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 0x7f4653f9adf0>
│   │   │       
│   │   │           def test_mock_open_error(monkeypatch):
│   │   │               # Mock open() to raise IOError simulating read error
│   │   │               mocked_open = mock.mock_open()
│   │   │               mocked_open.side_effect = IOError("Mocked IOError")
│   │   │               monkeypatch.setattr("builtins.open", mocked_open)
│   │   │       >       with open("file.txt", "r") as f:
│   │   │       
│   │   │       tests/test_io_utils.py:43: 
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       .pixi/envs/default/lib/python3.8/unittest/mock.py:1081: in 
│   │   │       __call__
│   │   │           return self._mock_call(*args, **kwargs)
│   │   │       .pixi/envs/default/lib/python3.8/unittest/mock.py:1085: in 
│   │   │       _mock_call
│   │   │           return self._execute_mock_call(*args, **kwargs)
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       
│   │   │       self = <MagicMock name='open' spec='builtin_function_or_method' 
│   │   │       id='139940033308416'>
│   │   │       args = ('file.txt', 'r'), kwargs = {}, effect = OSError('Mocked 
│   │   │       IOError')
│   │   │       
│   │   │           def _execute_mock_call(self, /, *args, **kwargs):
│   │   │               # separate from _increment_mock_call so that awaited 
│   │   │       functions are
│   │   │               # executed separately from their call, also AsyncMock 
│   │   │       overrides this method
│   │   │           
│   │   │               effect = self.side_effect
│   │   │               if effect is not None:
│   │   │                   if _is_exception(effect):
│   │   │       >               raise effect
│   │   │       E               OSError: Mocked IOError
│   │   │       
│   │   │       .pixi/envs/default/lib/python3.8/unittest/mock.py:1140: OSError
│   │   └── teardown
│   │       ├── duration: 0.000293264864012599
│   │       └── 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.000146408099681139
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00018175807781517506
│   │   │   ├── 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():
│   │   │               # Accessing closed file raises ValueError
│   │   │               f = io.StringIO("content")
│   │   │               f.close()
│   │   │       >       f.read()
│   │   │       E       ValueError: I/O operation on closed file
│   │   │       
│   │   │       tests/test_io_utils.py:50: ValueError
│   │   └── teardown
│   │       ├── duration: 0.00016809883527457714
│   │       └── 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.0002402861136943102
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00017652916721999645
│   │   │   ├── 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 0x7f4653f6c0d0>
│   │   │       
│   │   │           def test_os_error(monkeypatch):
│   │   │               # Patch os.remove to raise OSError simulating filesystem
│   │   │       error
│   │   │               def raise_os_error(path):
│   │   │                   raise OSError("Simulated OSError")
│   │   │               monkeypatch.setattr("os.remove", raise_os_error)
│   │   │       >       os.remove("file.txt")
│   │   │       
│   │   │       tests/test_io_utils.py:57: 
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       
│   │   │       path = 'file.txt'
│   │   │       
│   │   │           def raise_os_error(path):
│   │   │       >       raise OSError("Simulated OSError")
│   │   │       E       OSError: Simulated OSError
│   │   │       
│   │   │       tests/test_io_utils.py:55: OSError
│   │   └── teardown
│   │       ├── duration: 0.00016252393834292889
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_io_utils.py::test_write_file_in_readonly_mode
│   │   ├── lineno: 58
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_write_file_in_readonly_mode
│   │   │   ├── test_io_utils.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.0005913102068006992
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0008393789175897837
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00013577588833868504
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_io_utils.py::test_file_not_found_error
│   │   ├── lineno: 67
│   │   ├── outcome: failed
│   │   ├── keywords
│   │   │   ├── test_file_not_found_error
│   │   │   ├── test_io_utils.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00011547398753464222
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00016303407028317451
│   │   │   ├── outcome: failed
│   │   │   ├── crash
│   │   │   │   ├── path: /workspace/tligui_y/slic/tests/test_io_utils.py
│   │   │   │   ├── lineno: 70
│   │   │   │   └── message: FileNotFoundError: [Errno 2] No such file or 
│   │   │   │       directory: 'no_such_file.txt'
│   │   │   ├── traceback
│   │   │   │   └── -
│   │   │   │       ├── path: tests/test_io_utils.py
│   │   │   │       ├── lineno: 70
│   │   │   │       └── message: FileNotFoundError
│   │   │   └── longrepr: def test_file_not_found_error():
│   │   │               # Raises FileNotFoundError when opening a non-existent 
│   │   │       file
│   │   │       >       open("no_such_file.txt", "r")
│   │   │       E       FileNotFoundError: [Errno 2] No such file or directory: 
│   │   │       'no_such_file.txt'
│   │   │       
│   │   │       tests/test_io_utils.py:70: FileNotFoundError
│   │   └── teardown
│   │       ├── duration: 0.0001443119253963232
│   │       └── 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.00013014301657676697
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001509960275143385
│   │   │   ├── 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():
│   │   │               # simulating a broken or faulty test implementation that
│   │   │       will cause the test to error
│   │   │       >       want_the_test_to_fail
│   │   │       E       NameError: name 'want_the_test_to_fail' is not defined
│   │   │       
│   │   │       tests/test_math_utils.py:16: NameError
│   │   └── teardown
│   │       ├── duration: 0.00013376190327107906
│   │       └── 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.00012259790673851967
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.000153364147990942
│   │   │   ├── 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():
│   │   │               # Accessing a missing function attribute raises 
│   │   │       AttributeError
│   │   │       >       getattr(math_utils, "non_existent_function")()
│   │   │       E       AttributeError: module 'functions.math_utils' has no 
│   │   │       attribute 'non_existent_function'
│   │   │       
│   │   │       tests/test_math_utils.py:20: AttributeError
│   │   └── teardown
│   │       ├── duration: 0.00014212308451533318
│   │       └── 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.000274997903034091
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00014888704754412174
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00014776107855141163
│   │       └── 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.0002465848810970783
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00014202878810465336
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00013178098015487194
│   │       └── 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.00024101301096379757
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00014324416406452656
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00013298401609063148
│   │       └── 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.0002320348285138607
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00013249111361801624
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.0001308009959757328
│   │       └── 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.00024029891937971115
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00013662106357514858
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.0001331409439444542
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_math_utils.py::test_addition_pass_id
│   │   ├── lineno: 36
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_addition_pass_id
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── a=2,b=2,expected=4
│   │   │   ├── test_math_utils.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.0002354609314352274
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00014643697068095207
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00013262894935905933
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_math_utils.py::test_addition_pass_id
│   │   ├── lineno: 36
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_addition_pass_id
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── a=1,b=5,expected=6
│   │   │   ├── test_math_utils.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.000231041107326746
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00013674492947757244
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00013268901966512203
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_math_utils.py::test_addition_pass_id
│   │   ├── lineno: 36
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_addition_pass_id
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── a=3,b=4,expected=7
│   │   │   ├── test_math_utils.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00023625511676073074
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00013280101120471954
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.0001279059797525406
│   │       └── 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.00010489183478057384
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0004359888844192028
│   │   │   ├── outcome: failed
│   │   │   ├── crash
│   │   │   │   ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py
│   │   │   │   ├── lineno: 51
│   │   │   │   └── message: assert 4 == 5
│   │   │   │        +  where 4 = addition(2, 2)
│   │   │   ├── traceback
│   │   │   │   └── -
│   │   │   │       ├── path: tests/test_math_utils.py
│   │   │   │       ├── lineno: 51
│   │   │   │       └── message: AssertionError
│   │   │   └── longrepr: def test_addition_fail():
│   │   │               # Assertion failure: expected incorrect result
│   │   │       >       assert addition(2, 2) == 5
│   │   │       E       assert 4 == 5
│   │   │       E        +  where 4 = addition(2, 2)
│   │   │       
│   │   │       tests/test_math_utils.py:51: AssertionError
│   │   └── teardown
│   │       ├── duration: 0.0001498139463365078
│   │       └── 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.00012319395318627357
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00015292898751795292
│   │   │   ├── 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():
│   │   │               # Will raise ZeroDivisionError if not handled in 
│   │   │       division
│   │   │       >       division(1, 0)
│   │   │       
│   │   │       tests/test_math_utils.py:55: 
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       
│   │   │       a = 1, b = 0
│   │   │       
│   │   │           def division(a, b):
│   │   │       >       return a / b
│   │   │       E       ZeroDivisionError: division by zero
│   │   │       
│   │   │       functions/math_utils.py:5: ZeroDivisionError
│   │   └── teardown
│   │       ├── duration: 0.00013719499111175537
│   │       └── 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.00013488414697349072
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0002619961742311716
│   │   │   ├── outcome: skipped
│   │   │   ├── crash
│   │   │   │   ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py
│   │   │   │   ├── lineno: 60
│   │   │   │   └── message: assert 4 == 5
│   │   │   │        +  where 4 = multiply(2, 2)
│   │   │   ├── traceback
│   │   │   │   └── -
│   │   │   │       ├── path: tests/test_math_utils.py
│   │   │   │       ├── lineno: 60
│   │   │   │       └── message: AssertionError
│   │   │   └── longrepr: @pytest.mark.xfail(reason="Expected failure")
│   │   │           def test_multiply_xfail():
│   │   │               # Expected fail test (xfail): incorrect expected 
│   │   │       multiply result
│   │   │       >       assert multiply(2, 2) == 5
│   │   │       E       assert 4 == 5
│   │   │       E        +  where 4 = multiply(2, 2)
│   │   │       
│   │   │       tests/test_math_utils.py:60: AssertionError
│   │   └── teardown
│   │       ├── duration: 0.00013590720482170582
│   │       └── 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.00011499808169901371
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001471762079745531
│   │   │   ├── 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():
│   │   │               # Test raises an uncaught RuntimeError
│   │   │       >       raise RuntimeError("Forced runtime error")
│   │   │       E       RuntimeError: Forced runtime error
│   │   │       
│   │   │       tests/test_math_utils.py:64: RuntimeError
│   │   └── teardown
│   │       ├── duration: 0.00013177492655813694
│   │       └── 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.00011880905367434025
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001535271294414997
│   │   │   ├── 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():
│   │   │               # Manually raise MemoryError to simulate out-of-memory 
│   │   │       condition
│   │   │       >       raise MemoryError("Simulated memory error")
│   │   │       E       MemoryError: Simulated memory error
│   │   │       
│   │   │       tests/test_math_utils.py:68: MemoryError
│   │   └── teardown
│   │       ├── duration: 0.00013314909301698208
│   │       └── 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.00011596689000725746
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00014621810987591743
│   │   │   ├── 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():
│   │   │               # Manually raise TimeoutError simulating timeout 
│   │   │       conditions
│   │   │       >       raise TimeoutError("Simulated timeout error")
│   │   │       E       TimeoutError: Simulated timeout error
│   │   │       
│   │   │       tests/test_math_utils.py:72: TimeoutError
│   │   └── teardown
│   │       ├── duration: 0.00013434002175927162
│   │       └── 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.00011664209887385368
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0007643799763172865
│   │   │   ├── 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():
│   │   │               # Infinite recursion triggers RecursionError
│   │   │               def recursive():
│   │   │                   return recursive()
│   │   │       >       recursive()
│   │   │       
│   │   │       tests/test_math_utils.py:78: 
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       tests/test_math_utils.py:77: in recursive
│   │   │           return recursive()
│   │   │       tests/test_math_utils.py:77: in recursive
│   │   │           return recursive()
│   │   │       E   RecursionError: maximum recursion depth exceeded
│   │   │       !!! Recursion detected (same locals & position)
│   │   └── teardown
│   │       ├── duration: 0.0002000490203499794
│   │       └── 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.00014063785783946514
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.000174627173691988
│   │   │   ├── 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():
│   │   │               # Manually raise FloatingPointError
│   │   │       >       raise FloatingPointError("Simulated floating point 
│   │   │       error")
│   │   │       E       FloatingPointError: Simulated floating point error
│   │   │       
│   │   │       tests/test_math_utils.py:82: FloatingPointError
│   │   └── teardown
│   │       ├── duration: 0.0001514679752290249
│   │       └── 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.00012627709656953812
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00019822409376502037
│   │   │   ├── 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():
│   │   │               # Exponential overflow triggers OverflowError
│   │   │       >       math.exp(1000)
│   │   │       E       OverflowError: math range error
│   │   │       
│   │   │       tests/test_math_utils.py:86: OverflowError
│   │   └── teardown
│   │       ├── duration: 0.000159447081387043
│   │       └── 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.00012492714449763298
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00015829503536224365
│   │   │   ├── 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():
│   │   │               # ValueError on invalid integer conversion
│   │   │       >       int("invalid")
│   │   │       E       ValueError: invalid literal for int() with base 10: 
│   │   │       'invalid'
│   │   │       
│   │   │       tests/test_math_utils.py:90: ValueError
│   │   └── teardown
│   │       ├── duration: 0.0001328759826719761
│   │       └── 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.00011527701281011105
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00016502104699611664
│   │   │   ├── 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():
│   │   │               # TypeError when passing wrong argument type to sum
│   │   │       >       sum(5)
│   │   │       E       TypeError: 'int' object is not iterable
│   │   │       
│   │   │       tests/test_math_utils.py:94: TypeError
│   │   └── teardown
│   │       ├── duration: 0.00013130786828696728
│   │       └── 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.00011565303429961205
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00014518597163259983
│   │   │   ├── 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():
│   │   │               # Raises generic unhandled Exception
│   │   │       >       raise Exception("Generic unhandled exception")
│   │   │       E       Exception: Generic unhandled exception
│   │   │       
│   │   │       tests/test_math_utils.py:98: Exception
│   │   └── teardown
│   │       ├── duration: 0.00013493397273123264
│   │       └── 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.00011826306581497192
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00015050708316266537
│   │   │   ├── 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():
│   │   │               # Raises user-defined CustomError exception
│   │   │       >       raise CustomError("Custom error simulation")
│   │   │       E       test_math_utils.CustomError: Custom error simulation
│   │   │       
│   │   │       tests/test_math_utils.py:102: CustomError
│   │   └── teardown
│   │       ├── duration: 0.00013376399874687195
│   │       └── 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.00011567305773496628
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00015244679525494576
│   │   │   ├── outcome: failed
│   │   │   ├── crash
│   │   │   │   ├── path: 
│   │   │   │   │   /workspace/tligui_y/slic/.pixi/envs/default/lib/python3.8/si
│   │   │   │   │   te-packages/_pytest/capture.py
│   │   │   │   ├── lineno: 880
│   │   │   │   └── message: RuntimeError: generator raised StopIteration
│   │   │   ├── traceback
│   │   │   │   ├── -
│   │   │   │   │   ├── path: 
│   │   │   │   │   │   .pixi/envs/default/lib/python3.8/site-packages/_pytest/r
│   │   │   │   │   │   unner.py
│   │   │   │   │   ├── lineno: 341
│   │   │   │   │   └── message: 
│   │   │   │   ├── -
│   │   │   │   │   ├── path: 
│   │   │   │   │   │   .pixi/envs/default/lib/python3.8/site-packages/_pytest/r
│   │   │   │   │   │   unner.py
│   │   │   │   │   ├── lineno: 242
│   │   │   │   │   └── message: in <lambda>
│   │   │   │   ├── -
│   │   │   │   │   ├── path: 
│   │   │   │   │   │   .pixi/envs/default/lib/python3.8/site-packages/pluggy/_h
│   │   │   │   │   │   ooks.py
│   │   │   │   │   ├── lineno: 513
│   │   │   │   │   └── message: in __call__
│   │   │   │   ├── -
│   │   │   │   │   ├── path: 
│   │   │   │   │   │   .pixi/envs/default/lib/python3.8/site-packages/pluggy/_m
│   │   │   │   │   │   anager.py
│   │   │   │   │   ├── lineno: 120
│   │   │   │   │   └── message: in _hookexec
│   │   │   │   ├── -
│   │   │   │   │   ├── path: 
│   │   │   │   │   │   .pixi/envs/default/lib/python3.8/site-packages/_pytest/t
│   │   │   │   │   │   hreadexception.py
│   │   │   │   │   ├── lineno: 92
│   │   │   │   │   └── message: in pytest_runtest_call
│   │   │   │   ├── -
│   │   │   │   │   ├── path: 
│   │   │   │   │   │   .pixi/envs/default/lib/python3.8/site-packages/_pytest/t
│   │   │   │   │   │   hreadexception.py
│   │   │   │   │   ├── lineno: 68
│   │   │   │   │   └── message: in thread_exception_runtest_hook
│   │   │   │   ├── -
│   │   │   │   │   ├── path: 
│   │   │   │   │   │   .pixi/envs/default/lib/python3.8/site-packages/_pytest/u
│   │   │   │   │   │   nraisableexception.py
│   │   │   │   │   ├── lineno: 95
│   │   │   │   │   └── message: in pytest_runtest_call
│   │   │   │   ├── -
│   │   │   │   │   ├── path: 
│   │   │   │   │   │   .pixi/envs/default/lib/python3.8/site-packages/_pytest/u
│   │   │   │   │   │   nraisableexception.py
│   │   │   │   │   ├── lineno: 70
│   │   │   │   │   └── message: in unraisable_exception_runtest_hook
│   │   │   │   ├── -
│   │   │   │   │   ├── path: 
│   │   │   │   │   │   .pixi/envs/default/lib/python3.8/site-packages/_pytest/l
│   │   │   │   │   │   ogging.py
│   │   │   │   │   ├── lineno: 846
│   │   │   │   │   └── message: in pytest_runtest_call
│   │   │   │   ├── -
│   │   │   │   │   ├── path: 
│   │   │   │   │   │   .pixi/envs/default/lib/python3.8/site-packages/_pytest/l
│   │   │   │   │   │   ogging.py
│   │   │   │   │   ├── lineno: 829
│   │   │   │   │   └── message: in _runtest_for
│   │   │   │   └── -
│   │   │   │       ├── path: 
│   │   │   │       │   .pixi/envs/default/lib/python3.8/site-packages/_pytest/c
│   │   │   │       │   apture.py
│   │   │   │       ├── lineno: 880
│   │   │   │       └── message: RuntimeError
│   │   │   └── longrepr: def test_stop_iteration_direct():
│   │   │               # Directly raise StopIteration exception
│   │   │       >       raise StopIteration()
│   │   │       E       StopIteration
│   │   │       
│   │   │       tests/test_math_utils.py:106: StopIteration
│   │   │       
│   │   │       The above exception was the direct cause of the following 
│   │   │       exception:
│   │   │       
│   │   │       cls = <class '_pytest.runner.CallInfo'>
│   │   │       func = <function call_and_report.<locals>.<lambda> at 
│   │   │       0x7f4653c3a670>
│   │   │       when = 'call'
│   │   │       reraise = (<class '_pytest.outcomes.Exit'>, <class 
│   │   │       'KeyboardInterrupt'>)
│   │   │       
│   │   │           @classmethod
│   │   │           def from_call(
│   │   │               cls,
│   │   │               func: Callable[[], TResult],
│   │   │               when: Literal["collect", "setup", "call", "teardown"],
│   │   │               reraise: type[BaseException] | 
│   │   │       tuple[type[BaseException], ...] | None = None,
│   │   │           ) -> CallInfo[TResult]:
│   │   │               """Call func, wrapping the result in a CallInfo.
│   │   │           
│   │   │               :param func:
│   │   │                   The function to call. Called without arguments.
│   │   │               :type func: Callable[[], _pytest.runner.TResult]
│   │   │               :param when:
│   │   │                   The phase in which the function is called.
│   │   │               :param reraise:
│   │   │                   Exception or exceptions that shall propagate if 
│   │   │       raised by the
│   │   │                   function, instead of being wrapped in the CallInfo.
│   │   │               """
│   │   │               excinfo = None
│   │   │               start = timing.time()
│   │   │               precise_start = timing.perf_counter()
│   │   │               try:
│   │   │       >           result: TResult | None = func()
│   │   │       
│   │   │       .pixi/envs/default/lib/python3.8/site-packages/_pytest/runner.py
│   │   │       :341: 
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       .pixi/envs/default/lib/python3.8/site-packages/_pytest/runner.py
│   │   │       :242: in <lambda>
│   │   │           lambda: runtest_hook(item=item, **kwds), when=when, 
│   │   │       reraise=reraise
│   │   │       .pixi/envs/default/lib/python3.8/site-packages/pluggy/_hooks.py:
│   │   │       513: in __call__
│   │   │           return self._hookexec(self.name, self._hookimpls.copy(), 
│   │   │       kwargs, firstresult)
│   │   │       .pixi/envs/default/lib/python3.8/site-packages/pluggy/_manager.p
│   │   │       y:120: in _hookexec
│   │   │           return self._inner_hookexec(hook_name, methods, kwargs, 
│   │   │       firstresult)
│   │   │       .pixi/envs/default/lib/python3.8/site-packages/_pytest/threadexc
│   │   │       eption.py:92: in pytest_runtest_call
│   │   │           yield from thread_exception_runtest_hook()
│   │   │       .pixi/envs/default/lib/python3.8/site-packages/_pytest/threadexc
│   │   │       eption.py:68: in thread_exception_runtest_hook
│   │   │           yield
│   │   │       .pixi/envs/default/lib/python3.8/site-packages/_pytest/unraisabl
│   │   │       eexception.py:95: in pytest_runtest_call
│   │   │           yield from unraisable_exception_runtest_hook()
│   │   │       .pixi/envs/default/lib/python3.8/site-packages/_pytest/unraisabl
│   │   │       eexception.py:70: in unraisable_exception_runtest_hook
│   │   │           yield
│   │   │       .pixi/envs/default/lib/python3.8/site-packages/_pytest/logging.p
│   │   │       y:846: in pytest_runtest_call
│   │   │           yield from self._runtest_for(item, "call")
│   │   │       .pixi/envs/default/lib/python3.8/site-packages/_pytest/logging.p
│   │   │       y:829: in _runtest_for
│   │   │           yield
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       
│   │   │       self = <CaptureManager _method='no' 
│   │   │       _global_capturing=<MultiCapture out=None err=None in_=None 
│   │   │       _state='suspended' _in_suspended=False> _capture_fixture=None>
│   │   │       item = <Function test_stop_iteration_direct>
│   │   │       
│   │   │           @hookimpl(wrapper=True)
│   │   │           def pytest_runtest_call(self, item: Item) -> 
│   │   │       Generator[None]:
│   │   │               with self.item_capture("call", item):
│   │   │       >           return (yield)
│   │   │       E           RuntimeError: generator raised StopIteration
│   │   │       
│   │   │       .pixi/envs/default/lib/python3.8/site-packages/_pytest/capture.p
│   │   │       y:880: RuntimeError
│   │   └── teardown
│   │       ├── duration: 0.0002570070791989565
│   │       └── 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.0001401419285684824
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00017015007324516773
│   │   │   ├── 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():
│   │   │               # Directly raise GeneratorExit exception
│   │   │       >       raise GeneratorExit()
│   │   │       E       GeneratorExit
│   │   │       
│   │   │       tests/test_math_utils.py:110: GeneratorExit
│   │   └── teardown
│   │       ├── duration: 0.0002235090360045433
│   │       └── 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.0001559099182486534
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00018543400801718235
│   │   │   ├── outcome: failed
│   │   │   ├── crash
│   │   │   │   ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py
│   │   │   │   ├── lineno: 114
│   │   │   │   └── message:   File "<string>", line 1
│   │   │   │           def bad(:
│   │   │   │                   ^
│   │   │   │       SyntaxError: invalid syntax
│   │   │   ├── traceback
│   │   │   │   └── -
│   │   │   │       ├── path: tests/test_math_utils.py
│   │   │   │       ├── lineno: 114
│   │   │   │       └── message: SyntaxError
│   │   │   └── longrepr: def test_malformed_code():
│   │   │               # SyntaxError when executing malformed Python code
│   │   │       >       exec("def bad(:\n pass")
│   │   │       E         File "<string>", line 1
│   │   │       E           def bad(:
│   │   │       E                   ^
│   │   │       E       SyntaxError: invalid syntax
│   │   │       
│   │   │       tests/test_math_utils.py:114: SyntaxError
│   │   └── teardown
│   │       ├── duration: 0.0001730069052428007
│   │       └── 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.0001277630217373371
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00017202692106366158
│   │   │   ├── 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():
│   │   │               # Simulate SystemExit via sys.exit
│   │   │       >       sys.exit(1)
│   │   │       E       SystemExit: 1
│   │   │       
│   │   │       tests/test_math_utils.py:118: SystemExit
│   │   └── teardown
│   │       ├── duration: 0.00013296399265527725
│   │       └── 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.00011862791143357754
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00015087611973285675
│   │   │   ├── 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():
│   │   │               # Simulate broken function raising TypeError
│   │   │               def broken_func(*args, **kwargs):
│   │   │                   raise TypeError("Broken function")
│   │   │       >       broken_func()
│   │   │       
│   │   │       tests/test_math_utils.py:124: 
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       
│   │   │       args = (), kwargs = {}
│   │   │       
│   │   │           def broken_func(*args, **kwargs):
│   │   │       >       raise TypeError("Broken function")
│   │   │       E       TypeError: Broken function
│   │   │       
│   │   │       tests/test_math_utils.py:123: TypeError
│   │   └── teardown
│   │       ├── duration: 0.00013840594328939915
│   │       └── 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.00011608609929680824
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00015037599951028824
│   │   │   ├── outcome: failed
│   │   │   ├── crash
│   │   │   │   ├── path: /workspace/tligui_y/slic/tests/test_math_utils.py
│   │   │   │   ├── lineno: 128
│   │   │   │   └── message: ImportError: Simulated ImportError
│   │   │   ├── traceback
│   │   │   │   └── -
│   │   │   │       ├── path: tests/test_math_utils.py
│   │   │   │       ├── lineno: 128
│   │   │   │       └── message: ImportError
│   │   │   └── longrepr: def test_import_error():
│   │   │               # Directly raise ImportError exception
│   │   │       >       raise ImportError("Simulated ImportError")
│   │   │       E       ImportError: Simulated ImportError
│   │   │       
│   │   │       tests/test_math_utils.py:128: ImportError
│   │   └── teardown
│   │       ├── duration: 0.00013322709128260612
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_math_utils.py::test_module_not_found_error
│   │   ├── lineno: 129
│   │   ├── outcome: failed
│   │   ├── keywords
│   │   │   ├── test_module_not_found_error
│   │   │   ├── test_math_utils.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00012682913802564144
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0004667481407523155
│   │   │   ├── outcome: failed
│   │   │   ├── crash
│   │   │   │   ├── path: <frozen importlib._bootstrap>
│   │   │   │   ├── lineno: 973
│   │   │   │   └── message: ModuleNotFoundError: No module named 
│   │   │   │       'non_existent_module_xyz'
│   │   │   ├── traceback
│   │   │   │   ├── -
│   │   │   │   │   ├── path: tests/test_math_utils.py
│   │   │   │   │   ├── lineno: 132
│   │   │   │   │   └── message: 
│   │   │   │   ├── -
│   │   │   │   │   ├── path: 
│   │   │   │   │   │   .pixi/envs/default/lib/python3.8/importlib/__init__.py
│   │   │   │   │   ├── lineno: 127
│   │   │   │   │   └── message: in import_module
│   │   │   │   ├── -
│   │   │   │   │   ├── path: <frozen importlib._bootstrap>
│   │   │   │   │   ├── lineno: 1014
│   │   │   │   │   └── message: in _gcd_import
│   │   │   │   ├── -
│   │   │   │   │   ├── path: <frozen importlib._bootstrap>
│   │   │   │   │   ├── lineno: 991
│   │   │   │   │   └── message: in _find_and_load
│   │   │   │   └── -
│   │   │   │       ├── path: <frozen importlib._bootstrap>
│   │   │   │       ├── lineno: 973
│   │   │   │       └── message: ModuleNotFoundError
│   │   │   └── longrepr: def test_module_not_found_error():
│   │   │               # Raises ModuleNotFoundError (subclass of ImportError) 
│   │   │       for missing module
│   │   │       >       importlib.import_module("non_existent_module_xyz")
│   │   │       
│   │   │       tests/test_math_utils.py:132: 
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       .pixi/envs/default/lib/python3.8/importlib/__init__.py:127: in 
│   │   │       import_module
│   │   │           return _bootstrap._gcd_import(name, package, level)
│   │   │       <frozen importlib._bootstrap>:1014: in _gcd_import
│   │   │           ???
│   │   │       <frozen importlib._bootstrap>:991: in _find_and_load
│   │   │           ???
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       
│   │   │       name = 'non_existent_module_xyz'
│   │   │       import_ = <function _gcd_import at 0x7f46582ab4c0>
│   │   │       
│   │   │       >   ???
│   │   │       E   ModuleNotFoundError: No module named 
│   │   │       'non_existent_module_xyz'
│   │   │       
│   │   │       <frozen importlib._bootstrap>:973: ModuleNotFoundError
│   │   └── teardown
│   │       ├── duration: 0.00014841812662780285
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_basic_ids
│   │   ├── lineno: 3
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_basic_ids
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── one
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.0002442058175802231
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001374250277876854
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00013315817341208458
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_basic_ids
│   │   ├── lineno: 3
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_basic_ids
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── two
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00018523097969591618
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00012714113108813763
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.0001241189893335104
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_with_reason_and_marks
│   │   ├── lineno: 11
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_with_reason_and_marks
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── ten
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.0001629700418561697
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001207590103149414
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00010932702571153641
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_with_reason_and_marks
│   │   ├── lineno: 11
│   │   ├── outcome: skipped
│   │   ├── keywords
│   │   │   ├── test_with_reason_and_marks
│   │   │   ├── parametrize
│   │   │   ├── skip
│   │   │   ├── pytestmark
│   │   │   ├── twenty
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.0002305211964994669
│   │   │   ├── outcome: skipped
│   │   │   └── longrepr: ('/workspace/tligui_y/slic/tests/test_param.py', 12, 
│   │   │       'Skipped: nope')
│   │   └── teardown
│   │       ├── duration: 0.0001095819752663374
│   │       └── 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.00022646505385637283
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001257800031453371
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.0001227930188179016
│   │       └── 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.00020934292115271091
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00012428313493728638
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.0001221878919750452
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_non_literal_with_id
│   │   ├── lineno: 27
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_non_literal_with_id
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── custom-obj
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00017368188127875328
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00012485100887715816
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00011228304356336594
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_timedistance_v1
│   │   ├── lineno: 43
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_timedistance_v1
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── a0-b0-expected0
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.0002495748922228813
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00012239092029631138
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.0001411831472069025
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_timedistance_v1
│   │   ├── lineno: 43
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_timedistance_v1
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── a1-b1-expected1
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00025183381512761116
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001275939866900444
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00012988620437681675
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_sum_positive
│   │   ├── lineno: 55
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_sum_positive
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── one
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00021187192760407925
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00012215296737849712
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00012564309872686863
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_sum_positive
│   │   ├── lineno: 55
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_sum_positive
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── two
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00023218290880322456
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001246519386768341
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00012002512812614441
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_sum_positive
│   │   ├── lineno: 55
│   │   ├── outcome: failed
│   │   ├── keywords
│   │   │   ├── test_sum_positive
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── edge
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00020181690342724323
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0002511769998818636
│   │   │   ├── outcome: failed
│   │   │   ├── crash
│   │   │   │   ├── path: /workspace/tligui_y/slic/tests/test_param.py
│   │   │   │   ├── lineno: 58
│   │   │   │   └── message: assert (-1 + -1) >= 0
│   │   │   ├── traceback
│   │   │   │   └── -
│   │   │   │       ├── path: tests/test_param.py
│   │   │   │       ├── lineno: 58
│   │   │   │       └── message: AssertionError
│   │   │   └── longrepr: x = -1, y = -1
│   │   │       
│   │   │           @pytest.mark.parametrize("x, y", [(param["x"], param["y"]) 
│   │   │       for _, param in scenarios], ids=)
│   │   │           def test_sum_positive(x, y):
│   │   │       >       assert (x + y) >= 0
│   │   │       E       assert (-1 + -1) >= 0
│   │   │       
│   │   │       tests/test_param.py:58: AssertionError
│   │   └── teardown
│   │       ├── duration: 0.00017045391723513603
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_dynamic
│   │   ├── lineno: 65
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_dynamic
│   │   │   ├── ten
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.0001841471530497074
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00012887688353657722
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00011754082515835762
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_dynamic
│   │   ├── lineno: 65
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_dynamic
│   │   │   ├── twenty
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00016175792552530766
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001264750026166439
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00011478317901492119
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_dynamic
│   │   ├── lineno: 65
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_dynamic
│   │   │   ├── thirty
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00015746918506920338
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00011882302351295948
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00011976715177297592
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_element_type[\U0001f525]
│   │   ├── lineno: 74
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_element_type[\U0001f525]
│   │   │   ├── \U0001f525
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00016128900460898876
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00012357579544186592
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00011158897541463375
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_element_type[\U0001f4a7]
│   │   ├── lineno: 74
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_element_type[\U0001f4a7]
│   │   │   ├── \U0001f4a7
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00015907897613942623
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00011821999214589596
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.0001072390004992485
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_element_type[\U0001f30d]
│   │   ├── lineno: 74
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_element_type[\U0001f30d]
│   │   │   ├── \U0001f30d
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.000163292046636343
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00011593499220907688
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00010616285726428032
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_combination
│   │   ├── lineno: 78
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_combination
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── a-1
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00020413589663803577
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00012762704864144325
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00012224819511175156
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_combination
│   │   ├── lineno: 78
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_combination
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── a-2
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.0001988599542528391
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00011959811672568321
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00011924607679247856
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_combination
│   │   ├── lineno: 78
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_combination
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── b-1
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00020448514260351658
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.000125393969938159
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00012157694436609745
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_combination
│   │   ├── lineno: 78
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_combination
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── b-2
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00019445782527327538
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001366769429296255
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.0001191399060189724
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_indirect_fixture[1]
│   │   ├── lineno: 89
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_indirect_fixture[1]
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── 1
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00016290508210659027
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001243001315742731
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00011174706742167473
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_indirect_fixture[2]
│   │   ├── lineno: 89
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_indirect_fixture[2]
│   │   │   ├── parametrize
│   │   │   ├── pytestmark
│   │   │   ├── 2
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.0001549671869724989
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00011884607374668121
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00011124880984425545
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_addition
│   │   ├── lineno: 94
│   │   ├── outcome: failed
│   │   ├── keywords
│   │   │   ├── test_addition
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00010213116183876991
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001375058200210333
│   │   │   ├── outcome: failed
│   │   │   ├── crash
│   │   │   │   ├── path: /workspace/tligui_y/slic/tests/test_param.py
│   │   │   │   ├── lineno: 97
│   │   │   │   └── message: NameError: name 'addition' is not defined
│   │   │   ├── traceback
│   │   │   │   └── -
│   │   │   │       ├── path: tests/test_param.py
│   │   │   │       ├── lineno: 97
│   │   │   │       └── message: NameError
│   │   │   └── longrepr: a = 5, b = 5, expected = 10
│   │   │       
│   │   │           def test_addition(a = 5, b = 5, expected = 10):
│   │   │               # Has to pass
│   │   │       >       assert addition(a, b) == expected
│   │   │       E       NameError: name 'addition' is not defined
│   │   │       
│   │   │       tests/test_param.py:97: NameError
│   │   └── teardown
│   │       ├── duration: 0.00013691699132323265
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_param.py::test_basic_error
│   │   ├── lineno: 99
│   │   ├── outcome: error
│   │   ├── keywords
│   │   │   ├── test_basic_error
│   │   │   ├── test_param.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.0001480488572269678
│   │   │   ├── outcome: failed
│   │   │   └── longrepr: file /workspace/tligui_y/slic/tests/test_param.py, 
│   │   │       line 100
│   │   │         def test_basic_error(x):
│   │   │       E       fixture 'x' not found
│   │   │       >       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
│   │   │       >       use 'pytest --fixtures ' for help on them.
│   │   │       
│   │   │       /workspace/tligui_y/slic/tests/test_param.py:100
│   │   └── teardown
│   │       ├── duration: 0.00011697201989591122
│   │       └── 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.00011956715025007725
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001406688243150711
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00010104989632964134
│   │       └── 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.00010715401731431484
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00014039897359907627
│   │   │   ├── 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():
│   │   │               # TypeError when input is None (invalid input)
│   │   │       >       uppercase(None)
│   │   │       
│   │   │       tests/test_string_utils.py:16: 
│   │   │       _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
│   │   │       _ _ _ _ _ _ _ _ 
│   │   │       
│   │   │       s = None
│   │   │       
│   │   │           def uppercase(s):
│   │   │               if s is None:
│   │   │       >           raise TypeError("Input cannot be None")
│   │   │       E           TypeError: Input cannot be None
│   │   │       
│   │   │       functions/string_utils.py:3: TypeError
│   │   └── teardown
│   │       ├── duration: 0.00014745001681149006
│   │       └── 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.00012111011892557144
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001391430851072073
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00011099805124104023
│   │       └── 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.00010522408410906792
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00014200713485479355
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 9.662401862442493e-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.00010338891297578812
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0001396569423377514
│   │   │   ├── 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():
│   │   │               # UnicodeDecodeError when decoding invalid byte sequence
│   │   │       >       b'\xff'.decode('utf-8')
│   │   │       E       UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff
│   │   │       in position 0: invalid start byte
│   │   │       
│   │   │       tests/test_string_utils.py:28: UnicodeDecodeError
│   │   └── teardown
│   │       ├── duration: 0.00012978003360331059
│   │       └── 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.00013086479157209396
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00015064002946019173
│   │   │   ├── 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():
│   │   │               # UnicodeDecodeError with strict error handler on 
│   │   │       invalid byte
│   │   │       >       b"\x80".decode("utf-8", errors="strict")
│   │   │       E       UnicodeDecodeError: 'utf-8' codec can't decode byte 0x80
│   │   │       in position 0: invalid start byte
│   │   │       
│   │   │       tests/test_string_utils.py:32: UnicodeDecodeError
│   │   └── teardown
│   │       ├── duration: 0.00013115303590893745
│   │       └── outcome: passed
│   ├── -
│   │   ├── nodeid: tests/test_string_utils.py::test_syntax_warning
│   │   ├── lineno: 33
│   │   ├── outcome: passed
│   │   ├── keywords
│   │   │   ├── test_syntax_warning
│   │   │   ├── test_string_utils.py
│   │   │   ├── tests
│   │   │   ├── slic
│   │   │   └── 
│   │   ├── setup
│   │   │   ├── duration: 0.00011464487761259079
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.00014321994967758656
│   │   │   └── outcome: passed
│   │   └── teardown
│   │       ├── duration: 0.00010527088306844234
│   │       └── 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.00012233597226440907
│   │   │   └── outcome: passed
│   │   ├── call
│   │   │   ├── duration: 0.0006404821760952473
│   │   │   ├── outcome: skipped
│   │   │   ├── crash
│   │   │   │   ├── path: /workspace/tligui_y/slic/tests/test_string_utils.py
│   │   │   │   ├── lineno: 41
│   │   │   │   └── message: AssertionError: assert 'ABC123' == 'ABC1234'
│   │   │   │         
│   │   │   │         - ABC1234
│   │   │   │         ?       -
│   │   │   │         + ABC123
│   │   │   ├── traceback
│   │   │   │   └── -
│   │   │   │       ├── path: tests/test_string_utils.py
│   │   │   │       ├── lineno: 41
│   │   │   │       └── message: AssertionError
│   │   │   └── longrepr: @pytest.mark.xfail(reason="Expected failure: uppercase
│   │   │       does not handle digits")
│   │   │           def test_xfail_uppercase_digits():
│   │   │               # Expected fail test because uppercase won't change 
│   │   │       digits
│   │   │       >       assert uppercase("abc123") == "ABC1234"
│   │   │       E       AssertionError: assert 'ABC123' == 'ABC1234'
│   │   │       E         
│   │   │       E         - ABC1234
│   │   │       E         ?       -
│   │   │       E         + ABC123
│   │   │       
│   │   │       tests/test_string_utils.py:41: AssertionError
│   │   └── teardown
│   │       ├── duration: 0.00013234512880444527
│   │       └── 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.00011658016592264175
│           └── outcome: passed
└── warnings
    ├── -
    │   ├── message: Test warning
    │   ├── category: UserWarning
    │   ├── when: runtest
    │   ├── filename: /workspace/tligui_y/slic/tests/test_string_utils.py
    │   └── lineno: 24
    └── -
        ├── message: This is a syntax warning
        ├── category: SyntaxWarning
        ├── when: runtest
        ├── filename: /workspace/tligui_y/slic/tests/test_string_utils.py
        └── lineno: 36
