{
  "original_problem": {
    "instance_id": "pytest-dev__pytest-5103",
    "repo": "pytest-dev/pytest",
    "created_at": "2019-04-13T16:17:45Z",
    "problem_statement": "Unroll the iterable for all/any calls to get better reports\nSometime I need to assert some predicate on all of an iterable, and for that the builtin functions `all`/`any` are great - but the failure messages aren't useful at all!\r\nFor example - the same test written in three ways:\r\n\r\n- A generator expression\r\n```sh                                                                                                                                                                                                                         \r\n    def test_all_even():\r\n        even_stevens = list(range(1,100,2))\r\n>       assert all(is_even(number) for number in even_stevens)\r\nE       assert False\r\nE        +  where False = all(<generator object test_all_even.<locals>.<genexpr> at 0x101f82ed0>)\r\n```\r\n- A list comprehension\r\n```sh\r\n    def test_all_even():\r\n        even_stevens = list(range(1,100,2))\r\n>       assert all([is_even(number) for number in even_stevens])\r\nE       assert False\r\nE        +  where False = all([False, False, False, False, False, False, ...])\r\n```\r\n- A for loop\r\n```sh\r\n    def test_all_even():\r\n        even_stevens = list(range(1,100,2))\r\n        for number in even_stevens:\r\n>           assert is_even(number)\r\nE           assert False\r\nE            +  where False = is_even(1)\r\n\r\ntest_all_any.py:7: AssertionError\r\n```\r\nThe only one that gives a meaningful report is the for loop - but it's way more wordy, and `all` asserts don't translate to a for loop nicely (I'll have to write a `break` or a helper function - yuck)\r\nI propose the assertion re-writer \"unrolls\" the iterator to the third form, and then uses the already existing reports.\r\n\r\n- [x] Include a detailed description of the bug or suggestion\r\n- [x] `pip list` of the virtual environment you are using\r\n```\r\nPackage        Version\r\n-------------- -------\r\natomicwrites   1.3.0  \r\nattrs          19.1.0 \r\nmore-itertools 7.0.0  \r\npip            19.0.3 \r\npluggy         0.9.0  \r\npy             1.8.0  \r\npytest         4.4.0  \r\nsetuptools     40.8.0 \r\nsix            1.12.0 \r\n```\r\n- [x] pytest and operating system versions\r\n`platform darwin -- Python 3.7.3, pytest-4.4.0, py-1.8.0, pluggy-0.9.0`\r\n- [x] Minimal example if possible\r\n\n",
    "patch": "diff --git a/src/_pytest/assertion/rewrite.py b/src/_pytest/assertion/rewrite.py\n--- a/src/_pytest/assertion/rewrite.py\n+++ b/src/_pytest/assertion/rewrite.py\n@@ -964,6 +964,8 @@ def visit_Call_35(self, call):\n         \"\"\"\n         visit `ast.Call` nodes on Python3.5 and after\n         \"\"\"\n+        if isinstance(call.func, ast.Name) and call.func.id == \"all\":\n+            return self._visit_all(call)\n         new_func, func_expl = self.visit(call.func)\n         arg_expls = []\n         new_args = []\n@@ -987,6 +989,27 @@ def visit_Call_35(self, call):\n         outer_expl = \"%s\\n{%s = %s\\n}\" % (res_expl, res_expl, expl)\n         return res, outer_expl\n \n+    def _visit_all(self, call):\n+        \"\"\"Special rewrite for the builtin all function, see #5062\"\"\"\n+        if not isinstance(call.args[0], (ast.GeneratorExp, ast.ListComp)):\n+            return\n+        gen_exp = call.args[0]\n+        assertion_module = ast.Module(\n+            body=[ast.Assert(test=gen_exp.elt, lineno=1, msg=\"\", col_offset=1)]\n+        )\n+        AssertionRewriter(module_path=None, config=None).run(assertion_module)\n+        for_loop = ast.For(\n+            iter=gen_exp.generators[0].iter,\n+            target=gen_exp.generators[0].target,\n+            body=assertion_module.body,\n+            orelse=[],\n+        )\n+        self.statements.append(for_loop)\n+        return (\n+            ast.Num(n=1),\n+            \"\",\n+        )  # Return an empty expression, all the asserts are in the for_loop\n+\n     def visit_Starred(self, starred):\n         # From Python 3.5, a Starred node can appear in a function call\n         res, expl = self.visit(starred.value)\n@@ -997,6 +1020,8 @@ def visit_Call_legacy(self, call):\n         \"\"\"\n         visit `ast.Call nodes on 3.4 and below`\n         \"\"\"\n+        if isinstance(call.func, ast.Name) and call.func.id == \"all\":\n+            return self._visit_all(call)\n         new_func, func_expl = self.visit(call.func)\n         arg_expls = []\n         new_args = []\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_3088",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about progress reporting errors, which is unrelated to assertion message clarity or iterator handling."
      },
      {
        "idx": 2,
        "id": "similar_3773",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue deals with test discovery and collection, not assertion message clarity or iterator handling."
      },
      {
        "idx": 3,
        "id": "similar_4487",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about logging errors during shutdown, unrelated to assertion message clarity or iterator handling."
      },
      {
        "idx": 4,
        "id": "similar_2631",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves exception context chaining, which does not relate to assertion message clarity or iterator handling."
      },
      {
        "idx": 5,
        "id": "similar_811",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about test function collection with functools.partial, unrelated to assertion message clarity or iterator handling."
      }
    ]
  },
  "raw_summaries": [
    {
      "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 concerns an inaccurate reporting of progress percentages in a testing framework when a test suite's teardown process fails. Specifically, the progress output can erroneously exceed 100%, misleading users about the test suite's execution status. \n\n1. **Problem description in general terms**: The testing framework reports an invalid progress percentage, showing values greater than 100%, when the teardown phase of a test fails during execution. This misrepresentation affects the perceived completion status of the test suite.\n\n2. **Key symptoms and behaviors observed**: The main symptom is the progress percentage displayed as 200% when a teardown failure occurs, as illustrated in the test output logs. This behavior is inconsistent with the expected progress reporting, which should not exceed 100%.\n\n3. **Affected components or systems**: The issue is rooted in the pytest testing framework, specifically affecting the TerminalReporter module responsible for logging and displaying test progress information.\n\n4. **Potential impact or severity**: The severity of this issue is moderate, as it can cause confusion and misinterpretation of test results by developers and testers. It may lead to incorrect assumptions about the completion and success of test suites, potentially impacting software deployment decisions.\n\n5. **Relevant technical details abstracted for broader understanding**: The problem arises within the pytest version 3.3.1 environment, utilizing plugins such as allure-adaptor. The teardown function in a test fixture is incorrectly influencing the progress calculation, leading to the erroneous display of progress percentages. The issue may be exacerbated by specific configurations or interactions within the TerminalReporter class, which necessitated updates to functions handling test result logging and progress calculation.",
      "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": "Pytest 3.7.1 is not collecting `__init__.py` files",
        "issue_body": "Hi! I seem to have run into a bug on the latest build. Pytest is not collecting `__init__.py` files, even after specifying `python_files` to `*.py` in `pytest.ini`. I have all of my test functions named correctly, starting with `test_*` as well.\r\n\r\nHere is a quick example.\r\n\r\nTree:\r\n\r\n```\r\ntests/\r\n├── __init__.py\r\n├── sample\r\n│   ├── __init__.py\r\n│   └── sample_test.py\r\n```\r\n\r\nCommand + output:\r\n```\r\npytest --collect-only tests/sample/\r\n============================= test session starts ==============================\r\nplatform linux -- Python 3.7.0, pytest-3.7.1, py-1.5.4, pluggy-0.7.1\r\nrootdir: /home/deebs/playground/radish_steps, inifile: pytest.ini\r\ncollected 1 item                                                               \r\n<Module 'tests/sample/sample_test.py'>\r\n  <Function 'test_sample'>\r\n\r\n========================= no tests ran in 0.02 seconds =========================\r\n```\r\n\r\nIf you need any more details, please feel free to reach out",
        "issue_id": 3773,
        "pr_number": 3884,
        "pr_title": "Merge master into features",
        "pr_body": "",
        "issue_closed_at": "2018-08-26T11:50:17Z",
        "base_commit": "044d2b8e6e4717a3cbc5316117e1433098c3fe08"
      },
      "summary": "### Summary:\n\nThis issue revolves around a problem with the Pytest testing framework, specifically version 3.7.1, where it fails to collect `__init__.py` files during test discovery. This occurs even when users configure `pytest.ini` to recognize all `.py` files as potential test files. The issue manifests when running a test collection command, as `__init__.py` files are omitted from the list of collected test modules, resulting in fewer test items than expected.\n\n**Key Symptoms and Behaviors Observed:**\n- Pytest does not collect or recognize `__init__.py` files as test modules.\n- The issue persists despite correctly naming test functions with the prefix `test_*`.\n- The test tree structure includes `__init__.py` files both at the root of the test directory and within subdirectories.\n\n**Affected Components or Systems:**\n- The issue affects Pytest's test collection mechanism.\n- It impacts users running Pytest on Python 3.7.0 with version 3.7.1 of the Pytest framework.\n\n**Potential Impact or Severity:**\n- The issue can lead to incomplete test execution, as tests within `__init__.py` files are not run.\n- This could result in missed errors or failures in the code that would otherwise be caught during testing.\n\n**Relevant Technical Details Abstracted for Broader Understanding:**\n- The problem is related to the test discovery and collection phase of Pytest.\n- The solution involves modifying various components within Pytest’s source code to ensure `__init__.py` files are included during test collection.\n- Key areas of the code that were changed include modules responsible for assertion rewriting, capture management, configuration parsing, and test file collection. These changes indicate a comprehensive update to Pytest's internal mechanisms to handle `__init__.py` files correctly.",
      "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: Pytest 3.7.1 is not collecting `__init__.py` files\n\nBody:\nHi! I seem to have run into a bug on the latest build. Pytest is not collecting `__init__.py` files, even after specifying `python_files` to `*.py` in `pytest.ini`. I have all of my test functions named correctly, starting with `test_*` as well.\r\n\r\nHere is a quick example.\r\n\r\nTree:\r\n\r\n```\r\ntests/\r\n├── __init__.py\r\n├── sample\r\n│   ├── __init__.py\r\n│   └── sample_test.py\r\n```\r\n\r\nCommand + output:\r\n```\r\npytest --collect-only tests/sample/\r\n============================= test session starts ==============================\r\nplatform linux -- Python 3.7.0, pytest-3.7.1, py-1.5.4, pluggy-0.7.1\r\nrootdir: /home/deebs/playground/radish_steps, inifile: pytest.ini\r\ncollected 1 item                                                               \r\n<Module 'tests/sample/sample_test.py'>\r\n  <Function 'test_sample'>\r\n\r\n========================= no tests ran in 0.02 seconds =========================\r\n```\r\n\r\nIf you need any more details, please feel free to reach out\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:\nbench/empty.py\n  line: line 1\n  line: line 1\n  line: line 1\n\ndoc/en/example/assertion/failure_demo.py\n  line: line 1\n  function: test_dynamic_compile_shows_nicely\n\ndoc/en/example/assertion/global_testmodule_config/conftest.py\n  function: pytest_runtest_setup\n\ndoc/en/example/multipython.py\n  line: line 2\n  class: Python\n\nsrc/_pytest/_code/_py2traceback.py\n  line: line 2\n  function: format_exception_only\n  function: _format_final_exc_line\n  function: _some_str\n\nsrc/_pytest/_code/code.py\n  line: line 11\n  function: Frame.exec_\n\nsrc/_pytest/assertion/rewrite.py\n  function: AssertionRewritingHook.load_module\n  function: _saferepr\n  function: _should_repr_global_name\n\nsrc/_pytest/assertion/util.py\n  function: escape_for_readable_diff\n\nsrc/_pytest/capture.py\n  line: line 14\n  function: silence_logging_at_shutdown\n  function: CaptureManager._getcapture\n  function: CaptureManager.stop_global_capturing\n  function: CaptureManager.deactivate_fixture\n  function: CaptureManager.pytest_make_collect_report\n  function: CaptureManager.pytest_keyboard_interrupt\n  class: CaptureFixture\n  function: MultiCapture.readouterr\n  class: FDCaptureBinary\n  class: FDCapture\n  function: SysCaptureBinary.snap\n  function: SysCapture.writeorg\n\nsrc/_pytest/config/argparsing.py\n  line: line 2\n  function: Parser.parse\n  function: Parser.parse_known_and_unknown_args\n\nsrc/_pytest/debugging.py\n  class: PdbInvoke\n\nsrc/_pytest/fixtures.py\n  line: line 2\n  function: get_scope_package\n  function: FixtureDef.finish\n  function: FixtureDef.execute\n\nsrc/_pytest/main.py\n  function: Session._matchnodes\n\nsrc/_pytest/outcomes.py\n  line: line 3\n  function: OutcomeException.__repr__\n\nsrc/_pytest/pytester.py\n  line: line 22\n  function: pytest_addoption\n  function: HookRecorder.popcall\n  function: Testdir.to_text\n  function: Testdir.copy_example\n  function: runpytest\n  function: popen\n  function: run\n  function: _dump_lines\n\nsrc/_pytest/python.py\n  function: pytest_collect_file\n  function: Generator.collect\n  function: FunctionMixin._prunetraceback\n\nsrc/_pytest/python_api.py\n  line: line 4\n  function: raises\n\nsrc/_pytest/recwarn.py\n  line: line 4\n  function: warns\n\nsrc/_pytest/runner.py\n  line: line 6\n  function: SetupState._callfinalizers\n  function: SetupState._teardown_towards\n  function: SetupState.prepare\n\nsrc/_pytest/setuponly.py\n  function: _show_fixture_action\n\nsrc/_pytest/terminal.py\n  function: TerminalReporter.summary_passes\n"
    },
    {
      "similar_issue": {
        "issue_title": "Logging done late enough might happen when capture already stopped.",
        "issue_body": "```\r\n22:56:26,997 [pytestsalt.utils:206 ][INFO    ][1024] Stopping process psutil.Process(pid=1228, name='/home/vampas/.d', started='22:55:17') and respective children: [psutil.Process(pid=1245, name='/home/vampas/.d', started='22:55:18'), psut\r\nil.Process(pid=1262, name='/home/vampas/.d', started='22:55:19'), psutil.Process(pid=1263, name='/home/vampas/.d', started='22:55:19')]                                                                                                        \r\nError in atexit._run_exitfuncs:                                                                                                                                                                                                                \r\nTraceback (most recent call last):                                                                                                                                                                                                             \r\n  File \"/home/vampas/.dotfiles/.ext/pyenv/versions/3.5.4/lib/python3.5/logging/__init__.py\", line 861, in handle                                                                                                                               \r\n    self.emit(record)                                                                                                                                                                                                                          \r\n  File \"/home/vampas/.dotfiles/.ext/pyenv/versions/3.5.4/envs/Salt-3.5.4-Develop/lib/python3.5/site-packages/_pytest/logging.py\", line 625, in emit                                                                                            \r\n    logging.StreamHandler.emit(self, record)\r\n  File \"/home/vampas/.dotfiles/.ext/pyenv/versions/3.5.4/lib/python3.5/contextlib.py\", line 66, in __exit__\r\n    next(self.gen)\r\n  File \"/home/vampas/.dotfiles/.ext/pyenv/versions/3.5.4/envs/Salt-3.5.4-Develop/lib/python3.5/site-packages/_pytest/capture.py\", line 167, in global_and_fixture_disabled\r\n    self.resume_global_capture()\r\n  File \"/home/vampas/.dotfiles/.ext/pyenv/versions/3.5.4/envs/Salt-3.5.4-Develop/lib/python3.5/site-packages/_pytest/capture.py\", line 120, in resume_global_capture\r\n    self._global_capturing.resume_capturing()\r\nAttributeError: 'NoneType' object has no attribute 'resume_capturing'\r\n```\r\n- [x] Create a new changelog file in the `changelog` folder, with a name like `<ISSUE NUMBER>.<TYPE>.rst`. See [changelog/README.rst](https://github.com/pytest-dev/pytest/blob/master/changelog/README.rst) for details.\r\n- [x] Target the `master` branch for bug fixes, documentation updates and trivial changes.",
        "issue_id": 4487,
        "pr_number": 4524,
        "pr_title": "Merge master into features",
        "pr_body": "",
        "issue_closed_at": "2018-12-02T11:10:00Z",
        "base_commit": "76884c73bf1ba0cd9fa5ed6e4ba65931fa38096d"
      },
      "summary": "### Summary:\n\nThis issue pertains to a timing problem in a software logging mechanism where logging operations are attempted after the capture process has already ceased, leading to errors. The problem is characterized by attempts to execute logging functions during program exit procedures, specifically within the `atexit` module, resulting in an error traceback indicating a `NoneType` object error. \n\nKey symptoms include an error traceback triggered during the shutdown of processes, highlighting the failure in resuming global capturing due to an unhandled `NoneType` object. This suggests that the logging framework is trying to interact with a capturing mechanism that is no longer active or initialized.\n\nThe affected components are within the Python logging and pytest capture modules, specifically in the context of a pytest environment. The issue impacts the functionality of pytest's logging and capturing features, which are crucial for debugging and test result analysis.\n\nThe potential impact of this issue is moderate, as it affects the reliability of logging during test execution and teardown, potentially leading to incomplete or missing log data. This could hinder debugging efforts and the interpretation of test results.\n\nRelevant technical details include interactions between Python's logging and contextlib modules, and pytest's capture management system. The error arises from a failure to properly manage the lifecycle of capturing resources, indicating a need for more robust handling of the capturing state during teardown processes. The fix involves changes to the `CaptureManager.stop_global_capturing` function and the `Config._mark_plugins_for_rewrite` function to ensure proper handling of the capturing lifecycle.",
      "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: Logging done late enough might happen when capture already stopped.\n\nBody:\n```\r\n22:56:26,997 [pytestsalt.utils:206 ][INFO    ][1024] Stopping process psutil.Process(pid=1228, name='/home/vampas/.d', started='22:55:17') and respective children: [psutil.Process(pid=1245, name='/home/vampas/.d', started='22:55:18'), psut\r\nil.Process(pid=1262, name='/home/vampas/.d', started='22:55:19'), psutil.Process(pid=1263, name='/home/vampas/.d', started='22:55:19')]                                                                                                        \r\nError in atexit._run_exitfuncs:                                                                                                                                                                                                                \r\nTraceback (most recent call last):                                                                                                                                                                                                             \r\n  File \"/home/vampas/.dotfiles/.ext/pyenv/versions/3.5.4/lib/python3.5/logging/__init__.py\", line 861, in handle                                                                                                                               \r\n    self.emit(record)                                                                                                                                                                                                                          \r\n  File \"/home/vampas/.dotfiles/.ext/pyenv/versions/3.5.4/envs/Salt-3.5.4-Develop/lib/python3.5/site-packages/_pytest/logging.py\", line 625, in emit                                                                                            \r\n    logging.StreamHandler.emit(self, record)\r\n  File \"/home/vampas/.dotfiles/.ext/pyenv/versions/3.5.4/lib/python3.5/contextlib.py\", line 66, in __exit__\r\n    next(self.gen)\r\n  File \"/home/vampas/.dotfiles/.ext/pyenv/versions/3.5.4/envs/Salt-3.5.4-Develop/lib/python3.5/site-packages/_pytest/capture.py\", line 167, in global_and_fixture_disabled\r\n    self.resume_global_capture()\r\n  File \"/home/vampas/.dotfiles/.ext/pyenv/versions/3.5.4/envs/Salt-3.5.4-Develop/lib/python3.5/site-packages/_pytest/capture.py\", line 120, in resume_global_capture\r\n    self._global_capturing.resume_capturing()\r\nAttributeError: 'NoneType' object has no attribute 'resume_capturing'\r\n```\r\n- [x] Create a new changelog file in the `changelog` folder, with a name like `<ISSUE NUMBER>.<TYPE>.rst`. See [changelog/README.rst](https://github.com/pytest-dev/pytest/blob/master/changelog/README.rst) for details.\r\n- [x] Target the `master` branch for bug fixes, documentation updates and trivial changes.\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/capture.py\n  function: CaptureManager.stop_global_capturing\n\nsrc/_pytest/config/__init__.py\n  function: Config._mark_plugins_for_rewrite\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:\nThis issue pertains to the handling of exception context chaining in pytest, a popular testing framework for Python. The problem arises from the lack of support for PEP-415's `Exception.__suppress_context__` attribute, which should prevent the chaining of exception contexts in traceback outputs when set to `True`. In the current implementation of pytest, exceptions are always chained in the test report, ignoring the `__suppress_context__` attribute. This behavior is inconsistent with the standard Python traceback mechanism, which respects the `__suppress_context__` attribute.\n\n### Key Symptoms and Behaviors Observed:\n- In pytest, exceptions raised from another (using `raise exception from None`) still show a chained context in the traceback, contrary to the expected behavior.\n- The observed behavior is inconsistent with Python's native `traceback.TracebackException`, which properly suppresses the context when `__suppress_context__` is `True`.\n\n### Affected Components or Systems:\n- The issue affects the `_pytest._code.code.FormattedExcinfo` component of the pytest framework, specifically in the way it represents exception information in test reports.\n\n### Potential Impact or Severity:\n- The impact is mostly related to the clarity and accuracy of exception reporting in pytest. It could lead to confusion or misinterpretation of error contexts during testing, especially when developers expect traceback outputs to match standard Python behavior.\n- The severity is moderate, as it affects the usability and reliability of test reports but does not cause test failures or crashes.\n\n### Relevant Technical Details Abstracted for Broader Understanding:\n- The `__suppress_context__` attribute is part of PEP-415 and is supported in all Python 3 versions compatible with pytest. It serves as a mechanism to suppress automatic chaining of contexts in exception tracebacks.\n- The solution involves updating the exception handling logic within `FormattedExcinfo.repr_excinfo` to check for `__suppress_context__` before chaining contexts, aligning pytest's output with Python's built-in traceback behavior.",
      "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"
    },
    {
      "similar_issue": {
        "issue_title": "Test functions generated by functools.partial raise an internal error during collection",
        "issue_body": "As discussed in #740, the following test functions fail during collection:\n\n``` python\nimport functools\ndef do_it(x):\n    assert x == 2\ntest_foo = functools.partial(do_it, x=1)  \n```\n\n```\n=================================== ERRORS ====================================\n________________________ ERROR collecting test_foo.py _________________________\n...\\lib\\inspect.py:752: in getargs\n    raise TypeError('{!r} is not a code object'.format(co))\nE   TypeError: <functools.partial object at 0x0000000003D37278> is not a code object\n=============================== warning summary ===============================\nWC2 X:\\test_foo.py cannot collect 'test_foo' because it is not a function.\n===================== 1 warnings, 1 error in 0.02 seconds =====================\n```\n",
        "issue_id": 811,
        "pr_number": 813,
        "pr_title": "Collect functools.partial objects",
        "pr_body": "Fix for issue #811.\n\nI feel the current implementation is hackish and might break in some corner-cases.\n\nPerhaps it would be better to don't support tests created by `functools.partial` objects at all, and issue a warning during collection and add a note to the documentation?\n",
        "issue_closed_at": "2015-07-17T00:05:43Z",
        "base_commit": "330de0a93db404921c7a4c80305b43fd87bc3119"
      },
      "summary": "### Summary:\n\nThis issue is related to a problem encountered when using Python's `functools.partial` with testing frameworks that collect test functions. Specifically, test functions created using `functools.partial` cause an internal error during the test discovery process. \n\n1. **Problem Description in General Terms:**\n   The problem arises when test functions are dynamically generated using `functools.partial`. These partially applied functions are not being correctly identified as callable test functions by the test collection mechanism, leading to errors during the test collection phase.\n\n2. **Key Symptoms and Behaviors Observed:**\n   The key symptom is an internal error during the test collection process. The error message indicates that a `TypeError` is raised because the `functools.partial` object is not recognized as a code object. Additionally, a warning is issued, stating that the test function cannot be collected because it is not recognized as a function.\n\n3. **Affected Components or Systems:**\n   The components affected include any test discovery and collection systems that rely on Python's `inspect` module to process test functions. Specifically, this issue affects the test suite in which functions are wrapped with `functools.partial`.\n\n4. **Potential Impact or Severity:**\n   The impact of this issue can be significant in testing environments where `functools.partial` is used to generate test cases dynamically. The inability to collect and execute these tests could lead to incomplete test coverage and potentially undetected defects in software.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   The root of the problem lies in the incompatibility between `functools.partial` objects and the test collection mechanism, which expects callable objects to conform to a specific interface or be recognized as code objects. The error occurs because the `inspect` module, used by the test collector, cannot process `functools.partial` objects in the same way it does regular functions. The resolution involves adjusting the test collection mechanism to accommodate the unique nature of `functools.partial` objects.\n\nThe changes to resolve this issue are specifically in the `pytest` codebase, involving modifications to files and functions related to test setup and function argument handling, ensuring the compatibility of `functools.partial` with the test collection process.",
      "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: Test functions generated by functools.partial raise an internal error during collection\n\nBody:\nAs discussed in #740, the following test functions fail during collection:\n\n``` python\nimport functools\ndef do_it(x):\n    assert x == 2\ntest_foo = functools.partial(do_it, x=1)  \n```\n\n```\n=================================== ERRORS ====================================\n________________________ ERROR collecting test_foo.py _________________________\n...\\lib\\inspect.py:752: in getargs\n    raise TypeError('{!r} is not a code object'.format(co))\nE   TypeError: <functools.partial object at 0x0000000003D37278> is not a code object\n=============================== warning summary ===============================\nWC2 X:\\test_foo.py cannot collect 'test_foo' because it is not a function.\n===================== 1 warnings, 1 error in 0.02 seconds =====================\n```\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  line: line 1\n  line: line 18\n  function: Function.setup\n  function: FixtureLookupError.formatrepr\n  function: getfuncargnames\n"
    }
  ]
}