{
  "original_problem": {
    "instance_id": "pytest-dev__pytest-7168",
    "repo": "pytest-dev/pytest",
    "created_at": "2020-05-05T22:23:38Z",
    "problem_statement": "INTERNALERROR when exception in __repr__\nMinimal code to reproduce the issue: \r\n```python\r\nclass SomeClass:\r\n    def __getattribute__(self, attr):\r\n        raise\r\n    def __repr__(self):\r\n        raise\r\ndef test():\r\n    SomeClass().attr\r\n```\r\nSession traceback:\r\n```\r\n============================= test session starts ==============================\r\nplatform darwin -- Python 3.8.1, pytest-5.4.1, py-1.8.1, pluggy-0.13.1 -- /usr/local/opt/python@3.8/bin/python3.8\r\ncachedir: .pytest_cache\r\nrootdir: ******\r\nplugins: asyncio-0.10.0, mock-3.0.0, cov-2.8.1\r\ncollecting ... collected 1 item\r\n\r\ntest_pytest.py::test \r\nINTERNALERROR> Traceback (most recent call last):\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/main.py\", line 191, in wrap_session\r\nINTERNALERROR>     session.exitstatus = doit(config, session) or 0\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/main.py\", line 247, in _main\r\nINTERNALERROR>     config.hook.pytest_runtestloop(session=session)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/hooks.py\", line 286, in __call__\r\nINTERNALERROR>     return self._hookexec(self, self.get_hookimpls(), kwargs)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/manager.py\", line 93, in _hookexec\r\nINTERNALERROR>     return self._inner_hookexec(hook, methods, kwargs)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/manager.py\", line 84, in <lambda>\r\nINTERNALERROR>     self._inner_hookexec = lambda hook, methods, kwargs: hook.multicall(\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/callers.py\", line 208, in _multicall\r\nINTERNALERROR>     return outcome.get_result()\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/callers.py\", line 80, in get_result\r\nINTERNALERROR>     raise ex[1].with_traceback(ex[2])\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/callers.py\", line 187, in _multicall\r\nINTERNALERROR>     res = hook_impl.function(*args)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/main.py\", line 272, in pytest_runtestloop\r\nINTERNALERROR>     item.config.hook.pytest_runtest_protocol(item=item, nextitem=nextitem)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/hooks.py\", line 286, in __call__\r\nINTERNALERROR>     return self._hookexec(self, self.get_hookimpls(), kwargs)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/manager.py\", line 93, in _hookexec\r\nINTERNALERROR>     return self._inner_hookexec(hook, methods, kwargs)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/manager.py\", line 84, in <lambda>\r\nINTERNALERROR>     self._inner_hookexec = lambda hook, methods, kwargs: hook.multicall(\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/callers.py\", line 208, in _multicall\r\nINTERNALERROR>     return outcome.get_result()\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/callers.py\", line 80, in get_result\r\nINTERNALERROR>     raise ex[1].with_traceback(ex[2])\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/callers.py\", line 187, in _multicall\r\nINTERNALERROR>     res = hook_impl.function(*args)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/runner.py\", line 85, in pytest_runtest_protocol\r\nINTERNALERROR>     runtestprotocol(item, nextitem=nextitem)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/runner.py\", line 100, in runtestprotocol\r\nINTERNALERROR>     reports.append(call_and_report(item, \"call\", log))\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/runner.py\", line 188, in call_and_report\r\nINTERNALERROR>     report = hook.pytest_runtest_makereport(item=item, call=call)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/hooks.py\", line 286, in __call__\r\nINTERNALERROR>     return self._hookexec(self, self.get_hookimpls(), kwargs)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/manager.py\", line 93, in _hookexec\r\nINTERNALERROR>     return self._inner_hookexec(hook, methods, kwargs)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/manager.py\", line 84, in <lambda>\r\nINTERNALERROR>     self._inner_hookexec = lambda hook, methods, kwargs: hook.multicall(\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/callers.py\", line 203, in _multicall\r\nINTERNALERROR>     gen.send(outcome)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/skipping.py\", line 129, in pytest_runtest_makereport\r\nINTERNALERROR>     rep = outcome.get_result()\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/callers.py\", line 80, in get_result\r\nINTERNALERROR>     raise ex[1].with_traceback(ex[2])\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/pluggy/callers.py\", line 187, in _multicall\r\nINTERNALERROR>     res = hook_impl.function(*args)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/runner.py\", line 260, in pytest_runtest_makereport\r\nINTERNALERROR>     return TestReport.from_item_and_call(item, call)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/reports.py\", line 294, in from_item_and_call\r\nINTERNALERROR>     longrepr = item.repr_failure(excinfo)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/python.py\", line 1513, in repr_failure\r\nINTERNALERROR>     return self._repr_failure_py(excinfo, style=style)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/nodes.py\", line 355, in _repr_failure_py\r\nINTERNALERROR>     return excinfo.getrepr(\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/_code/code.py\", line 634, in getrepr\r\nINTERNALERROR>     return fmt.repr_excinfo(self)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/_code/code.py\", line 879, in repr_excinfo\r\nINTERNALERROR>     reprtraceback = self.repr_traceback(excinfo_)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/_code/code.py\", line 823, in repr_traceback\r\nINTERNALERROR>     reprentry = self.repr_traceback_entry(entry, einfo)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/_code/code.py\", line 784, in repr_traceback_entry\r\nINTERNALERROR>     reprargs = self.repr_args(entry) if not short else None\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/_code/code.py\", line 693, in repr_args\r\nINTERNALERROR>     args.append((argname, saferepr(argvalue)))\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/_io/saferepr.py\", line 82, in saferepr\r\nINTERNALERROR>     return SafeRepr(maxsize).repr(obj)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/_io/saferepr.py\", line 51, in repr\r\nINTERNALERROR>     s = _format_repr_exception(exc, x)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/_io/saferepr.py\", line 23, in _format_repr_exception\r\nINTERNALERROR>     exc_info, obj.__class__.__name__, id(obj)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/_io/saferepr.py\", line 47, in repr\r\nINTERNALERROR>     s = super().repr(x)\r\nINTERNALERROR>   File \"/usr/local/Cellar/python@3.8/3.8.1/Frameworks/Python.framework/Versions/3.8/lib/python3.8/reprlib.py\", line 52, in repr\r\nINTERNALERROR>     return self.repr1(x, self.maxlevel)\r\nINTERNALERROR>   File \"/usr/local/Cellar/python@3.8/3.8.1/Frameworks/Python.framework/Versions/3.8/lib/python3.8/reprlib.py\", line 62, in repr1\r\nINTERNALERROR>     return self.repr_instance(x, level)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/_io/saferepr.py\", line 60, in repr_instance\r\nINTERNALERROR>     s = _format_repr_exception(exc, x)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/_io/saferepr.py\", line 23, in _format_repr_exception\r\nINTERNALERROR>     exc_info, obj.__class__.__name__, id(obj)\r\nINTERNALERROR>   File \"/usr/local/lib/python3.8/site-packages/_pytest/_io/saferepr.py\", line 56, in repr_instance\r\nINTERNALERROR>     s = repr(x)\r\nINTERNALERROR>   File \"/Users/stiflou/Documents/projets/apischema/tests/test_pytest.py\", line 6, in __repr__\r\nINTERNALERROR>     raise\r\nINTERNALERROR> RuntimeError: No active exception to reraise\r\n\r\n============================ no tests ran in 0.09s ============================\r\n```\n",
    "patch": "diff --git a/src/_pytest/_io/saferepr.py b/src/_pytest/_io/saferepr.py\n--- a/src/_pytest/_io/saferepr.py\n+++ b/src/_pytest/_io/saferepr.py\n@@ -20,7 +20,7 @@ def _format_repr_exception(exc: BaseException, obj: Any) -> str:\n     except BaseException as exc:\n         exc_info = \"unpresentable exception ({})\".format(_try_repr_or_str(exc))\n     return \"<[{} raised in repr()] {} object at 0x{:x}>\".format(\n-        exc_info, obj.__class__.__name__, id(obj)\n+        exc_info, type(obj).__name__, id(obj)\n     )\n \n \n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_3883",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about a progress indicator malfunction, unrelated to exception handling or internal errors."
      },
      {
        "idx": 2,
        "id": "similar_1397",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves CI log cluttering, which does not relate to exception handling or internal errors."
      },
      {
        "idx": 3,
        "id": "similar_3088",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about incorrect progress reporting, unrelated to exception handling or internal errors."
      },
      {
        "idx": 4,
        "id": "similar_736",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves fixture and parameterization errors, not related to exception handling or internal errors."
      },
      {
        "idx": 5,
        "id": "similar_2631",
        "decision": "Useful",
        "confidence": "High",
        "reason": "This issue involves exception context handling, which is directly relevant to the current issue's exception handling in `__repr__`."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "console_output_style=classic missing tests and seems broken since 3.4.0",
        "issue_body": "Thanks for submitting an issue!\r\n\r\nHere's a quick checklist in what to include:\r\n\r\n- [x] Include a detailed description of the bug or suggestion\r\nconsole_output_style=classic seems to leave the progress indicator in place, but just leave it at 0%.\r\nThis worked in pytest 3.3 versions.\r\n\r\nI couldn't find any tests for this feature. Which may be why it wasn't caught earlier.\r\n\r\n- [x] `pip list` of the virtual environment you are using\r\n```\r\n(venv) $ pip list\r\nPackage        Version\r\n-------------- -------\r\natomicwrites   1.2.0  \r\nattrs          18.1.0 \r\nclick          6.7    \r\nmore-itertools 4.3.0  \r\npip            18.0   \r\npluggy         0.7.1  \r\npy             1.5.4  \r\npytest         3.7.2  \r\nsetuptools     39.0.1 \r\nsix            1.11.0 \r\ntinydb         3.11.0 \r\n```\r\n- [x] pytest and operating system versions\r\n\r\nplatform darwin -- Python 3.7.0, pytest-3.7.2, py-1.5.4, pluggy-0.7.1\r\nbut seems broken starting with pytest 3.4.0\r\n\r\n- [x] Minimal example if possible\r\n```\r\n(venv) $ pip install pytest==3.7.2\r\n...\r\nSuccessfully installed pluggy-0.7.1 pytest-3.7.2\r\n(venv) $ pytest --tb=no -o console_output_style=classic\r\n===================== test session starts ======================\r\nplatform darwin -- Python 3.7.0, pytest-3.7.2, py-1.5.4, pluggy-0.7.1\r\nrootdir: /Users/okken/projects/book/pytest_update/Book/code/ch1, inifile: pytest.ini\r\ncollected 6 items                                              \r\n\r\ntest_one.py .                                            [  0%]\r\ntest_two.py F                                            [  0%]\r\ntasks/test_four.py ..                                    [  0%]\r\ntasks/test_three.py ..\r\n\r\n============== 1 failed, 5 passed in 0.10 seconds ==============\r\n(venv) $ pip install pytest==3.3.2\r\n...\r\nSuccessfully installed pluggy-0.6.0 pytest-3.3.2\r\n(venv) $ pytest --tb=no -o console_output_style=classic\r\n===================== test session starts ======================\r\nplatform darwin -- Python 3.7.0, pytest-3.3.2, py-1.5.4, pluggy-0.6.0\r\nrootdir: /Users/okken/projects/book/pytest_update/Book/code/ch1, inifile: pytest.ini\r\ncollected 6 items                                              \r\n\r\ntest_one.py .\r\ntest_two.py F\r\ntasks/test_four.py ..\r\ntasks/test_three.py ..\r\n\r\n============== 1 failed, 5 passed in 0.09 seconds ==============\r\n```",
        "issue_id": 3883,
        "pr_number": 3885,
        "pr_title": "Fix bad console output when using console_output_style=classic",
        "pr_body": "Fix #3883\r\n\r\n",
        "issue_closed_at": "2018-08-27T22:07:03Z",
        "base_commit": "a31967431f3d112da547ddbd05c4efdb90cb8ad6"
      },
      "summary": "### Summary:\nThis issue is related to the \"console_output_style=classic\" option in the pytest testing framework, which appears to be malfunctioning in versions starting from 3.4.0. The primary symptom is the progress indicator remaining at 0% throughout the test execution, whereas it functioned correctly in previous versions like 3.3.2. The lack of automated tests for this feature may have contributed to the oversight and subsequent introduction of this bug. The issue affects the test reporting component of pytest, specifically the TerminalReporter class, which is responsible for handling console output during test execution. The malfunctioning progress indicator can mislead users regarding the progress and status of their test suites, potentially affecting the efficiency of testing processes and causing confusion. The problem is observed on the Darwin platform with Python 3.7 and specific package versions, highlighting a potential compatibility issue introduced in the newer pytest versions.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: console_output_style=classic missing tests and seems broken since 3.4.0\n\nBody:\nThanks for submitting an issue!\r\n\r\nHere's a quick checklist in what to include:\r\n\r\n- [x] Include a detailed description of the bug or suggestion\r\nconsole_output_style=classic seems to leave the progress indicator in place, but just leave it at 0%.\r\nThis worked in pytest 3.3 versions.\r\n\r\nI couldn't find any tests for this feature. Which may be why it wasn't caught earlier.\r\n\r\n- [x] `pip list` of the virtual environment you are using\r\n```\r\n(venv) $ pip list\r\nPackage        Version\r\n-------------- -------\r\natomicwrites   1.2.0  \r\nattrs          18.1.0 \r\nclick          6.7    \r\nmore-itertools 4.3.0  \r\npip            18.0   \r\npluggy         0.7.1  \r\npy             1.5.4  \r\npytest         3.7.2  \r\nsetuptools     39.0.1 \r\nsix            1.11.0 \r\ntinydb         3.11.0 \r\n```\r\n- [x] pytest and operating system versions\r\n\r\nplatform darwin -- Python 3.7.0, pytest-3.7.2, py-1.5.4, pluggy-0.7.1\r\nbut seems broken starting with pytest 3.4.0\r\n\r\n- [x] Minimal example if possible\r\n```\r\n(venv) $ pip install pytest==3.7.2\r\n...\r\nSuccessfully installed pluggy-0.7.1 pytest-3.7.2\r\n(venv) $ pytest --tb=no -o console_output_style=classic\r\n===================== test session starts ======================\r\nplatform darwin -- Python 3.7.0, pytest-3.7.2, py-1.5.4, pluggy-0.7.1\r\nrootdir: /Users/okken/projects/book/pytest_update/Book/code/ch1, inifile: pytest.ini\r\ncollected 6 items                                              \r\n\r\ntest_one.py .                                            [  0%]\r\ntest_two.py F                                            [  0%]\r\ntasks/test_four.py ..                                    [  0%]\r\ntasks/test_three.py ..\r\n\r\n============== 1 failed, 5 passed in 0.10 seconds ==============\r\n(venv) $ pip install pytest==3.3.2\r\n...\r\nSuccessfully installed pluggy-0.6.0 pytest-3.3.2\r\n(venv) $ pytest --tb=no -o console_output_style=classic\r\n===================== test session starts ======================\r\nplatform darwin -- Python 3.7.0, pytest-3.3.2, py-1.5.4, pluggy-0.6.0\r\nrootdir: /Users/okken/projects/book/pytest_update/Book/code/ch1, inifile: pytest.ini\r\ncollected 6 items                                              \r\n\r\ntest_one.py .\r\ntest_two.py F\r\ntasks/test_four.py ..\r\ntasks/test_three.py ..\r\n\r\n============== 1 failed, 5 passed in 0.09 seconds ==============\r\n```\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsrc/_pytest/terminal.py\n  function: TerminalReporter.hasopt\n  function: TerminalReporter.pytest_runtest_logstart\n"
    },
    {
      "similar_issue": {
        "issue_title": "\"collecting\" output with --color=yes in Continuous Integration output",
        "issue_body": "Hi,\n\nWe like to use `--color=yes` when running py.test in continuous integration services like Jenkins (with the [Ansi Color Plugin](https://wiki.jenkins-ci.org/display/JENKINS/AnsiColor+Plugin)). This enables us to see the same nice colors in Jenkins that we see on the terminal.\n\nThe only problem is that the \"collecting\" display progress actually piles up in the terminal because py.test output is being redirected and captured by the server. This can easily be reproduced by redirecting to a file instead:\n\n``` python\nimport pytest\n@pytest.mark.parametrize('i', range(10))\ndef test_foo(i):\n    if i == 5:\n        assert 0\n```\n\n```\npy.test --color=yes test_foo.py > out\n```\n\nContents of `out`:\n\n```\n\u001b[1m============================= test session starts =============================\u001b[0m\nplatform win32 -- Python 2.7.11, pytest-2.8.5, py-1.4.31, pluggy-0.3.1\nrootdir: x:\\jobs_done10, inifile: \n\u001b[1m\ncollecting 0 items\u001b[0m\u001b[1m\ncollecting 10 items\u001b[0m\u001b[1m\ncollected 10 items \n\u001b[0m\nfoo.py .....F....\n\n================================== FAILURES ===================================\n\u001b[1m\u001b[31m_________________________________ test_foo[5] _________________________________\u001b[0m\n\ni = 5\n\n\u001b[1m    @pytest.mark.parametrize('i', range(10))\u001b[0m\n\u001b[1m    def test_foo(i):\u001b[0m\n\u001b[1m        if i == 5:\u001b[0m\n\u001b[1m>           assert 0\u001b[0m\n\u001b[1m\u001b[31mE           assert 0\u001b[0m\n\nfoo.py:6: AssertionError\n\u001b[1m\u001b[31m===================== 1 failed, 9 passed in 0.02 seconds ======================\u001b[0m\n```\n\nThe color codes are correct, but the \"collecting\" messages are a problem because they occupy many lines of output in test suites with hundreds of tests.\n\nIs there any way to prevent those \"collecting\" messages from appearing? `-q` gets rid of them, but I want the header to appear, specially in CI.\n",
        "issue_id": 1397,
        "pr_number": 1405,
        "pr_title": "Display collect progress only when in a terminal",
        "pr_body": "Fix #1397\n",
        "issue_closed_at": "2016-02-21T07:17:35Z",
        "base_commit": "3874d53ee121415c5a964a3f706b97c8010796aa"
      },
      "summary": "### Summary:\n\nThis issue is related to the display of progress messages in Continuous Integration (CI) environments when utilizing the `--color=yes` option with the pytest testing framework. Specifically, the problem arises within CI services such as Jenkins, where the pytest output is redirected and captured. This redirection causes the \"collecting\" progress messages, which indicate the collection of test items, to accumulate and clutter the output log. This becomes particularly problematic in large test suites with numerous test cases, as the repeated \"collecting\" messages can fill up the CI logs, making them difficult to read and analyze.\n\nKey symptoms and behaviors observed include the excessive accumulation of \"collecting\" messages in the CI output, even when the rest of the test output appears correctly formatted with color codes. Although using the `-q` option can suppress these messages, it also removes the test session header, which is undesirable for users who wish to retain that information in CI logs.\n\nThe affected components are the pytest framework, specifically its terminal reporting functionality, and the Jenkins CI system when used with the Ansi Color Plugin. The issue impacts the readability and manageability of CI logs, potentially complicating the analysis of test results, which can hinder efficient development and testing workflows.\n\nFrom a technical perspective, the problem is associated with the TerminalReporter class within pytest, and the functions responsible for initializing the terminal reporter, logging test reports, and reporting collections. Addressing this issue likely involves modifying these functions to ensure that \"collecting\" messages do not accumulate excessively in the redirected CI output while maintaining the desired header information in the logs.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: \"collecting\" output with --color=yes in Continuous Integration output\n\nBody:\nHi,\n\nWe like to use `--color=yes` when running py.test in continuous integration services like Jenkins (with the [Ansi Color Plugin](https://wiki.jenkins-ci.org/display/JENKINS/AnsiColor+Plugin)). This enables us to see the same nice colors in Jenkins that we see on the terminal.\n\nThe only problem is that the \"collecting\" display progress actually piles up in the terminal because py.test output is being redirected and captured by the server. This can easily be reproduced by redirecting to a file instead:\n\n``` python\nimport pytest\n@pytest.mark.parametrize('i', range(10))\ndef test_foo(i):\n    if i == 5:\n        assert 0\n```\n\n```\npy.test --color=yes test_foo.py > out\n```\n\nContents of `out`:\n\n```\n\u001b[1m============================= test session starts =============================\u001b[0m\nplatform win32 -- Python 2.7.11, pytest-2.8.5, py-1.4.31, pluggy-0.3.1\nrootdir: x:\\jobs_done10, inifile: \n\u001b[1m\ncollecting 0 items\u001b[0m\u001b[1m\ncollecting 10 items\u001b[0m\u001b[1m\ncollected 10 items \n\u001b[0m\nfoo.py .....F....\n\n================================== FAILURES ===================================\n\u001b[1m\u001b[31m_________________________________ test_foo[5] _________________________________\u001b[0m\n\ni = 5\n\n\u001b[1m    @pytest.mark.parametrize('i', range(10))\u001b[0m\n\u001b[1m    def test_foo(i):\u001b[0m\n\u001b[1m        if i == 5:\u001b[0m\n\u001b[1m>           assert 0\u001b[0m\n\u001b[1m\u001b[31mE           assert 0\u001b[0m\n\nfoo.py:6: AssertionError\n\u001b[1m\u001b[31m===================== 1 failed, 9 passed in 0.02 seconds ======================\u001b[0m\n```\n\nThe color codes are correct, but the \"collecting\" messages are a problem because they occupy many lines of output in test suites with hundreds of tests.\n\nIs there any way to prevent those \"collecting\" messages from appearing? `-q` gets rid of them, but I want the header to appear, specially in CI.\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\n_pytest/terminal.py\n  function: TerminalReporter.__init__\n  function: TerminalReporter.pytest_runtest_logreport\n  function: TerminalReporter.pytest_collectreport\n  function: TerminalReporter.report_collect\n"
    },
    {
      "similar_issue": {
        "issue_title": "Invalid percentages of Test Suite progress",
        "issue_body": "Progress of Test Suite shows more than 100% if Teardown fails:\r\n```\r\n$ python3 -m pytest -v ./test.py &> res.txt; cat res.txt                                                                                                                                        \r\n============================= test session starts ==============================                                                                                                                                   \r\nplatform linux -- Python 3.6.4, pytest-3.3.1, py-1.5.0, pluggy-0.6.0 -- /usr/bin/python3\r\ncachedir: .cache\r\nrootdir: /home/pavel, inifile:\r\nplugins: allure-adaptor-1.7.8\r\ncollecting ... collected 1 item\r\n\r\ntest.py::test_foo1 PASSED                                                [100%]\r\ntest.py::test_foo1 ERROR                                                 [200%]\r\n\r\n==================================== ERRORS ====================================\r\n```\r\ntest.py:\r\n```\r\nimport pytest                                                                                                                                                                                                      \r\n\r\n@pytest.fixture\r\ndef fail_teardown():\r\n    print(\"SETUP\")\r\n    yield fail_teardown\r\n    print(\"TEARDOWN\")\r\n    assert 1 == 2\r\n\r\ndef test_foo1(fail_teardown):\r\n    print(\"TEST\")\r\n```\r\nSystem:\r\n```\r\n$ pip list 2>/dev/null                                                                                                                                                                          \r\nappdirs (1.4.3)                                                                                                                                                                                                    \r\nasn1crypto (0.24.0)                                                                                                                                                                                                \r\nattrs (17.4.0)\r\nbcrypt (3.1.4)\r\ncffi (1.11.2)\r\ncryptography (2.1.4)\r\nidna (2.6)\r\nisc (2.0)\r\njson2html (1.1.1)\r\nlxml (4.1.1)                                                                                                                                                                                                       \r\nmsgpack-python (0.4.8)                                                                                                                                                                                             \r\nnamedlist (1.7)                                                                                                                                                                                                    \r\nnetifaces (0.10.6)                                                                                                                                                                                                 \r\npackaging (16.8)                                                                                                                                                                                                   \r\nparamiko (2.4.0)                                                                                                                                                                                                   \r\npip (9.0.1)                                                                                                                                                                                                        \r\npluggy (0.6.0)                                                                                                                                                                                                     \r\nply (3.10)                                                                                                                                                                                                         \r\npy (1.5.0)                                                                                                                                                                                                         \r\npyasn1 (0.4.2)                                                                                                                                                                                                     \r\npycparser (2.18)                                                                                                                                                                                                   \r\nPyNaCl (1.2.0)                                                                                                                                                                                                     \r\npyparsing (2.2.0)                                                                                                                                                                                                  \r\npyserial (3.4)                                                                                                                                                                                                     \r\npytest (3.3.1)                                                                                                                                                                                                     \r\npytest-allure-adaptor (1.7.8)                                                                                                                                                                                      \r\nscp (0.10.2)                                                                                                                                                                                                       \r\nsetuptools (38.2.5)                                                                                                                                                                                                \r\nsix (1.11.0)                                                                                                                                                                                                       \r\nspeedtest-cli (1.0.7)                                                                                                                                                                                              \r\nws4py (0.3.4)                                                                                                                                                                                            \r\n$ uname -a                                                                                                                                                                                      \r\nLinux afitester 4.14.10-1-ARCH #1 SMP PREEMPT Fri Dec 29 20:17:35 UTC 2017 x86_64 GNU/Linux\r\n```",
        "issue_id": 3088,
        "pr_number": 3110,
        "pr_title": "Fix progress report when tests fail during teardown",
        "pr_body": "Fix #3088\r\n",
        "issue_closed_at": "2018-01-12T10:27:27Z",
        "base_commit": "b0032ba2b3258ada67bb1fa705c18af1741778fd"
      },
      "summary": "### Summary:\nThis issue is related to the inaccurate reporting of test suite progress percentages in a test automation framework when a teardown operation fails. Specifically, the progress percentage erroneously shows values exceeding 100%, such as 200%, under certain conditions.\n\n1. **Problem description in general terms:**\n   The problem involves incorrect progress reporting in a test suite execution. When the teardown process of a test fails, the reported progress percentage can exceed the logical limit of 100%, leading to misleading and confusing results.\n\n2. **Key symptoms and behaviors observed:**\n   The primary symptom is the display of an invalid progress percentage, specifically showing more than 100% completion. This occurs when the teardown phase of a test case fails, as illustrated by the example output showing a 200% completion rate for a single test case.\n\n3. **Affected components or systems:**\n   The issue affects the pytest test framework, specifically the reporting mechanism related to test progress tracking. This is evident in the test output produced by the pytest terminal reporter.\n\n4. **Potential impact or severity:**\n   The severity of the issue is moderate, as it does not directly impact the execution of tests or their outcomes but can lead to misinterpretation of test suite progress by developers and testers. Accurate progress reporting is essential for understanding the state and reliability of the test automation efforts.\n\n5. **Relevant technical details abstracted for broader understanding:**\n   The problem arises from a logical flaw in the progress calculation during the test teardown phase. The test framework is executing on a Linux platform with Python 3.6.4 and pytest version 3.3.1. The issue is specifically related to how the pytest terminal handles logging and calculation of test progress percentages, addressed by modifications in various functions within the `py.test/terminal.py` file, including `TerminalReporter.__init__`, `TerminalReporter.write_ensure_prefix`, and multiple occurrences within `TerminalReporter.pytest_runtest_logreport`.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Invalid percentages of Test Suite progress\n\nBody:\nProgress of Test Suite shows more than 100% if Teardown fails:\r\n```\r\n$ python3 -m pytest -v ./test.py &> res.txt; cat res.txt                                                                                                                                        \r\n============================= test session starts ==============================                                                                                                                                   \r\nplatform linux -- Python 3.6.4, pytest-3.3.1, py-1.5.0, pluggy-0.6.0 -- /usr/bin/python3\r\ncachedir: .cache\r\nrootdir: /home/pavel, inifile:\r\nplugins: allure-adaptor-1.7.8\r\ncollecting ... collected 1 item\r\n\r\ntest.py::test_foo1 PASSED                                                [100%]\r\ntest.py::test_foo1 ERROR                                                 [200%]\r\n\r\n==================================== ERRORS ====================================\r\n```\r\ntest.py:\r\n```\r\nimport pytest                                                                                                                                                                                                      \r\n\r\n@pytest.fixture\r\ndef fail_teardown():\r\n    print(\"SETUP\")\r\n    yield fail_teardown\r\n    print(\"TEARDOWN\")\r\n    assert 1 == 2\r\n\r\ndef test_foo1(fail_teardown):\r\n    print(\"TEST\")\r\n```\r\nSystem:\r\n```\r\n$ pip list 2>/dev/null                                                                                                                                                                          \r\nappdirs (1.4.3)                                                                                                                                                                                                    \r\nasn1crypto (0.24.0)                                                                                                                                                                                                \r\nattrs (17.4.0)\r\nbcrypt (3.1.4)\r\ncffi (1.11.2)\r\ncryptography (2.1.4)\r\nidna (2.6)\r\nisc (2.0)\r\njson2html (1.1.1)\r\nlxml (4.1.1)                                                                                                                                                                                                       \r\nmsgpack-python (0.4.8)                                                                                                                                                                                             \r\nnamedlist (1.7)                                                                                                                                                                                                    \r\nnetifaces (0.10.6)                                                                                                                                                                                                 \r\npackaging (16.8)                                                                                                                                                                                                   \r\nparamiko (2.4.0)                                                                                                                                                                                                   \r\npip (9.0.1)                                                                                                                                                                                                        \r\npluggy (0.6.0)                                                                                                                                                                                                     \r\nply (3.10)                                                                                                                                                                                                         \r\npy (1.5.0)                                                                                                                                                                                                         \r\npyasn1 (0.4.2)                                                                                                                                                                                                     \r\npycparser (2.18)                                                                                                                                                                                                   \r\nPyNaCl (1.2.0)                                                                                                                                                                                                     \r\npyparsing (2.2.0)                                                                                                                                                                                                  \r\npyserial (3.4)                                                                                                                                                                                                     \r\npytest (3.3.1)                                                                                                                                                                                                     \r\npytest-allure-adaptor (1.7.8)                                                                                                                                                                                      \r\nscp (0.10.2)                                                                                                                                                                                                       \r\nsetuptools (38.2.5)                                                                                                                                                                                                \r\nsix (1.11.0)                                                                                                                                                                                                       \r\nspeedtest-cli (1.0.7)                                                                                                                                                                                              \r\nws4py (0.3.4)                                                                                                                                                                                            \r\n$ uname -a                                                                                                                                                                                      \r\nLinux afitester 4.14.10-1-ARCH #1 SMP PREEMPT Fri Dec 29 20:17:35 UTC 2017 x86_64 GNU/Linux\r\n```\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\n_pytest/terminal.py\n  function: TerminalReporter.__init__\n  function: TerminalReporter.write_ensure_prefix\n  function: TerminalReporter.pytest_runtest_logreport\n  function: TerminalReporter.pytest_runtest_logreport\n  function: TerminalReporter.pytest_runtest_logreport\n"
    },
    {
      "similar_issue": {
        "issue_title": "Parametrized argument named similarly to fixture (contains it) breaks that fixture's parametrization",
        "issue_body": "Originally reported by: **Jacobo Giralt (BitBucket: [jgiralt](http://bitbucket.org/jgiralt), GitHub: [jgiralt](http://github.com/jgiralt))**\n\n---\n\n```\n#!python\n\nimport pytest\n\n@pytest.fixture(params=[1,2,3])\ndef foo(request):\n    return request.param\n\n@pytest.mark.parametrize('foobar', [4,5,6])\ndef test_issue(foo, foobar):\n    assert True\n```\n\n```\n#!python\n\nrequest = <SubRequest 'foo' for <Function 'test_issue[4]'>>\n\n    @pytest.fixture(params=[1,2,3])\n    def foo(request):\n>       return request.param\nAttributeError: SubRequest instance has no attribute 'param'\n```\n\nThe issue seems reproducible as long as the parametrized test argument contains the fixture name as a substring, e.g. foobar, barfoo, foox, xfoo, disappears as soon as I modify the fixture name to anything else.\n\nThis same code works in pytest-2.6.4 and fails for 2.7.\n\n---\n- Bitbucket: https://bitbucket.org/pytest-dev/pytest/issue/736\n",
        "issue_id": 736,
        "pr_number": 926,
        "pr_title": "Don't skip fixtures that are substrings of params",
        "pr_body": "Fix #736\n",
        "issue_closed_at": "2015-08-11T00:12:52Z",
        "base_commit": "681e502c12f5baa3f2da9c9de4a848813a872945"
      },
      "summary": "### Summary:\n\nThis issue is a software bug in the pytest testing framework related to the interaction between fixture names and parametrized test arguments. The problem arises when a parametrized test argument's name includes the name of a fixture as a substring. Under these circumstances, the affected fixture cannot access its parameters as expected, resulting in an `AttributeError`. This issue is specifically observed when upgrading from pytest version 2.6.4 to 2.7, indicating a regression in the software's functionality.\n\nKey symptoms include the failure of tests that utilize fixtures with names that are substrings of their parametrized arguments. The error message provided, `AttributeError: SubRequest instance has no attribute 'param'`, suggests that the test framework is unable to correctly resolve the parameter value for the fixture, which disrupts the normal execution of the test.\n\nThe affected components include the pytest fixture mechanism, specifically the sections of code responsible for managing and resolving fixture parameters during test execution. The potential impact of this issue is significant for users of pytest who rely on complex test setups with fixtures and parameterization, as it can cause test failures and hinder the testing process.\n\nOverall, this issue highlights the importance of ensuring that naming conventions in test code do not inadvertently trigger obscure bugs in the testing framework, and it emphasizes the need for thorough regression testing when upgrading software libraries to new versions.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Parametrized argument named similarly to fixture (contains it) breaks that fixture's parametrization\n\nBody:\nOriginally reported by: **Jacobo Giralt (BitBucket: [jgiralt](http://bitbucket.org/jgiralt), GitHub: [jgiralt](http://github.com/jgiralt))**\n\n---\n\n```\n#!python\n\nimport pytest\n\n@pytest.fixture(params=[1,2,3])\ndef foo(request):\n    return request.param\n\n@pytest.mark.parametrize('foobar', [4,5,6])\ndef test_issue(foo, foobar):\n    assert True\n```\n\n```\n#!python\n\nrequest = <SubRequest 'foo' for <Function 'test_issue[4]'>>\n\n    @pytest.fixture(params=[1,2,3])\n    def foo(request):\n>       return request.param\nAttributeError: SubRequest instance has no attribute 'param'\n```\n\nThe issue seems reproducible as long as the parametrized test argument contains the fixture name as a substring, e.g. foobar, barfoo, foox, xfoo, disappears as soon as I modify the fixture name to anything else.\n\nThis same code works in pytest-2.6.4 and fails for 2.7.\n\n---\n- Bitbucket: https://bitbucket.org/pytest-dev/pytest/issue/736\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\n_pytest/python.py\n  function: FixtureManager.pytest_generate_tests\n"
    },
    {
      "similar_issue": {
        "issue_title": "Support PEP-415's Exception.__suppress_context__",
        "issue_body": "- [x] Include a detailed description of the bug or suggestion\r\n\r\nPEP-415 states that `exception.__context__` should be suppressed in traceback outputs, if `exception.__suppress_context__` is `True`.\r\n\r\nIf a ``raise exception from None`` is caught by pytest, pytest should not chain the context in the test report.\r\n\r\nThe current algorithm in `_pytest._code.code.FormattedExcinfo` is:\r\n\r\n```python\r\nif e.__cause__ is not None:\r\n    # Code to chain the cause.\r\nelif e.__context__ is not None:\r\n    # Code to chain the context.\r\n```\r\n\r\nwhich means that pytest always chains the exception, assuming that `e.__context__` hasn't been set to `None`.\r\n\r\nBy comparison, the algorithm in `traceback.TracebackException` is:\r\n\r\n```python\r\nif e.__cause__ is not None:\r\n    # Code to chain the cause.\r\nelif (e.__context__ is not None and not e.__suppress_context__):\r\n    # Code to chain the context.\r\n```\r\n\r\n`Exception.__suppress_context__` is available in all of the versions of Python 3 that are supported by pytest, so it is trivial to add support for this feature.\r\n\r\n- [x] Minimal example if possible\r\n\r\nHere's a test that has a ``raise exception from None`` in it:\r\n\r\n```python\r\ndef test_raise_from_none():\r\n    try:\r\n        raise ValueError()\r\n    except Exception:\r\n        raise AttributeError() from None\r\n```\r\n\r\nThis is the test output (with the chained exception traceback) that results when running against the pytest feature branch (commit 768edde899fe3629a69d55289f82bb0d95635c06):\r\n\r\n```\r\n_____________________________________________________ test_raise_from_none _____________________________________________________\r\n\r\n    def test_raise_from_none():\r\n        try:\r\n>           raise ValueError()\r\nE           ValueError\r\n\r\ntesting/code/test_excinfo.py:1257: ValueError\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\n    def test_raise_from_none():\r\n        try:\r\n            raise ValueError()\r\n        except Exception:\r\n>           raise AttributeError() from None\r\nE           AttributeError\r\n\r\ntesting/code/test_excinfo.py:1259: AttributeError\r\n```\r\n\r\nBut running the same code in a terminal produces this shorter, non-chained traceback:\r\n\r\n```\r\nAttributeError                            Traceback (most recent call last)\r\n<ipython-input-51-e2e3809c49fb> in <module>()\r\n----> 1 test_raise_from_none()\r\n\r\n<ipython-input-50-d651befdf00e> in test_raise_from_none()\r\n      3         raise ValueError()\r\n      4     except Exception:\r\n----> 5         raise AttributeError() from None\r\n      6\r\n\r\nAttributeError:\r\n```\r\n\r\nAnd this is what the pytest output should look like:\r\n\r\n```\r\n_____________________________________________________ test_raise_from_none _____________________________________________________\r\n\r\n    def test_raise_from_none():\r\n        try:\r\n            raise ValueError()\r\n        except Exception:\r\n>           raise AttributeError() from None\r\nE           AttributeError\r\n\r\ntesting/code/test_excinfo.py:1259: AttributeError\r\n```",
        "issue_id": 2631,
        "pr_number": 2632,
        "pr_title": "Support PEP-415's Exception.__suppress_context__",
        "pr_body": "PEP-415 states that `exception.__context__` should be suppressed\r\nin traceback outputs, if `exception.__suppress_context__` is\r\n`True`.\r\n\r\nNow if a ``raise exception from None`` is caught by pytest,\r\npytest will no longer chain the context in the test report.\r\n\r\nThe algorithm in `FormattedExcinfo` now better matches the one\r\nin `traceback.TracebackException`.\r\n\r\n`Exception.__suppress_context__` is available in all of the\r\nversions of Python 3 that are supported by pytest.\r\n\r\nFixes #2631.",
        "issue_closed_at": "2017-07-30T21:46:09Z",
        "base_commit": "768edde899fe3629a69d55289f82bb0d95635c06"
      },
      "summary": "### Summary:\n\nThis issue pertains to the handling of exception context chaining in the pytest framework, specifically aligning its behavior with the guidelines set forth in Python Enhancement Proposal 415 (PEP-415). PEP-415 introduces an attribute `__suppress_context__` in exceptions to control whether the context of an exception should be suppressed in traceback outputs. \n\n1. **Problem Description**: The problem involves pytest improperly chaining exception contexts in traceback outputs, even when the `__suppress_context__` attribute is set to `True`. This behavior is inconsistent with the expected behavior as outlined by PEP-415 and differs from the standard Python traceback handling.\n\n2. **Key Symptoms and Behaviors Observed**: When an exception is raised using the syntax `raise exception from None`, pytest currently includes the context of the previous exception in the traceback output. This results in longer and potentially confusing error reports, contrary to the standard Python behavior which suppresses the context as expected.\n\n3. **Affected Components or Systems**: The issue affects the `_pytest._code.code.FormattedExcinfo` component of the pytest framework, specifically its `repr_excinfo` function which is responsible for formatting exception reports.\n\n4. **Potential Impact or Severity**: The impact of this issue is mainly on the clarity and readability of test failure reports within pytest. This can lead to confusion for developers trying to debug tests, especially when context chaining is not desired or relevant. However, since this does not affect the functionality of the tests themselves, the severity is relatively low but still important for maintaining consistency and adherence to Python standards.\n\n5. **Relevant Technical Details**: The resolution involves modifying the existing exception handling logic in pytest to incorporate the condition that checks the `__suppress_context__` attribute. This adjustment aligns pytest's behavior with the standard `traceback.TracebackException` logic, ensuring that context chaining is suppressed when `__suppress_context__` is `True`.\n\nChanges Summary:\n\n- The change involves updating the `repr_excinfo` function in `_pytest/_code/code.py` to correctly handle exception chaining by respecting the `__suppress_context__` attribute in exception instances. This aligns pytest’s traceback output with the intended behavior described in PEP-415, resulting in more concise and accurate error reporting.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Support PEP-415's Exception.__suppress_context__\n\nBody:\n- [x] Include a detailed description of the bug or suggestion\r\n\r\nPEP-415 states that `exception.__context__` should be suppressed in traceback outputs, if `exception.__suppress_context__` is `True`.\r\n\r\nIf a ``raise exception from None`` is caught by pytest, pytest should not chain the context in the test report.\r\n\r\nThe current algorithm in `_pytest._code.code.FormattedExcinfo` is:\r\n\r\n```python\r\nif e.__cause__ is not None:\r\n    # Code to chain the cause.\r\nelif e.__context__ is not None:\r\n    # Code to chain the context.\r\n```\r\n\r\nwhich means that pytest always chains the exception, assuming that `e.__context__` hasn't been set to `None`.\r\n\r\nBy comparison, the algorithm in `traceback.TracebackException` is:\r\n\r\n```python\r\nif e.__cause__ is not None:\r\n    # Code to chain the cause.\r\nelif (e.__context__ is not None and not e.__suppress_context__):\r\n    # Code to chain the context.\r\n```\r\n\r\n`Exception.__suppress_context__` is available in all of the versions of Python 3 that are supported by pytest, so it is trivial to add support for this feature.\r\n\r\n- [x] Minimal example if possible\r\n\r\nHere's a test that has a ``raise exception from None`` in it:\r\n\r\n```python\r\ndef test_raise_from_none():\r\n    try:\r\n        raise ValueError()\r\n    except Exception:\r\n        raise AttributeError() from None\r\n```\r\n\r\nThis is the test output (with the chained exception traceback) that results when running against the pytest feature branch (commit 768edde899fe3629a69d55289f82bb0d95635c06):\r\n\r\n```\r\n_____________________________________________________ test_raise_from_none _____________________________________________________\r\n\r\n    def test_raise_from_none():\r\n        try:\r\n>           raise ValueError()\r\nE           ValueError\r\n\r\ntesting/code/test_excinfo.py:1257: ValueError\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\n    def test_raise_from_none():\r\n        try:\r\n            raise ValueError()\r\n        except Exception:\r\n>           raise AttributeError() from None\r\nE           AttributeError\r\n\r\ntesting/code/test_excinfo.py:1259: AttributeError\r\n```\r\n\r\nBut running the same code in a terminal produces this shorter, non-chained traceback:\r\n\r\n```\r\nAttributeError                            Traceback (most recent call last)\r\n<ipython-input-51-e2e3809c49fb> in <module>()\r\n----> 1 test_raise_from_none()\r\n\r\n<ipython-input-50-d651befdf00e> in test_raise_from_none()\r\n      3         raise ValueError()\r\n      4     except Exception:\r\n----> 5         raise AttributeError() from None\r\n      6\r\n\r\nAttributeError:\r\n```\r\n\r\nAnd this is what the pytest output should look like:\r\n\r\n```\r\n_____________________________________________________ test_raise_from_none _____________________________________________________\r\n\r\n    def test_raise_from_none():\r\n        try:\r\n            raise ValueError()\r\n        except Exception:\r\n>           raise AttributeError() from None\r\nE           AttributeError\r\n\r\ntesting/code/test_excinfo.py:1259: AttributeError\r\n```\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\n_pytest/_code/code.py\n  function: FormattedExcinfo.repr_excinfo\n"
    }
  ]
}