{
  "original_problem": {
    "instance_id": "pytest-dev__pytest-9359",
    "repo": "pytest-dev/pytest",
    "created_at": "2021-12-01T14:31:38Z",
    "problem_statement": "Error message prints extra code line when using assert in python3.9\n<!--\r\nThanks for submitting an issue!\r\n\r\nQuick check-list while reporting bugs:\r\n-->\r\n\r\n- [x] a detailed description of the bug or problem you are having\r\n- [x] output of `pip list` from the virtual environment you are using\r\n- [x] pytest and operating system versions\r\n- [ ] minimal example if possible\r\n### Description\r\nI have a test like this:\r\n```\r\nfrom pytest import fixture\r\n\r\n\r\ndef t(foo):\r\n    return foo\r\n\r\n\r\n@fixture\r\ndef foo():\r\n    return 1\r\n\r\n\r\ndef test_right_statement(foo):\r\n    assert foo == (3 + 2) * (6 + 9)\r\n\r\n    @t\r\n    def inner():\r\n        return 2\r\n\r\n    assert 2 == inner\r\n\r\n\r\n@t\r\ndef outer():\r\n    return 2\r\n```\r\nThe test \"test_right_statement\" fails at the first assertion,but print extra code (the \"t\" decorator) in error details, like this:\r\n\r\n```\r\n ============================= test session starts =============================\r\nplatform win32 -- Python 3.9.6, pytest-6.2.5, py-1.10.0, pluggy-0.13.1 -- \r\ncachedir: .pytest_cache\r\nrootdir: \r\nplugins: allure-pytest-2.9.45\r\ncollecting ... collected 1 item\r\n\r\ntest_statement.py::test_right_statement FAILED                           [100%]\r\n\r\n================================== FAILURES ===================================\r\n____________________________ test_right_statement _____________________________\r\n\r\nfoo = 1\r\n\r\n    def test_right_statement(foo):\r\n>       assert foo == (3 + 2) * (6 + 9)\r\n    \r\n        @t\r\nE       assert 1 == 75\r\nE         +1\r\nE         -75\r\n\r\ntest_statement.py:14: AssertionError\r\n=========================== short test summary info ===========================\r\nFAILED test_statement.py::test_right_statement - assert 1 == 75\r\n============================== 1 failed in 0.12s ==============================\r\n```\r\nAnd the same thing **did not** happen when using python3.7.10：\r\n```\r\n============================= test session starts =============================\r\nplatform win32 -- Python 3.7.10, pytest-6.2.5, py-1.11.0, pluggy-1.0.0 -- \r\ncachedir: .pytest_cache\r\nrootdir: \r\ncollecting ... collected 1 item\r\n\r\ntest_statement.py::test_right_statement FAILED                           [100%]\r\n\r\n================================== FAILURES ===================================\r\n____________________________ test_right_statement _____________________________\r\n\r\nfoo = 1\r\n\r\n    def test_right_statement(foo):\r\n>       assert foo == (3 + 2) * (6 + 9)\r\nE       assert 1 == 75\r\nE         +1\r\nE         -75\r\n\r\ntest_statement.py:14: AssertionError\r\n=========================== short test summary info ===========================\r\nFAILED test_statement.py::test_right_statement - assert 1 == 75\r\n============================== 1 failed in 0.03s ==============================\r\n```\r\nIs there some problems when calculate the statement lineno?\r\n\r\n### pip list \r\n```\r\n$ pip list\r\nPackage            Version\r\n------------------ -------\r\natomicwrites       1.4.0\r\nattrs              21.2.0\r\ncolorama           0.4.4\r\nimportlib-metadata 4.8.2\r\niniconfig          1.1.1\r\npackaging          21.3\r\npip                21.3.1\r\npluggy             1.0.0\r\npy                 1.11.0\r\npyparsing          3.0.6\r\npytest             6.2.5\r\nsetuptools         59.4.0\r\ntoml               0.10.2\r\ntyping_extensions  4.0.0\r\nzipp               3.6.0\r\n\r\n```\r\n### pytest and operating system versions\r\npytest 6.2.5\r\nWindows 10 \r\nSeems to happen in python 3.9,not 3.7\r\n\n",
    "patch": "diff --git a/src/_pytest/_code/source.py b/src/_pytest/_code/source.py\n--- a/src/_pytest/_code/source.py\n+++ b/src/_pytest/_code/source.py\n@@ -149,6 +149,11 @@ def get_statement_startend2(lineno: int, node: ast.AST) -> Tuple[int, Optional[i\n     values: List[int] = []\n     for x in ast.walk(node):\n         if isinstance(x, (ast.stmt, ast.ExceptHandler)):\n+            # Before Python 3.8, the lineno of a decorated class or function pointed at the decorator.\n+            # Since Python 3.8, the lineno points to the class/def, so need to include the decorators.\n+            if isinstance(x, (ast.ClassDef, ast.FunctionDef, ast.AsyncFunctionDef)):\n+                for d in x.decorator_list:\n+                    values.append(d.lineno - 1)\n             values.append(x.lineno - 1)\n             for name in (\"finalbody\", \"orelse\"):\n                 val: Optional[List[ast.stmt]] = getattr(x, name, None)\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_3088",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves progress reporting errors due to teardown failures, which is unrelated to assertion error line reporting."
      },
      {
        "idx": 2,
        "id": "similar_1397",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about excessive verbose output in CI environments, not related to assertion error line reporting."
      },
      {
        "idx": 3,
        "id": "similar_2895",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves a hook not triggering during test collection, unrelated to assertion error line reporting."
      },
      {
        "idx": 4,
        "id": "similar_3773",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about test discovery not including certain files, unrelated to assertion error line reporting."
      },
      {
        "idx": 5,
        "id": "similar_5547",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves stepwise execution with xfail markers, unrelated to assertion error line reporting."
      }
    ]
  },
  "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:\n\nThis issue is related to incorrect reporting of test suite progress percentages when a test teardown phase fails. Specifically, the progress exceeds the typical 100% threshold, inaccurately displaying up to 200% completion. This is a result of a failure in the teardown process of a test fixture, which is not handled correctly by the progress reporting mechanism.\n\n1. **Problem Description in General Terms**:\n   The problem involves the incorrect calculation and display of progress percentages in test suite execution reports when there is a failure during the teardown phase of a test.\n\n2. **Key Symptoms and Behaviors Observed**:\n   - The test suite progress is reported as exceeding 100%, sometimes reaching up to 200%.\n   - The issue arises when a teardown function within a test fails, which is not accounted for correctly in the progress calculation.\n\n3. **Affected Components or Systems**:\n   - The issue affects the pytest terminal reporter component, specifically how it logs and calculates test progress during test execution.\n   - The problem occurs in systems using Python 3.6.4 with pytest version 3.3.1 and is observed on a Linux platform.\n\n4. **Potential Impact or Severity**:\n   - The severity of the issue is moderate, as it primarily affects the accuracy of test progress reporting, potentially leading to confusion or misinterpretation of test suite execution status by developers and testers.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**:\n   - The problem is linked to the pytest framework's terminal reporting functionality, where the test progress calculation does not account for failed teardown phases.\n   - The issue highlights the importance of robust error handling and accurate state tracking in test reporting mechanisms to ensure clarity and correctness in test suite execution feedback.\n\nFixes implemented in the patch address this issue by adjusting the relevant functions within the pytest terminal reporting module to handle teardown failures appropriately, ensuring the progress percentages are calculated and reported accurately.",
      "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": "\"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:\nThis issue is concerned with the display of progress messages when running tests using the `py.test` tool with color output enabled in continuous integration environments. Specifically, when tests are executed with the `--color=yes` option on CI platforms like Jenkins, where output is redirected and captured, the \"collecting\" progress messages appear repeatedly, cluttering the output log.\n\n1. **Problem description in general terms**: The problem involves excessive verbose output related to test collection progress when using colored output in automated test environments, which leads to cluttered logs.\n\n2. **Key symptoms and behaviors observed**: Users observe that the \"collecting\" messages are duplicated for each test item, resulting in a large number of lines in the output. This occurs while the output is redirected, such as during CI pipeline execution, and is exacerbated by the use of colored output.\n\n3. **Affected components or systems**: The affected component is the test runner, `py.test`, specifically its terminal reporting functionality when integrated with CI systems that capture stdout.\n\n4. **Potential impact or severity**: The issue primarily affects readability and usability of test logs in CI systems. Although it does not impact the actual execution of tests, it hinders efficient log analysis and can be a nuisance in large test suites.\n\n5. **Any relevant technical details abstracted for broader understanding**: The problem arises from the TerminalReporter class in py.test, which handles the output of test progress to the terminal. The redundant \"collecting\" messages are a result of how the progress is reported when output is captured. The resolution likely involves modifying how these messages are managed to reduce redundancy without losing other important header information in logs.\n\nChanges Summary:\nThe fix was implemented by modifying several functions within the `TerminalReporter` class, specifically `__init__`, `pytest_runtest_logreport`, `pytest_collectreport`, and `report_collect`, which are responsible for managing the display of test processing messages.",
      "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": "pytest_report_collectionfinish does not execute with --collect-only",
        "issue_body": "As commented [here](https://github.com/pytest-dev/pytest/pull/2623#issuecomment-341478287).",
        "issue_id": 2895,
        "pr_number": 4749,
        "pr_title": "Merge master into features",
        "pr_body": "",
        "issue_closed_at": "2019-02-06T22:38:12Z",
        "base_commit": "4cd268dc5d19a5ac362785d3068229559e69ddd7"
      },
      "summary": "### Summary:\n\nThis issue is related to the behavior of the `pytest` testing framework, specifically regarding the execution of the `pytest_report_collectionfinish` hook when the `--collect-only` option is used. \n\n1. **Problem Description in General Terms**: The problem is that a specific hook (`pytest_report_collectionfinish`) does not get triggered as expected when tests are collected but not executed. This hook is intended to run after test collection is completed, providing an opportunity to perform actions or generate reports based on the collected test information.\n\n2. **Key Symptoms and Behaviors Observed**: The primary symptom is the non-execution of the `pytest_report_collectionfinish` hook during the test collection phase when the `--collect-only` option is used. Users expecting certain functionalities or outputs dependent on this hook would find them missing or incomplete.\n\n3. **Affected Components or Systems**: The components affected include various parts of the `pytest` framework responsible for test collection and reporting. Specifically, the issue impacted functions and methods related to configuration, logging, session management, test collection, and terminal output.\n\n4. **Potential Impact or Severity**: The impact of this issue is primarily on users who rely on the `pytest_report_collectionfinish` hook for generating reports or performing actions post-test collection. While it does not affect the execution of tests directly, it may lead to incomplete reporting or analysis workflows, particularly in environments where test collection and reporting are automated.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The fix involved changes across multiple modules within the `pytest` framework, including configuration initialization, logging setup, session filtering, test collection, API handling, and terminal reporting. This indicates a broad impact on the framework's internal mechanisms for handling hooks and reporting, necessitating adjustments to ensure the hook executes correctly under the specified conditions.",
      "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_report_collectionfinish does not execute with --collect-only\n\nBody:\nAs commented [here](https://github.com/pytest-dev/pytest/pull/2623#issuecomment-341478287).\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/config/__init__.py\n  function: _get_plugin_specs_as_list\n\nsrc/_pytest/logging.py\n  function: get_actual_log_level\n  function: _LiveLoggingStreamHandler.__init__\n  function: _LiveLoggingStreamHandler.__init__\n  function: LoggingPlugin._log_cli_enabled\n  function: LoggingPlugin.pytest_sessionfinish\n  function: LoggingPlugin.pytest_runtestloop\n\nsrc/_pytest/main.py\n  function: Session.filter_\n\nsrc/_pytest/python.py\n  function: Package.gethookproxy\n  function: Instance.collect\n  function: _find_parametrized_scope\n  function: _idval\n\nsrc/_pytest/python_api.py\n  function: raises\n\nsrc/_pytest/terminal.py\n  function: TerminalReporter.pytest_report_header\n\nsrc/_pytest/unittest.py\n  function: _make_xunit_fixture\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 pertains to the Pytest testing framework, specifically version 3.7.1, where a problem was identified with the framework's inability to collect `__init__.py` files during test discovery. Users who configured their `pytest.ini` files with `python_files` set to `*.py` experienced this problem, despite having correctly named test functions (e.g., `test_*`).\n\n1. **Problem Description in General Terms**: The issue arises from Pytest failing to recognize and include `__init__.py` files in its test collection process, even when configuration files are set to include all Python files.\n\n2. **Key Symptoms and Behaviors Observed**: The primary symptom observed is that `__init__.py` files are not being collected by Pytest during test discovery, resulting in a failure to execute tests that may reside within these files. This was evident when running the `pytest --collect-only` command, which listed only tests from other files.\n\n3. **Affected Components or Systems**: The issue affects the Pytest framework, particularly the components and functions responsible for test collection and discovery, such as those in the `src/_pytest/python.py` file. It involves various related functions and classes that handle file parsing and test execution.\n\n4. **Potential Impact or Severity**: This issue could significantly impact developers relying on `__init__.py` files for organizing tests within packages, leading to incomplete test runs and potentially overlooked test failures. It decreases the reliability of test coverage, especially in projects structured with `__init__.py` files containing test cases.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The problem centers around the test collection mechanism in Pytest, which was resolved by modifying code elements spread across multiple files within the Pytest codebase. Fixes included adjustments to functions related to test collection, assertion rewriting, capture management, and configuration parsing. These changes ensure proper recognition and inclusion of `__init__.py` files during test discovery, thereby restoring expected behavior.\n\nThe resolution involved addressing issues in numerous files and functions, such as `pytest_collect_file` in `src/_pytest/python.py`, ensuring that test discovery mechanisms correctly handle all intended files, including `__init__.py`.",
      "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": "pytest stepwise doesn't work with xfail strict failures",
        "issue_body": "```\r\ngraingert@onomastic:~/projects/foo$ cat tests/test_foo.py \r\nimport pytest\r\n\r\n\r\n@pytest.mark.xfail(reason=\"pass\")\r\ndef test_a():\r\n    pass\r\n\r\n\r\n@pytest.mark.xfail(reason=\"pass\")\r\ndef test_b():\r\n    pass\r\ngraingert@onomastic:~/projects/foo$ cat tests/pytest.ini \r\n[pytest]\r\naddopts = --strict\r\nxfail_strict=true\r\ngraingert@onomastic:~/projects/foo$ pytest --sw tests/\r\n================================ test session starts ================================\r\nplatform linux -- Python 3.7.3, pytest-5.0.0, py-1.8.0, pluggy-0.12.0\r\nrootdir: /home/graingert/projects/foo/tests, inifile: pytest.ini\r\ncollected 2 items                                                                   \r\nstepwise: no previously failed tests, not skipping.\r\n\r\ntests/test_foo.py FF                                                          [100%]\r\n\r\n===================================== FAILURES ======================================\r\n______________________________________ test_a _______________________________________\r\n[XPASS(strict)] pass\r\n______________________________________ test_b _______________________________________\r\n[XPASS(strict)] pass\r\n============================= 2 failed in 0.01 seconds ==============================\r\n```",
        "issue_id": 5547,
        "pr_number": 5559,
        "pr_title": "Merge master into features",
        "pr_body": "",
        "issue_closed_at": "2019-07-04T23:50:34Z",
        "base_commit": "60a358fa2dc82a571c68d1be2d25703b51351538"
      },
      "summary": "### Summary:\n\nThis issue is related to the pytest testing framework, specifically when using the `stepwise` feature in conjunction with tests marked as `xfail` and executed with `strict` mode enabled. \n\n1. **Problem Description in General Terms:**\n   The problem arises when utilizing pytest's `stepwise` feature, which is intended to run tests incrementally, skipping those that have already passed and focusing on previously failed ones. The issue occurs when tests are marked with `xfail` under strict conditions, leading to unexpected behavior.\n\n2. **Key Symptoms and Behaviors Observed:**\n   The primary symptom is that tests marked with `xfail` and expected to fail (XPASS) under strict conditions are not handled correctly by the `stepwise` feature. Instead of recognizing these tests as strictly failed, the system incorrectly handles them, resulting in all such tests being reported as failures, which affects the stepwise execution logic.\n\n3. **Affected Components or Systems:**\n   The issue affects the pytest testing framework, particularly the components related to test collection and execution using the `stepwise` feature and `xfail` markers under strict conditions. Specifically, changes were made to files within the pytest codebase such as `conftest.py`, `code.py`, and `stepwise.py` to address the issue.\n\n4. **Potential Impact or Severity:**\n   The impact of this issue is significant for developers who rely on the `stepwise` feature to efficiently manage test execution, especially in scenarios where tests are expected to have known failures. It could lead to incorrect test reporting and inefficient test runs, affecting the overall development and testing workflow.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   - The problem is triggered by the combination of `xfail` markers with `strict` mode, which expects tests that pass unexpectedly to be treated as failures.\n   - The `stepwise` feature was not appropriately handling these strict xfail conditions, leading to incorrect test failure reports.\n   - Fixes involved modifications to the pytest codebase, particularly in the way exceptions and test collection modifications are handled, to ensure proper functionality of the `stepwise` feature with strict xfail tests.",
      "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 stepwise doesn't work with xfail strict failures\n\nBody:\n```\r\ngraingert@onomastic:~/projects/foo$ cat tests/test_foo.py \r\nimport pytest\r\n\r\n\r\n@pytest.mark.xfail(reason=\"pass\")\r\ndef test_a():\r\n    pass\r\n\r\n\r\n@pytest.mark.xfail(reason=\"pass\")\r\ndef test_b():\r\n    pass\r\ngraingert@onomastic:~/projects/foo$ cat tests/pytest.ini \r\n[pytest]\r\naddopts = --strict\r\nxfail_strict=true\r\ngraingert@onomastic:~/projects/foo$ pytest --sw tests/\r\n================================ test session starts ================================\r\nplatform linux -- Python 3.7.3, pytest-5.0.0, py-1.8.0, pluggy-0.12.0\r\nrootdir: /home/graingert/projects/foo/tests, inifile: pytest.ini\r\ncollected 2 items                                                                   \r\nstepwise: no previously failed tests, not skipping.\r\n\r\ntests/test_foo.py FF                                                          [100%]\r\n\r\n===================================== FAILURES ======================================\r\n______________________________________ test_a _______________________________________\r\n[XPASS(strict)] pass\r\n______________________________________ test_b _______________________________________\r\n[XPASS(strict)] pass\r\n============================= 2 failed in 0.01 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:\ndoc/en/example/nonpython/conftest.py\n  line: line 3\n\nsrc/_pytest/_code/code.py\n  function: ExceptionInfo.match\n\nsrc/_pytest/stepwise.py\n  function: StepwisePlugin.pytest_collection_modifyitems\n"
    }
  ]
}