{
  "original_problem": {
    "instance_id": "pytest-dev__pytest-5221",
    "repo": "pytest-dev/pytest",
    "created_at": "2019-05-06T22:36:44Z",
    "problem_statement": "Display fixture scope with `pytest --fixtures`\nIt would be useful to show fixture scopes with `pytest --fixtures`; currently the only way to learn the scope of a fixture is look at the docs (when that is documented) or at the source code.\n",
    "patch": "diff --git a/src/_pytest/python.py b/src/_pytest/python.py\n--- a/src/_pytest/python.py\n+++ b/src/_pytest/python.py\n@@ -1342,17 +1342,19 @@ def _showfixtures_main(config, session):\n                 currentmodule = module\n         if verbose <= 0 and argname[0] == \"_\":\n             continue\n+        tw.write(argname, green=True)\n+        if fixturedef.scope != \"function\":\n+            tw.write(\" [%s scope]\" % fixturedef.scope, cyan=True)\n         if verbose > 0:\n-            funcargspec = \"%s -- %s\" % (argname, bestrel)\n-        else:\n-            funcargspec = argname\n-        tw.line(funcargspec, green=True)\n+            tw.write(\" -- %s\" % bestrel, yellow=True)\n+        tw.write(\"\\n\")\n         loc = getlocation(fixturedef.func, curdir)\n         doc = fixturedef.func.__doc__ or \"\"\n         if doc:\n             write_docstring(tw, doc)\n         else:\n             tw.line(\"    %s: no docstring available\" % (loc,), red=True)\n+        tw.line()\n \n \n def write_docstring(tw, doc, indent=\"    \"):\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_2535",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue focuses on integration and error messaging between pytest and unittest, which is unrelated to displaying fixture scopes."
      },
      {
        "idx": 2,
        "id": "similar_736",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue deals with naming conflicts in parameterized fixtures, which does not relate to displaying fixture scopes."
      },
      {
        "idx": 3,
        "id": "similar_1857",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about parameterized test identifiers, which is unrelated to the display of fixture scopes."
      },
      {
        "idx": 4,
        "id": "similar_3605",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves custom markers and type mismatches, which does not relate to fixture scope display."
      },
      {
        "idx": 5,
        "id": "similar_2486",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about an internal error in traceback processing, unrelated to fixture scope display."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Better error message needed for parametrized fixtures with unittest",
        "issue_body": "- [x] Include a detailed description of the bug or suggestion\r\n\r\nunittest style tests are allowed to use pytest fixtures through `@pytest.mark.usefixtures()`.\r\nHowever, if the fixture is paramterized, it crashes and burns and gives a bizarre message of:\r\n`E               Failed: The requested fixture has no parameter defined for the current test.`\r\n\r\nThat wouldn't be so terribly bad, if it wasn't for the other 96 lines of error message that come with it.\r\n\r\n- [x] `pip list` of the virtual environment you are using\r\npip (9.0.1)\r\npy (1.4.34)\r\npytest (3.1.2)\r\nsetuptools (36.0.1)\r\nwheel (0.29.0)\r\n\r\n- [x] pytest and operating system versions\r\nplatform linux -- Python 3.6.1, pytest-3.1.2, py-1.4.34, pluggy-0.4.0\r\n\r\npytest 3.1.2, on Ubuntu Linux running on Windows 10.\r\n\r\n- [x] Minimal example if possible\r\n\r\ntest_one() will pass, test_two() will not only Error, it spews lots of rubbish to confuse the user.\r\n\r\n```\r\nimport pytest\r\nimport unittest\r\n\r\n@pytest.fixture()\r\ndef one():\r\n  return 42\r\n\r\n@pytest.mark.usefixtures('one')\r\nclass TestSomething(unittest.TestCase):\r\n  def test_one(self):\r\n    pass\r\n\r\n@pytest.fixture(params=[1,2])\r\ndef two(request):\r\n  return request.param\r\n\r\n@pytest.mark.usefixtures('two')\r\nclass TestSomethingElse(unittest.TestCase):\r\n  def test_two(self):\r\n    pass\r\n```\r\n\r\noutput\r\n```\r\n(unit_venv) okken@RSA22473:~/projects/unit/fail$ pytest test_something.py\r\n================================== test session starts ==================================\r\nplatform linux -- Python 3.6.1, pytest-3.1.2, py-1.4.34, pluggy-0.4.0\r\nrootdir: /home/okken/projects/unit/fail, inifile: pytest.ini\r\ncollected 2 items\r\n\r\ntest_something.py .E\r\n\r\n======================================== ERRORS =========================================\r\n_____________________ ERROR at setup of TestSomethingElse.test_two ______________________\r\n\r\nself = <FixtureRequest for <TestCaseFunction 'test_two'>>\r\nfixturedef = <FixtureDef name='two' scope='function' baseid='test_something.py' >\r\n\r\n    def _getfixturevalue(self, fixturedef):\r\n        # prepare a subrequest object before calling fixture function\r\n        # (latter managed by fixturedef)\r\n        argname = fixturedef.argname\r\n        funcitem = self._pyfuncitem\r\n        scope = fixturedef.scope\r\n        try:\r\n>           param = funcitem.callspec.getparam(argname)\r\nE           AttributeError: 'TestCaseFunction' object has no attribute 'callspec'\r\n\r\n../unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:472: AttributeError\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nself = <CallInfo when='setup' exception: The requested fixture has no parameter defined for the current test.\r\n\r\nRequested fixt...mething.py:14\r\n\r\nRequested here:\r\n/home/okken/projects/unit/unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:382>\r\nfunc = <function call_runtest_hook.<locals>.<lambda> at 0x7f7689467f28>, when = 'setup'\r\n\r\n    def __init__(self, func, when):\r\n        #: context of invocation: one of \"setup\", \"call\",\r\n        #: \"teardown\", \"memocollect\"\r\n        self.when = when\r\n        self.start = time()\r\n        try:\r\n>           self.result = func()\r\n\r\n../unit_venv/lib/python3.6/site-packages/_pytest/runner.py:157:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n../unit_venv/lib/python3.6/site-packages/_pytest/runner.py:145: in <lambda>\r\n    return CallInfo(lambda: ihook(item=item, **kwds), when=when)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:745: in __call__\r\n    return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:339: in _hookexec\r\n    return self._inner_hookexec(hook, methods, kwargs)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:334: in <lambda>\r\n    _MultiCall(methods, kwargs, hook.spec_opts).execute()\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:613: in execute\r\n    return _wrapped_call(hook_impl.function(*args), self.execute)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:254: in _wrapped_call\r\n    return call_outcome.get_result()\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:279: in get_result\r\n    raise ex[1].with_traceback(ex[2])\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:265: in __init__\r\n    self.result = func()\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:614: in execute\r\n    res = hook_impl.function(*args)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/runner.py:94: in pytest_runtest_setup\r\n    item.session._setupstate.prepare(item)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/runner.py:449: in prepare\r\n    col.setup()\r\n../unit_venv/lib/python3.6/site-packages/_pytest/unittest.py:79: in setup\r\n    self._request._fillfixtures()\r\n../unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:382: in _fillfixtures\r\n    item.funcargs[argname] = self.getfixturevalue(argname)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:424: in getfixturevalue\r\n    return self._get_active_fixturedef(argname).cached_result[0]\r\n../unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:449: in _get_active_fixturedef\r\n    result = self._getfixturevalue(fixturedef)\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nself = <FixtureRequest for <TestCaseFunction 'test_two'>>\r\nfixturedef = <FixtureDef name='two' scope='function' baseid='test_something.py' >\r\n\r\n    def _getfixturevalue(self, fixturedef):\r\n        # prepare a subrequest object before calling fixture function\r\n        # (latter managed by fixturedef)\r\n        argname = fixturedef.argname\r\n        funcitem = self._pyfuncitem\r\n        scope = fixturedef.scope\r\n        try:\r\n            param = funcitem.callspec.getparam(argname)\r\n        except (AttributeError, ValueError):\r\n            param = NOTSET\r\n            param_index = 0\r\n            if fixturedef.params is not None:\r\n                frame = inspect.stack()[3]\r\n                frameinfo = inspect.getframeinfo(frame[0])\r\n                source_path = frameinfo.filename\r\n                source_lineno = frameinfo.lineno\r\n                source_path = py.path.local(source_path)\r\n                if source_path.relto(funcitem.config.rootdir):\r\n                    source_path = source_path.relto(funcitem.config.rootdir)\r\n                msg = (\r\n                    \"The requested fixture has no parameter defined for the \"\r\n                    \"current test.\\n\\nRequested fixture '{0}' defined in:\\n{1}\"\r\n                    \"\\n\\nRequested here:\\n{2}:{3}\".format(\r\n                        fixturedef.argname,\r\n                        getlocation(fixturedef.func, funcitem.config.rootdir),\r\n                        source_path,\r\n                        source_lineno,\r\n                    )\r\n                )\r\n>               fail(msg)\r\nE               Failed: The requested fixture has no parameter defined for the current test.\r\nE\r\nE               Requested fixture 'two' defined in:\r\nE               test_something.py:14\r\nE\r\nE               Requested here:\r\nE               /home/okken/projects/unit/unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:382\r\n\r\n../unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:494: Failed\r\n=========================== 1 passed, 1 error in 0.58 seconds ===========================\r\n```\r\n\r\n",
        "issue_id": 2535,
        "pr_number": 4076,
        "pr_title": "Improve error message when TestCase functions use a parametrized fixture",
        "pr_body": "Fix #2535\r\n",
        "issue_closed_at": "2018-10-06T05:43:58Z",
        "base_commit": "e712adc22651d9c9be5adc1a3337353e0dd1b225"
      },
      "summary": "### Summary:\n\nThis issue is related to the integration of `pytest` fixtures with `unittest` style tests, specifically when dealing with parameterized fixtures. The problem arises when a `pytest` fixture, which is parameterized, is used within a `unittest` test case, leading to a failure with an unclear and verbose error message.\n\n1. **Problem Description in General Terms:**\n   The issue involves the improper handling of parameterized `pytest` fixtures when they are utilized in `unittest` style test cases. This results in an inability for the test to execute correctly, and an overly complex error message is generated, which can be confusing to users.\n\n2. **Key Symptoms and Behaviors Observed:**\n   - When a parameterized fixture is applied to a `unittest` test case, an error occurs.\n   - The error message is not only unclear but also excessively lengthy, containing many lines of stack trace and technical details that obfuscate the core issue.\n   - The specific error message indicates that the fixture lacks a parameter definition for the current test, pointing to an `AttributeError` due to the absence of a `callspec` attribute.\n\n3. **Affected Components or Systems:**\n   - The integration between `pytest` and `unittest` frameworks is primarily affected.\n   - Specifically, the `pytest` fixture management system fails when invoked in the context of `unittest` test cases that require parameterization.\n\n4. **Potential Impact or Severity:**\n   - The issue significantly impacts developers who rely on using parameterized fixtures within `unittest` styled tests, as it prevents successful test execution.\n   - The confusing error messages can lead to increased debugging time and difficulty in identifying the root cause, potentially discouraging the use of `pytest` fixtures with `unittest`.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   - The error originates from the `FixtureRequest` class within `pytest`, where the expected `callspec` attribute is not present on `TestCaseFunction` objects.\n   - This absence results in a failure to retrieve fixture parameters correctly, leading to a misleading error message.\n   - The problem highlights a gap in compatibility and error handling between `pytest` fixtures and `unittest` test cases, particularly in scenarios requiring parameterization.",
      "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: Better error message needed for parametrized fixtures with unittest\n\nBody:\n- [x] Include a detailed description of the bug or suggestion\r\n\r\nunittest style tests are allowed to use pytest fixtures through `@pytest.mark.usefixtures()`.\r\nHowever, if the fixture is paramterized, it crashes and burns and gives a bizarre message of:\r\n`E               Failed: The requested fixture has no parameter defined for the current test.`\r\n\r\nThat wouldn't be so terribly bad, if it wasn't for the other 96 lines of error message that come with it.\r\n\r\n- [x] `pip list` of the virtual environment you are using\r\npip (9.0.1)\r\npy (1.4.34)\r\npytest (3.1.2)\r\nsetuptools (36.0.1)\r\nwheel (0.29.0)\r\n\r\n- [x] pytest and operating system versions\r\nplatform linux -- Python 3.6.1, pytest-3.1.2, py-1.4.34, pluggy-0.4.0\r\n\r\npytest 3.1.2, on Ubuntu Linux running on Windows 10.\r\n\r\n- [x] Minimal example if possible\r\n\r\ntest_one() will pass, test_two() will not only Error, it spews lots of rubbish to confuse the user.\r\n\r\n```\r\nimport pytest\r\nimport unittest\r\n\r\n@pytest.fixture()\r\ndef one():\r\n  return 42\r\n\r\n@pytest.mark.usefixtures('one')\r\nclass TestSomething(unittest.TestCase):\r\n  def test_one(self):\r\n    pass\r\n\r\n@pytest.fixture(params=[1,2])\r\ndef two(request):\r\n  return request.param\r\n\r\n@pytest.mark.usefixtures('two')\r\nclass TestSomethingElse(unittest.TestCase):\r\n  def test_two(self):\r\n    pass\r\n```\r\n\r\noutput\r\n```\r\n(unit_venv) okken@RSA22473:~/projects/unit/fail$ pytest test_something.py\r\n================================== test session starts ==================================\r\nplatform linux -- Python 3.6.1, pytest-3.1.2, py-1.4.34, pluggy-0.4.0\r\nrootdir: /home/okken/projects/unit/fail, inifile: pytest.ini\r\ncollected 2 items\r\n\r\ntest_something.py .E\r\n\r\n======================================== ERRORS =========================================\r\n_____________________ ERROR at setup of TestSomethingElse.test_two ______________________\r\n\r\nself = <FixtureRequest for <TestCaseFunction 'test_two'>>\r\nfixturedef = <FixtureDef name='two' scope='function' baseid='test_something.py' >\r\n\r\n    def _getfixturevalue(self, fixturedef):\r\n        # prepare a subrequest object before calling fixture function\r\n        # (latter managed by fixturedef)\r\n        argname = fixturedef.argname\r\n        funcitem = self._pyfuncitem\r\n        scope = fixturedef.scope\r\n        try:\r\n>           param = funcitem.callspec.getparam(argname)\r\nE           AttributeError: 'TestCaseFunction' object has no attribute 'callspec'\r\n\r\n../unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:472: AttributeError\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nself = <CallInfo when='setup' exception: The requested fixture has no parameter defined for the current test.\r\n\r\nRequested fixt...mething.py:14\r\n\r\nRequested here:\r\n/home/okken/projects/unit/unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:382>\r\nfunc = <function call_runtest_hook.<locals>.<lambda> at 0x7f7689467f28>, when = 'setup'\r\n\r\n    def __init__(self, func, when):\r\n        #: context of invocation: one of \"setup\", \"call\",\r\n        #: \"teardown\", \"memocollect\"\r\n        self.when = when\r\n        self.start = time()\r\n        try:\r\n>           self.result = func()\r\n\r\n../unit_venv/lib/python3.6/site-packages/_pytest/runner.py:157:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n../unit_venv/lib/python3.6/site-packages/_pytest/runner.py:145: in <lambda>\r\n    return CallInfo(lambda: ihook(item=item, **kwds), when=when)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:745: in __call__\r\n    return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:339: in _hookexec\r\n    return self._inner_hookexec(hook, methods, kwargs)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:334: in <lambda>\r\n    _MultiCall(methods, kwargs, hook.spec_opts).execute()\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:613: in execute\r\n    return _wrapped_call(hook_impl.function(*args), self.execute)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:254: in _wrapped_call\r\n    return call_outcome.get_result()\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:279: in get_result\r\n    raise ex[1].with_traceback(ex[2])\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:265: in __init__\r\n    self.result = func()\r\n../unit_venv/lib/python3.6/site-packages/_pytest/vendored_packages/pluggy.py:614: in execute\r\n    res = hook_impl.function(*args)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/runner.py:94: in pytest_runtest_setup\r\n    item.session._setupstate.prepare(item)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/runner.py:449: in prepare\r\n    col.setup()\r\n../unit_venv/lib/python3.6/site-packages/_pytest/unittest.py:79: in setup\r\n    self._request._fillfixtures()\r\n../unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:382: in _fillfixtures\r\n    item.funcargs[argname] = self.getfixturevalue(argname)\r\n../unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:424: in getfixturevalue\r\n    return self._get_active_fixturedef(argname).cached_result[0]\r\n../unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:449: in _get_active_fixturedef\r\n    result = self._getfixturevalue(fixturedef)\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nself = <FixtureRequest for <TestCaseFunction 'test_two'>>\r\nfixturedef = <FixtureDef name='two' scope='function' baseid='test_something.py' >\r\n\r\n    def _getfixturevalue(self, fixturedef):\r\n        # prepare a subrequest object before calling fixture function\r\n        # (latter managed by fixturedef)\r\n        argname = fixturedef.argname\r\n        funcitem = self._pyfuncitem\r\n        scope = fixturedef.scope\r\n        try:\r\n            param = funcitem.callspec.getparam(argname)\r\n        except (AttributeError, ValueError):\r\n            param = NOTSET\r\n            param_index = 0\r\n            if fixturedef.params is not None:\r\n                frame = inspect.stack()[3]\r\n                frameinfo = inspect.getframeinfo(frame[0])\r\n                source_path = frameinfo.filename\r\n                source_lineno = frameinfo.lineno\r\n                source_path = py.path.local(source_path)\r\n                if source_path.relto(funcitem.config.rootdir):\r\n                    source_path = source_path.relto(funcitem.config.rootdir)\r\n                msg = (\r\n                    \"The requested fixture has no parameter defined for the \"\r\n                    \"current test.\\n\\nRequested fixture '{0}' defined in:\\n{1}\"\r\n                    \"\\n\\nRequested here:\\n{2}:{3}\".format(\r\n                        fixturedef.argname,\r\n                        getlocation(fixturedef.func, funcitem.config.rootdir),\r\n                        source_path,\r\n                        source_lineno,\r\n                    )\r\n                )\r\n>               fail(msg)\r\nE               Failed: The requested fixture has no parameter defined for the current test.\r\nE\r\nE               Requested fixture 'two' defined in:\r\nE               test_something.py:14\r\nE\r\nE               Requested here:\r\nE               /home/okken/projects/unit/unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:382\r\n\r\n../unit_venv/lib/python3.6/site-packages/_pytest/fixtures.py:494: Failed\r\n=========================== 1 passed, 1 error in 0.58 seconds ===========================\r\n```\r\n\r\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsrc/_pytest/fixtures.py\n  function: FixtureRequest._compute_fixture_value\n  function: FixtureRequest._compute_fixture_value\n"
    },
    {
      "similar_issue": {
        "issue_title": "Parametrized argument named similarly to fixture (contains it) breaks that fixture's parametrization",
        "issue_body": "Originally reported by: **Jacobo Giralt (BitBucket: [jgiralt](http://bitbucket.org/jgiralt), GitHub: [jgiralt](http://github.com/jgiralt))**\n\n---\n\n```\n#!python\n\nimport pytest\n\n@pytest.fixture(params=[1,2,3])\ndef foo(request):\n    return request.param\n\n@pytest.mark.parametrize('foobar', [4,5,6])\ndef test_issue(foo, foobar):\n    assert True\n```\n\n```\n#!python\n\nrequest = <SubRequest 'foo' for <Function 'test_issue[4]'>>\n\n    @pytest.fixture(params=[1,2,3])\n    def foo(request):\n>       return request.param\nAttributeError: SubRequest instance has no attribute 'param'\n```\n\nThe issue seems reproducible as long as the parametrized test argument contains the fixture name as a substring, e.g. foobar, barfoo, foox, xfoo, disappears as soon as I modify the fixture name to anything else.\n\nThis same code works in pytest-2.6.4 and fails for 2.7.\n\n---\n- Bitbucket: https://bitbucket.org/pytest-dev/pytest/issue/736\n",
        "issue_id": 736,
        "pr_number": 926,
        "pr_title": "Don't skip fixtures that are substrings of params",
        "pr_body": "Fix #736\n",
        "issue_closed_at": "2015-08-11T00:12:52Z",
        "base_commit": "681e502c12f5baa3f2da9c9de4a848813a872945"
      },
      "summary": "### Summary:\nThis issue involves a problem with the parametrization of fixtures in the pytest testing framework. Specifically, when a test is parametrized with an argument name that contains the name of a fixture as a substring, it breaks the fixture's ability to properly access its parameters. This leads to an `AttributeError` because the `SubRequest` object, which is supposed to provide the parameter to the fixture, loses the expected attribute `param`.\n\n1. **Problem Description**: The problem occurs when a test function is parametrized with argument names that include the name of an existing fixture as a substring. This naming conflict prevents the fixture from correctly accessing its parameters, causing an error during test execution.\n\n2. **Key Symptoms and Behaviors Observed**: The primary symptom observed is an `AttributeError` indicating that the `SubRequest` object does not have the attribute `param`. This error arises during the execution of the test function when the fixture attempts to access its parameter.\n\n3. **Affected Components or Systems**: The issue specifically affects the pytest testing framework, particularly the mechanism that handles fixtures and their parametrization. It is observed in versions of pytest starting from 2.7, whereas it worked correctly in version 2.6.4.\n\n4. **Potential Impact or Severity**: This bug can disrupt automated testing processes for developers using pytest, especially if they inadvertently use conflicting naming conventions for test arguments and fixtures. It can lead to failures in test execution and might necessitate renaming fixtures or test arguments to avoid the conflict, which can be inconvenient and time-consuming.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The problem is rooted in the way pytest manages names and the scope of fixture parameters. The conflict arises because the test argument naming interferes with the internal naming and parameter access mechanisms of fixtures. The issue is resolved by avoiding naming test arguments with substrings of fixture names, or by updating pytest to a version where this behavior is fixed. The patch involved changes to the `FixtureManager.pytest_generate_tests` function in the pytest codebase, indicating modifications to how tests are generated with respect to fixtures and their parameters.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Parametrized argument named similarly to fixture (contains it) breaks that fixture's parametrization\n\nBody:\nOriginally reported by: **Jacobo Giralt (BitBucket: [jgiralt](http://bitbucket.org/jgiralt), GitHub: [jgiralt](http://github.com/jgiralt))**\n\n---\n\n```\n#!python\n\nimport pytest\n\n@pytest.fixture(params=[1,2,3])\ndef foo(request):\n    return request.param\n\n@pytest.mark.parametrize('foobar', [4,5,6])\ndef test_issue(foo, foobar):\n    assert True\n```\n\n```\n#!python\n\nrequest = <SubRequest 'foo' for <Function 'test_issue[4]'>>\n\n    @pytest.fixture(params=[1,2,3])\n    def foo(request):\n>       return request.param\nAttributeError: SubRequest instance has no attribute 'param'\n```\n\nThe issue seems reproducible as long as the parametrized test argument contains the fixture name as a substring, e.g. foobar, barfoo, foox, xfoo, disappears as soon as I modify the fixture name to anything else.\n\nThis same code works in pytest-2.6.4 and fails for 2.7.\n\n---\n- Bitbucket: https://bitbucket.org/pytest-dev/pytest/issue/736\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\n_pytest/python.py\n  function: FixtureManager.pytest_generate_tests\n"
    },
    {
      "similar_issue": {
        "issue_title": "Parameterized ids can't be integers (was allowed in 2.9.2)",
        "issue_body": "Parameterized id's used to be able to be integers. Now that crashes verbosely.\n- [ x ] Include a detailed description of the bug \n\nUsed to be able to have numerical ids in paramterizations.\n3.0.0 crashes verbosely if you do that.\n- [ x ] `pip list` of the virtual environment you are using\n  (venv) $ pip list\n  numpy (1.11.1)\n  pip (8.1.2)\n  py (1.4.31)\n  pymongo (3.3.0)\n  pytest (3.0.0)\n  setuptools (20.10.1)\n  unnecessary-math (0.0.1)\n- [ x ] pytest and operating system versions\n  pytest 3.0.0 (tested against 2.9.2 and works there)\n  os: mac something\n- [ x ] Minimal example if possible\n\n```\nimport pytest\n\ntestdata = [( 1, 2), ( 2, 4)]\n\ndef times_2(x):\n    return x * 2\n\n@pytest.mark.parametrize(\"x,expected\", testdata, ids=('a','b'))\ndef test_ids_strings(x,expected):\n    '''works in both 3.0.0 and 2.9.2'''\n    assert times_2(x) == expected\n\n\n@pytest.mark.parametrize(\"x,expected\", testdata, ids=(1,2))\ndef test_ids_numbers(x,expected):\n    '''works in 2.9.2, crashes verbosely in 3.0.0'''\n    assert times_2(x) == expected\n\n```\n\n2.9.2:\n\n```\n(venv_2.9.2) $ py.test -v test_ids2.py \n================================ test session starts =================================\nplatform darwin -- Python 3.5.2, pytest-2.9.2, py-1.4.31, pluggy-0.3.1 -- /Users/okken/projects/book/bopytest/Book/code/pytest/um_project/tests/venv_2.9.2/bin/python3.5\ncachedir: ../.cache\nrootdir: /Users/okken/projects/book/bopytest/Book/code/pytest/um_project, inifile: \ncollected 4 items \n\ntest_ids2.py::test_ids_strings[a] PASSED\ntest_ids2.py::test_ids_strings[b] PASSED\ntest_ids2.py::test_ids_numbers[1] PASSED\ntest_ids2.py::test_ids_numbers[2] PASSED\n\n============================== 4 passed in 0.02 seconds ==============================\n```\n\n3.0.0:\n\n```\n(venv) $ pytest -v test_ids2.py \n============================= test session starts ==============================\nplatform darwin -- Python 3.5.2, pytest-3.0.0, py-1.4.31, pluggy-0.3.1 -- /Users/okken/projects/book/bopytest/Book/venv/bin/python3.5\ncachedir: ../.cache\nrootdir: /Users/okken/projects/book/bopytest/Book/code/pytest/um_project, inifile: \ncollected 0 items / 1 errors \n\n==================================== ERRORS ====================================\n_____________________ ERROR collecting tests/test_ids2.py ______________________\n../../../../venv/lib/python3.5/site-packages/_pytest/runner.py:163: in __init__\n    self.result = func()\n../../../../venv/lib/python3.5/site-packages/_pytest/main.py:460: in _memocollect\n    return self._memoizedcall('_collected', lambda: list(self.collect()))\n../../../../venv/lib/python3.5/site-packages/_pytest/main.py:331: in _memoizedcall\n    res = function()\n../../../../venv/lib/python3.5/site-packages/_pytest/main.py:460: in <lambda>\n    return self._memoizedcall('_collected', lambda: list(self.collect()))\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:404: in collect\n    return super(Module, self).collect()\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:318: in collect\n    res = self.makeitem(name, obj)\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:330: in makeitem\n    collector=self, name=name, obj=obj)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:724: in __call__\n    return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:338: in _hookexec\n    return self._inner_hookexec(hook, methods, kwargs)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:333: in <lambda>\n    _MultiCall(methods, kwargs, hook.spec_opts).execute()\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:595: in execute\n    return _wrapped_call(hook_impl.function(*args), self.execute)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:249: in _wrapped_call\n    wrap_controller.send(call_outcome)\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:191: in pytest_pycollect_makeitem\n    res = list(collector._genfunctions(name, obj))\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:350: in _genfunctions\n    self.ihook.pytest_generate_tests(metafunc=metafunc)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:724: in __call__\n    return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:338: in _hookexec\n    return self._inner_hookexec(hook, methods, kwargs)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:333: in <lambda>\n    _MultiCall(methods, kwargs, hook.spec_opts).execute()\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:596: in execute\n    res = hook_impl.function(*args)\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:104: in pytest_generate_tests\n    metafunc.parametrize(*marker.args, **marker.kwargs)\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:846: in parametrize\n    ids = idmaker(argnames, argvalues, idfn, ids, self.config)\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:933: in idmaker\n    for valindex, valset in enumerate(argvalues)]\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:933: in <listcomp>\n    for valindex, valset in enumerate(argvalues)]\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:929: in _idvalset\n    return _escape_strings(ids[idx])\n../../../../venv/lib/python3.5/site-packages/_pytest/compat.py:144: in _escape_strings\n    return val.encode('unicode_escape').decode('ascii')\nE   AttributeError: 'int' object has no attribute 'encode'\n!!!!!!!!!!!!!!!!!!! Interrupted: 1 errors during collection !!!!!!!!!!!!!!!!!!!!\n=========================== 1 error in 0.64 seconds ============================\n\n```\n",
        "issue_id": 1857,
        "pr_number": 1861,
        "pr_title": "Improve error message when passing non-string ids to pytest.mark.parametrize",
        "pr_body": "Fix #1857\n",
        "issue_closed_at": "2016-08-24T04:43:57Z",
        "base_commit": "ea0febad2873da4df524f78fb688a9b182c55587"
      },
      "summary": "### Summary:\nThis issue pertains to a regression in the pytest framework, specifically from version 2.9.2 to 3.0.0, where a change in behavior regarding parameterized test identifiers has been observed. Previously, in version 2.9.2, it was permissible to use integer values as identifiers in parameterized tests. However, with the transition to version 3.0.0, this functionality is no longer supported, resulting in a verbose crash when integers are used as identifiers.\n\n1. **Problem Description in General Terms**: The problem involves the handling of parameterized test identifiers in the pytest framework, where integer IDs that were previously acceptable now cause errors in the newer version.\n\n2. **Key Symptoms and Behaviors Observed**: When attempting to run parameterized tests with integer IDs in pytest version 3.0.0, the framework fails to execute the tests and instead produces a verbose error message. This is in contrast to the expected behavior observed in version 2.9.2, where such tests would pass successfully.\n\n3. **Affected Components or Systems**: The issue directly impacts the pytest framework, specifically affecting the test parameterization process within the testing suite. The problematic behavior is linked to the `Metafunc.parametrize` function within the `_pytest/python.py` module.\n\n4. **Potential Impact or Severity**: The severity of this issue is significant for developers who rely on integer identifiers for organizing and executing parameterized tests. It may disrupt testing workflows and necessitate changes in test suites to accommodate the new behavior in pytest 3.0.0.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The core technical change involves the handling of IDs within the `Metafunc.parametrize` function, where integer IDs now trigger an `AttributeError` due to a failed attempt to encode them as strings. This indicates a shift in the internal handling of identifiers, necessitating adjustments or conversions of integer IDs to string formats to maintain compatibility with the updated framework version.",
      "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: Parameterized ids can't be integers (was allowed in 2.9.2)\n\nBody:\nParameterized id's used to be able to be integers. Now that crashes verbosely.\n- [ x ] Include a detailed description of the bug \n\nUsed to be able to have numerical ids in paramterizations.\n3.0.0 crashes verbosely if you do that.\n- [ x ] `pip list` of the virtual environment you are using\n  (venv) $ pip list\n  numpy (1.11.1)\n  pip (8.1.2)\n  py (1.4.31)\n  pymongo (3.3.0)\n  pytest (3.0.0)\n  setuptools (20.10.1)\n  unnecessary-math (0.0.1)\n- [ x ] pytest and operating system versions\n  pytest 3.0.0 (tested against 2.9.2 and works there)\n  os: mac something\n- [ x ] Minimal example if possible\n\n```\nimport pytest\n\ntestdata = [( 1, 2), ( 2, 4)]\n\ndef times_2(x):\n    return x * 2\n\n@pytest.mark.parametrize(\"x,expected\", testdata, ids=('a','b'))\ndef test_ids_strings(x,expected):\n    '''works in both 3.0.0 and 2.9.2'''\n    assert times_2(x) == expected\n\n\n@pytest.mark.parametrize(\"x,expected\", testdata, ids=(1,2))\ndef test_ids_numbers(x,expected):\n    '''works in 2.9.2, crashes verbosely in 3.0.0'''\n    assert times_2(x) == expected\n\n```\n\n2.9.2:\n\n```\n(venv_2.9.2) $ py.test -v test_ids2.py \n================================ test session starts =================================\nplatform darwin -- Python 3.5.2, pytest-2.9.2, py-1.4.31, pluggy-0.3.1 -- /Users/okken/projects/book/bopytest/Book/code/pytest/um_project/tests/venv_2.9.2/bin/python3.5\ncachedir: ../.cache\nrootdir: /Users/okken/projects/book/bopytest/Book/code/pytest/um_project, inifile: \ncollected 4 items \n\ntest_ids2.py::test_ids_strings[a] PASSED\ntest_ids2.py::test_ids_strings[b] PASSED\ntest_ids2.py::test_ids_numbers[1] PASSED\ntest_ids2.py::test_ids_numbers[2] PASSED\n\n============================== 4 passed in 0.02 seconds ==============================\n```\n\n3.0.0:\n\n```\n(venv) $ pytest -v test_ids2.py \n============================= test session starts ==============================\nplatform darwin -- Python 3.5.2, pytest-3.0.0, py-1.4.31, pluggy-0.3.1 -- /Users/okken/projects/book/bopytest/Book/venv/bin/python3.5\ncachedir: ../.cache\nrootdir: /Users/okken/projects/book/bopytest/Book/code/pytest/um_project, inifile: \ncollected 0 items / 1 errors \n\n==================================== ERRORS ====================================\n_____________________ ERROR collecting tests/test_ids2.py ______________________\n../../../../venv/lib/python3.5/site-packages/_pytest/runner.py:163: in __init__\n    self.result = func()\n../../../../venv/lib/python3.5/site-packages/_pytest/main.py:460: in _memocollect\n    return self._memoizedcall('_collected', lambda: list(self.collect()))\n../../../../venv/lib/python3.5/site-packages/_pytest/main.py:331: in _memoizedcall\n    res = function()\n../../../../venv/lib/python3.5/site-packages/_pytest/main.py:460: in <lambda>\n    return self._memoizedcall('_collected', lambda: list(self.collect()))\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:404: in collect\n    return super(Module, self).collect()\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:318: in collect\n    res = self.makeitem(name, obj)\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:330: in makeitem\n    collector=self, name=name, obj=obj)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:724: in __call__\n    return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:338: in _hookexec\n    return self._inner_hookexec(hook, methods, kwargs)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:333: in <lambda>\n    _MultiCall(methods, kwargs, hook.spec_opts).execute()\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:595: in execute\n    return _wrapped_call(hook_impl.function(*args), self.execute)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:249: in _wrapped_call\n    wrap_controller.send(call_outcome)\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:191: in pytest_pycollect_makeitem\n    res = list(collector._genfunctions(name, obj))\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:350: in _genfunctions\n    self.ihook.pytest_generate_tests(metafunc=metafunc)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:724: in __call__\n    return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:338: in _hookexec\n    return self._inner_hookexec(hook, methods, kwargs)\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:333: in <lambda>\n    _MultiCall(methods, kwargs, hook.spec_opts).execute()\n../../../../venv/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py:596: in execute\n    res = hook_impl.function(*args)\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:104: in pytest_generate_tests\n    metafunc.parametrize(*marker.args, **marker.kwargs)\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:846: in parametrize\n    ids = idmaker(argnames, argvalues, idfn, ids, self.config)\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:933: in idmaker\n    for valindex, valset in enumerate(argvalues)]\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:933: in <listcomp>\n    for valindex, valset in enumerate(argvalues)]\n../../../../venv/lib/python3.5/site-packages/_pytest/python.py:929: in _idvalset\n    return _escape_strings(ids[idx])\n../../../../venv/lib/python3.5/site-packages/_pytest/compat.py:144: in _escape_strings\n    return val.encode('unicode_escape').decode('ascii')\nE   AttributeError: 'int' object has no attribute 'encode'\n!!!!!!!!!!!!!!!!!!! Interrupted: 1 errors during collection !!!!!!!!!!!!!!!!!!!!\n=========================== 1 error in 0.64 seconds ============================\n\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  function: Metafunc.parametrize\n  function: Metafunc.parametrize\n"
    },
    {
      "similar_issue": {
        "issue_title": "get_marker doesn't work for parametrized tests using custom markers",
        "issue_body": "When we are using parametrize regarding to [doc](https://docs.pytest.org/en/latest/parametrize.html) and in pytest hook pytest_collection_modifyitems we would like to get marker and it's value we are failing with error:\r\n`ValueError: MarkInfo expects Mark instances, got MarkDecorator(mark=Mark(name='custom_mark', args=('custom mark1',), kwargs={})) (<class '_pytest.mark.structures.MarkDecorator'>)`\r\n\r\n\r\n- \r\n\r\nHow to reproduce:\r\nI attached full [example](https://github.com/pytest-dev/pytest/files/2119572/pytest_marker_issue.tar.gz),, you just need to run_test.sh script.\r\n\r\n- requirement file is part of [attached examle](https://github.com/pytest-dev/pytest/files/2119572/pytest_marker_issue.tar.gz), contains just latest pytest@features branch\r\n- latest - features branch\r\n- Minimal example if possible, attached [pytest_marker_issue.tar.gz](https://github.com/pytest-dev/pytest/files/2119572/pytest_marker_issue.tar.gz)\r\n\r\ntest_file.py:\r\n---------------\r\n```python\r\nimport pytest\r\n\r\nfirst_custom_mark = pytest.mark.custom_marker\r\ncustom_mark = pytest.mark.custom_mark\r\n\r\n@custom_mark(\"custom mark non parametrized\")\r\ndef test_custom_mark_non_parametrized():\r\n    print \"Hey from test\"\r\n\r\n@pytest.mark.parametrize(\r\n    \"obj_type\",\r\n    [\r\n        first_custom_mark(\"first custom mark\")(\"template\"),\r\n        pytest.param( # Think this should be recommended way?\r\n            \"disk\",\r\n            marks=custom_mark('custom mark1')\r\n        ),\r\n        custom_mark(\"custom mark2\")(\"vm\"),  # Tried also this\r\n    ]\r\n)\r\ndef test_custom_mark_parametrized(obj_type):\r\n    print \"obj_type is: %s\" % obj_type\r\n```\r\n\r\nconftest.py\r\n--------------\r\n```python\r\ndef pytest_collection_modifyitems(session, config, items):\r\n    for item in items:\r\n        # here we are failing with:\r\n        # INTERNALERROR> ValueError: MarkInfo expects Mark instances, got\r\n        # MarkDecorator(mark=Mark(name='custom_mark', args=('custom mark1',), kwargs={})) (<class '_pytest.mark.structures.MarkDecorator'>)\r\n        custom_mark = item.get_marker('custom_mark')\r\n        print(\"Custom mark %s\" % custom_mark)\r\n```",
        "issue_id": 3605,
        "pr_number": 3634,
        "pr_title": "Merge from master",
        "pr_body": "",
        "issue_closed_at": "2018-06-27T01:14:31Z",
        "base_commit": "e9371a58a0d1562f9d187778e67a7fae3708261f"
      },
      "summary": "### Summary:\nThis issue is related to the usage of custom markers in parameterized tests within the pytest framework. The problem arises when attempting to retrieve marker information using the `get_marker` function within the `pytest_collection_modifyitems` hook. Specifically, an error occurs indicating a type mismatch, as the system expects `Mark` instances but receives `MarkDecorator` objects instead. This issue affects the test collection process when custom markers are applied to parameterized test inputs.\n\n1. **Problem Description in General Terms:**\n   The problem pertains to the inability to correctly retrieve and utilize custom markers in parameterized tests when modifying test collections in pytest. The issue is triggered during the collection phase when custom markers are involved, leading to a type mismatch error.\n\n2. **Key Symptoms and Behaviors Observed:**\n   - Failure to retrieve custom marker information correctly.\n   - An error message indicating a type mismatch, where `MarkInfo` expects `Mark` instances but receives `MarkDecorator` objects.\n   - The error occurs during the execution of the `pytest_collection_modifyitems` hook.\n\n3. **Affected Components or Systems:**\n   - The pytest framework, specifically the components handling marker retrieval and test collection modification.\n   - The error impacts tests that utilize custom markers in combination with parameterization.\n\n4. **Potential Impact or Severity:**\n   - This issue can disrupt the test collection and execution process for projects leveraging custom markers in parameterized tests.\n   - It may prevent accurate test categorization and filtering based on custom markers, potentially leading to incomplete test runs or misclassification of tests.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   - The issue is rooted in the handling of marker objects within pytest, where a `MarkDecorator` object is provided instead of the expected `Mark` instance.\n   - The error suggests a need for modification in the way pytest processes and retrieves marker information during test collection.\n   - The resolution involves adjustments to the marker processing logic in the underlying pytest codebase, specifically functions related to the handling of markers and parameterized test call specifications.",
      "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: get_marker doesn't work for parametrized tests using custom markers\n\nBody:\nWhen we are using parametrize regarding to [doc](https://docs.pytest.org/en/latest/parametrize.html) and in pytest hook pytest_collection_modifyitems we would like to get marker and it's value we are failing with error:\r\n`ValueError: MarkInfo expects Mark instances, got MarkDecorator(mark=Mark(name='custom_mark', args=('custom mark1',), kwargs={})) (<class '_pytest.mark.structures.MarkDecorator'>)`\r\n\r\n\r\n- \r\n\r\nHow to reproduce:\r\nI attached full [example](https://github.com/pytest-dev/pytest/files/2119572/pytest_marker_issue.tar.gz),, you just need to run_test.sh script.\r\n\r\n- requirement file is part of [attached examle](https://github.com/pytest-dev/pytest/files/2119572/pytest_marker_issue.tar.gz), contains just latest pytest@features branch\r\n- latest - features branch\r\n- Minimal example if possible, attached [pytest_marker_issue.tar.gz](https://github.com/pytest-dev/pytest/files/2119572/pytest_marker_issue.tar.gz)\r\n\r\ntest_file.py:\r\n---------------\r\n```python\r\nimport pytest\r\n\r\nfirst_custom_mark = pytest.mark.custom_marker\r\ncustom_mark = pytest.mark.custom_mark\r\n\r\n@custom_mark(\"custom mark non parametrized\")\r\ndef test_custom_mark_non_parametrized():\r\n    print \"Hey from test\"\r\n\r\n@pytest.mark.parametrize(\r\n    \"obj_type\",\r\n    [\r\n        first_custom_mark(\"first custom mark\")(\"template\"),\r\n        pytest.param( # Think this should be recommended way?\r\n            \"disk\",\r\n            marks=custom_mark('custom mark1')\r\n        ),\r\n        custom_mark(\"custom mark2\")(\"vm\"),  # Tried also this\r\n    ]\r\n)\r\ndef test_custom_mark_parametrized(obj_type):\r\n    print \"obj_type is: %s\" % obj_type\r\n```\r\n\r\nconftest.py\r\n--------------\r\n```python\r\ndef pytest_collection_modifyitems(session, config, items):\r\n    for item in items:\r\n        # here we are failing with:\r\n        # INTERNALERROR> ValueError: MarkInfo expects Mark instances, got\r\n        # MarkDecorator(mark=Mark(name='custom_mark', args=('custom mark1',), kwargs={})) (<class '_pytest.mark.structures.MarkDecorator'>)\r\n        custom_mark = item.get_marker('custom_mark')\r\n        print(\"Custom mark %s\" % custom_mark)\r\n```\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsrc/_pytest/mark/structures.py\n  function: get_unpacked_marks\n\nsrc/_pytest/python.py\n  line: line 39\n  function: CallSpec2.setmulti2\n  function: Function.__init__\n"
    },
    {
      "similar_issue": {
        "issue_title": "_truncate_recursive_traceback()'s recursionindex can be None in 3.1.2",
        "issue_body": "```\r\ntest runtests: commands[0] | coverage run --parallel --source tested_library -m pytest --doctest-glob=*.md --junit-xml=report.xml\r\n============================= test session starts ==============================\r\nplatform linux2 -- Python 2.7.5, pytest-3.1.2, py-1.4.34, pluggy-0.4.0 -- workspace/.tox/test/bin/python2\r\ncachedir: .cache\r\nrootdir: workspace, inifile: tox.ini\r\nplugins: mock-1.6.0, pylama-7.3.3\r\ncollecting ... INTERNALERROR> Traceback (most recent call last):\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 105, in wrap_session\r\nINTERNALERROR>     session.exitstatus = doit(config, session) or 0\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 140, in _main\r\nINTERNALERROR>     config.hook.pytest_collection(session=session)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 745, in __call__\r\nINTERNALERROR>     return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 339, in _hookexec\r\nINTERNALERROR>     return self._inner_hookexec(hook, methods, kwargs)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 334, in <lambda>\r\nINTERNALERROR>     _MultiCall(methods, kwargs, hook.spec_opts).execute()\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 614, in execute\r\nINTERNALERROR>     res = hook_impl.function(*args)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 150, in pytest_collection\r\nINTERNALERROR>     return session.perform_collect()\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 604, in perform_collect\r\nINTERNALERROR>     items = self._perform_collect(args, genitems)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 641, in _perform_collect\r\nINTERNALERROR>     self.items.extend(self.genitems(node))\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 776, in genitems\r\nINTERNALERROR>     rep = collect_one_node(node)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/runner.py\", line 457, in collect_one_node\r\nINTERNALERROR>     rep = ihook.pytest_make_collect_report(collector=collector)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 745, in __call__\r\nINTERNALERROR>     return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 339, in _hookexec\r\nINTERNALERROR>     return self._inner_hookexec(hook, methods, kwargs)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 334, in <lambda>\r\nINTERNALERROR>     _MultiCall(methods, kwargs, hook.spec_opts).execute()\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 613, in execute\r\nINTERNALERROR>     return _wrapped_call(hook_impl.function(*args), self.execute)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 250, in _wrapped_call\r\nINTERNALERROR>     wrap_controller.send(call_outcome)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/capture.py\", line 118, in pytest_make_collect_report\r\nINTERNALERROR>     rep = outcome.get_result()\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 280, in get_result\r\nINTERNALERROR>     _reraise(*ex)  # noqa\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 265, in __init__\r\nINTERNALERROR>     self.result = func()\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 614, in execute\r\nINTERNALERROR>     res = hook_impl.function(*args)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/runner.py\", line 342, in pytest_make_collect_report\r\nINTERNALERROR>     errorinfo = collector.repr_failure(call.excinfo)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 480, in repr_failure\r\nINTERNALERROR>     return self._repr_failure_py(excinfo, style=\"short\")\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 457, in _repr_failure_py\r\nINTERNALERROR>     style=style, tbfilter=tbfilter)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/_code/code.py\", line 429, in getrepr\r\nINTERNALERROR>     return fmt.repr_excinfo(self)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/_code/code.py\", line 650, in repr_excinfo\r\nINTERNALERROR>     reprtraceback = self.repr_traceback(excinfo)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/_code/code.py\", line 607, in repr_traceback\r\nINTERNALERROR>     traceback, extraline = self._truncate_recursive_traceback(traceback)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/_code/code.py\", line 644, in _truncate_recursive_traceback\r\nINTERNALERROR>     traceback = traceback[:recursionindex + 1]\r\nINTERNALERROR> TypeError: unsupported operand type(s) for +: 'NoneType' and 'int'\r\n```\r\n",
        "issue_id": 2486,
        "pr_number": 2487,
        "pr_title": "Fix internal error when trying to detect the start of a recursive traceback",
        "pr_body": "Fix #2486\r\n",
        "issue_closed_at": "2017-06-22T11:40:33Z",
        "base_commit": "b2d7c26d80aedb8533430d2e70c3d472614c7c0c"
      },
      "summary": "### Summary:\n\nThis issue is related to an internal error encountered during the execution of tests using the pytest framework, specifically version 3.1.2, in a Python 2.7.5 environment. The error occurs when the `_truncate_recursive_traceback` function within the `FormattedExcinfo` class in the `_pytest/_code/code.py` file attempts to perform an arithmetic operation with a `NoneType` object. \n\n1. **Problem Description in General Terms**: The problem arises due to a function within the pytest framework attempting to process a traceback object with a `recursionindex` that can be `None`. This results in a `TypeError` when an arithmetic operation involving this `NoneType` is attempted.\n\n2. **Key Symptoms and Behaviors Observed**: The main symptom of this issue is an `INTERNALERROR` traceback seen in the test logs. The error message \"unsupported operand type(s) for +: 'NoneType' and 'int'\" indicates that the code tried to add an integer to a `None` value, which is not permitted.\n\n3. **Affected Components or Systems**: The affected component is the pytest testing framework, particularly the traceback processing functionality within the `_pytest/_code/code.py` module. This is triggered during the test collection phase, as seen in the stack trace.\n\n4. **Potential Impact or Severity**: The impact of this issue is significant for users relying on pytest for automated testing as it causes a halt in the testing process, preventing the execution of tests and the collection of results. This can affect development and deployment pipelines that depend on successful test runs.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The root cause of the issue is the lack of handling for a possible `None` value in the `recursionindex` variable within the `_truncate_recursive_traceback` function. Correct handling of this case is necessary to ensure that the function can operate correctly even when the `recursionindex` is not defined (i.e., is `None`).",
      "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: _truncate_recursive_traceback()'s recursionindex can be None in 3.1.2\n\nBody:\n```\r\ntest runtests: commands[0] | coverage run --parallel --source tested_library -m pytest --doctest-glob=*.md --junit-xml=report.xml\r\n============================= test session starts ==============================\r\nplatform linux2 -- Python 2.7.5, pytest-3.1.2, py-1.4.34, pluggy-0.4.0 -- workspace/.tox/test/bin/python2\r\ncachedir: .cache\r\nrootdir: workspace, inifile: tox.ini\r\nplugins: mock-1.6.0, pylama-7.3.3\r\ncollecting ... INTERNALERROR> Traceback (most recent call last):\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 105, in wrap_session\r\nINTERNALERROR>     session.exitstatus = doit(config, session) or 0\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 140, in _main\r\nINTERNALERROR>     config.hook.pytest_collection(session=session)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 745, in __call__\r\nINTERNALERROR>     return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 339, in _hookexec\r\nINTERNALERROR>     return self._inner_hookexec(hook, methods, kwargs)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 334, in <lambda>\r\nINTERNALERROR>     _MultiCall(methods, kwargs, hook.spec_opts).execute()\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 614, in execute\r\nINTERNALERROR>     res = hook_impl.function(*args)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 150, in pytest_collection\r\nINTERNALERROR>     return session.perform_collect()\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 604, in perform_collect\r\nINTERNALERROR>     items = self._perform_collect(args, genitems)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 641, in _perform_collect\r\nINTERNALERROR>     self.items.extend(self.genitems(node))\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 776, in genitems\r\nINTERNALERROR>     rep = collect_one_node(node)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/runner.py\", line 457, in collect_one_node\r\nINTERNALERROR>     rep = ihook.pytest_make_collect_report(collector=collector)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 745, in __call__\r\nINTERNALERROR>     return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 339, in _hookexec\r\nINTERNALERROR>     return self._inner_hookexec(hook, methods, kwargs)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 334, in <lambda>\r\nINTERNALERROR>     _MultiCall(methods, kwargs, hook.spec_opts).execute()\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 613, in execute\r\nINTERNALERROR>     return _wrapped_call(hook_impl.function(*args), self.execute)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 250, in _wrapped_call\r\nINTERNALERROR>     wrap_controller.send(call_outcome)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/capture.py\", line 118, in pytest_make_collect_report\r\nINTERNALERROR>     rep = outcome.get_result()\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 280, in get_result\r\nINTERNALERROR>     _reraise(*ex)  # noqa\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 265, in __init__\r\nINTERNALERROR>     self.result = func()\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/vendored_packages/pluggy.py\", line 614, in execute\r\nINTERNALERROR>     res = hook_impl.function(*args)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/runner.py\", line 342, in pytest_make_collect_report\r\nINTERNALERROR>     errorinfo = collector.repr_failure(call.excinfo)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 480, in repr_failure\r\nINTERNALERROR>     return self._repr_failure_py(excinfo, style=\"short\")\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/main.py\", line 457, in _repr_failure_py\r\nINTERNALERROR>     style=style, tbfilter=tbfilter)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/_code/code.py\", line 429, in getrepr\r\nINTERNALERROR>     return fmt.repr_excinfo(self)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/_code/code.py\", line 650, in repr_excinfo\r\nINTERNALERROR>     reprtraceback = self.repr_traceback(excinfo)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/_code/code.py\", line 607, in repr_traceback\r\nINTERNALERROR>     traceback, extraline = self._truncate_recursive_traceback(traceback)\r\nINTERNALERROR>   File \"workspace/test/lib/python2.7/site-packages/_pytest/_code/code.py\", line 644, in _truncate_recursive_traceback\r\nINTERNALERROR>     traceback = traceback[:recursionindex + 1]\r\nINTERNALERROR> TypeError: unsupported operand type(s) for +: 'NoneType' and 'int'\r\n```\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._truncate_recursive_traceback\n"
    }
  ]
}