{
  "original_problem": {
    "instance_id": "pytest-dev__pytest-5227",
    "repo": "pytest-dev/pytest",
    "created_at": "2019-05-07T20:27:24Z",
    "problem_statement": "Improve default logging format\nCurrently it is:\r\n\r\n> DEFAULT_LOG_FORMAT = \"%(filename)-25s %(lineno)4d %(levelname)-8s %(message)s\"\r\n\r\nI think `name` (module name) would be very useful here, instead of just the base filename.\r\n\r\n(It might also be good to have the relative path there (maybe at the end), but it is usually still very long (but e.g. `$VIRTUAL_ENV` could be substituted therein))\r\n\r\nCurrently it would look like this:\r\n```\r\nutils.py                   114 DEBUG    (0.000) SELECT \"app_url\".\"id\", \"app_url\".\"created\", \"app_url\".\"url\" FROM \"app_url\" WHERE \"app_url\".\"id\" = 2; args=(2,)\r\nmultipart.py               604 DEBUG    Calling on_field_start with no data\r\n```\r\n\r\n\r\nUsing `DEFAULT_LOG_FORMAT = \"%(levelname)-8s %(name)s:%(filename)s:%(lineno)d %(message)s\"` instead:\r\n\r\n```\r\nDEBUG    django.db.backends:utils.py:114 (0.000) SELECT \"app_url\".\"id\", \"app_url\".\"created\", \"app_url\".\"url\" FROM \"app_url\" WHERE \"app_url\".\"id\" = 2; args=(2,)\r\nDEBUG    multipart.multipart:multipart.py:604 Calling on_field_start with no data\r\n```\n",
    "patch": "diff --git a/src/_pytest/logging.py b/src/_pytest/logging.py\n--- a/src/_pytest/logging.py\n+++ b/src/_pytest/logging.py\n@@ -15,7 +15,7 @@\n from _pytest.config import create_terminal_writer\n from _pytest.pathlib import Path\n \n-DEFAULT_LOG_FORMAT = \"%(filename)-25s %(lineno)4d %(levelname)-8s %(message)s\"\n+DEFAULT_LOG_FORMAT = \"%(levelname)-8s %(name)s:%(filename)s:%(lineno)d %(message)s\"\n DEFAULT_LOG_DATE_FORMAT = \"%H:%M:%S\"\n \n \n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_3888",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is about a regression in doctests on macOS, unrelated to logging format changes."
      },
      {
        "idx": 2,
        "id": "similar_1010",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue involves environment variable handling on Windows, not applicable to logging format improvements."
      },
      {
        "idx": 3,
        "id": "similar_2895",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is about a hook not executing in a specific mode, unrelated to logging format changes."
      },
      {
        "idx": 4,
        "id": "similar_2105",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue involves configuration option handling, not related to logging format improvements."
      },
      {
        "idx": 5,
        "id": "similar_736",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is about naming conflicts in parametrized tests, unrelated to logging format changes."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "doctests regression with v3.7.3 on OS-X",
        "issue_body": "- [x] Include a detailed description of the bug or suggestion\r\n\r\nAfter upgrading to v3.7.3, all doctests started failing with the exception:\r\n\r\n```\r\n<my-pyenv>/lib/python3.7/site-packages/_pytest/doctest.py:206: TypeError: cannot unpack non-iterable NoneType object\r\n```\r\n\r\nEverything is OK with v3.7.2.\r\n\r\nSlightly longer traceback (For the record, looking into the stacktrace, I see some references to \"darwin\"-specific functions):\r\n\r\n```\r\n___________________________________________________________________ [doctest] xxx ___________________________________________________________________\r\n\r\nself = <CallInfo when='call' exception: cannot unpack non-iterable NoneType object>, func = <function call_runtest_hook.<locals>.<lambda> at 0x1112f49d8>, when = 'call'\r\ntreat_keyboard_interrupt_as_exception = False\r\n\r\n    def __init__(self, func, when, treat_keyboard_interrupt_as_exception=False):\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<my-pyenv>/lib/python3.7/site-packages/_pytest/runner.py:201:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\n>   lambda: ihook(item=item, **kwds),\r\n    when=when,\r\n    treat_keyboard_interrupt_as_exception=item.config.getvalue(\"usepdb\"),\r\n        )\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/_pytest/runner.py:183:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nself = <_HookCaller 'pytest_runtest_call'>, args = (), kwargs = {'item': <DoctestItem 'somemodule.somefunction'>}, notincall = set()\r\n\r\n    def __call__(self, *args, **kwargs):\r\n        if args:\r\n            raise TypeError(\"hook calling supports only keyword arguments\")\r\n        assert not self.is_historic()\r\n        if self.argnames:\r\n            notincall = set(self.argnames) - set(['__multicall__']) - set(\r\n                kwargs.keys())\r\n            if notincall:\r\n                warnings.warn(\r\n                    \"Argument(s) {} which are declared in the hookspec \"\r\n                    \"can not be found in this hook call\"\r\n                    .format(tuple(notincall)),\r\n                    stacklevel=2,\r\n                )\r\n>       return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/pluggy/hooks.py:258:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nself = <_pytest.config.PytestPluginManager object at 0x1034317b8>, hook = <_HookCaller 'pytest_runtest_call'>\r\nmethods = [<HookImpl plugin_name='runner', plugin=<module '_pytest.runner' from '<my-pyenv......t 0x103d4f4e0>>, <HookImpl plugin_name='logging-plugin', plugin=<_pytest.logging.LoggingPlugin object at 0x10e8f9860>>]\r\nkwargs = {'item': <DoctestItem 'somemodule.somefunction'>}\r\n\r\n    def _hookexec(self, hook, methods, kwargs):\r\n        # called from all hookcaller instances.\r\n        # enable_tracing will set its own wrapping function at self._inner_hookexec\r\n>       return self._inner_hookexec(hook, methods, kwargs)\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/pluggy/manager.py:67:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nhook = <_HookCaller 'pytest_runtest_call'>\r\nmethods = [<HookImpl plugin_name='runner', plugin=<module '_pytest.runner' from '<my-pyenv......t 0x103d4f4e0>>, <HookImpl plugin_name='logging-plugin', plugin=<_pytest.logging.LoggingPlugin object at 0x10e8f9860>>]\r\nkwargs = {'item': <DoctestItem 'somemodule.somefunction'>}\r\n\r\n    self._inner_hookexec = lambda hook, methods, kwargs: \\\r\n        hook.multicall(\r\n            methods, kwargs,\r\n>           firstresult=hook.spec_opts.get('firstresult'),\r\n        )\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/pluggy/manager.py:61:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nhook_impls = [<HookImpl plugin_name='runner', plugin=<module '_pytest.runner' from '<my-pyenv......t 0x103d4f4e0>>, <HookImpl plugin_name='logging-plugin', plugin=<_pytest.logging.LoggingPlugin object at 0x10e8f9860>>]\r\ncaller_kwargs = {'item': <DoctestItem 'somemodule.somefunction'>}, firstresult = False\r\n\r\n    def _multicall(hook_impls, caller_kwargs, firstresult=False):\r\n        \"\"\"Execute a call into multiple python functions/methods and return the\r\n        result(s).\r\n\r\n        ``caller_kwargs`` comes from _HookCaller.__call__().\r\n        \"\"\"\r\n        __tracebackhide__ = True\r\n        results = []\r\n        excinfo = None\r\n        try:  # run impl and wrapper setup functions in a loop\r\n            teardowns = []\r\n            try:\r\n                for hook_impl in reversed(hook_impls):\r\n                    try:\r\n                        args = [caller_kwargs[argname] for argname in hook_impl.argnames]\r\n                    except KeyError:\r\n                        for argname in hook_impl.argnames:\r\n                            if argname not in caller_kwargs:\r\n                                raise HookCallError(\r\n                                    \"hook call must provide argument %r\" % (argname,))\r\n\r\n                    if hook_impl.hookwrapper:\r\n                        try:\r\n                            gen = hook_impl.function(*args)\r\n                            next(gen)   # first yield\r\n                            teardowns.append(gen)\r\n                        except StopIteration:\r\n                            _raise_wrapfail(gen, \"did not yield\")\r\n                    else:\r\n                        res = hook_impl.function(*args)\r\n                        if res is not None:\r\n                            results.append(res)\r\n                            if firstresult:  # halt further impl calls\r\n                                break\r\n            except BaseException:\r\n                excinfo = sys.exc_info()\r\n        finally:\r\n            if firstresult:  # first result hooks return a single value\r\n                outcome = _Result(results[0] if results else None, excinfo)\r\n            else:\r\n                outcome = _Result(results, excinfo)\r\n\r\n            # run all wrapper post-yield blocks\r\n            for gen in reversed(teardowns):\r\n                try:\r\n                    gen.send(outcome)\r\n                    _raise_wrapfail(gen, \"has second yield\")\r\n                except StopIteration:\r\n                    pass\r\n\r\n>           return outcome.get_result()\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/pluggy/callers.py:201:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nself = <pluggy.callers._Result object at 0x11116efd0>\r\n\r\n    def get_result(self):\r\n        \"\"\"Get the result(s) for this hook call.\r\n\r\n            If the hook was marked as a ``firstresult`` only a single value\r\n            will be returned otherwise a list of results.\r\n            \"\"\"\r\n        __tracebackhide__ = True\r\n        if self._excinfo is None:\r\n            return self._result\r\n        else:\r\n            ex = self._excinfo\r\n            if _py3:\r\n>               raise ex[1].with_traceback(ex[2])\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/pluggy/callers.py:76:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nhook_impls = [<HookImpl plugin_name='runner', plugin=<module '_pytest.runner' from '<my-pyenv......t 0x103d4f4e0>>, <HookImpl plugin_name='logging-plugin', plugin=<_pytest.logging.LoggingPlugin object at 0x10e8f9860>>]\r\ncaller_kwargs = {'item': <DoctestItem 'somemodule.somefunction'>}, firstresult = False\r\n\r\n    def _multicall(hook_impls, caller_kwargs, firstresult=False):\r\n        \"\"\"Execute a call into multiple python functions/methods and return the\r\n        result(s).\r\n\r\n        ``caller_kwargs`` comes from _HookCaller.__call__().\r\n        \"\"\"\r\n        __tracebackhide__ = True\r\n        results = []\r\n        excinfo = None\r\n        try:  # run impl and wrapper setup functions in a loop\r\n            teardowns = []\r\n            try:\r\n                for hook_impl in reversed(hook_impls):\r\n                    try:\r\n                        args = [caller_kwargs[argname] for argname in hook_impl.argnames]\r\n                    except KeyError:\r\n                        for argname in hook_impl.argnames:\r\n                            if argname not in caller_kwargs:\r\n                                raise HookCallError(\r\n                                    \"hook call must provide argument %r\" % (argname,))\r\n\r\n                    if hook_impl.hookwrapper:\r\n                        try:\r\n                            gen = hook_impl.function(*args)\r\n                            next(gen)   # first yield\r\n                            teardowns.append(gen)\r\n                        except StopIteration:\r\n                            _raise_wrapfail(gen, \"did not yield\")\r\n                    else:\r\n>                       res = hook_impl.function(*args)\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/pluggy/callers.py:180:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nitem = <DoctestItem 'somemodule.somefunction'>\r\n\r\n    def pytest_runtest_call(item):\r\n        _update_current_test_var(item, \"call\")\r\n        sys.last_type, sys.last_value, sys.last_traceback = (None, None, None)\r\n        try:\r\n>           item.runtest()\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/_pytest/runner.py:111:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nself = <DoctestItem 'somemodule.somefunction'>\r\n\r\n    def runtest(self):\r\n        _check_all_skipped(self.dtest)\r\n>       self._disable_output_capturing_for_darwin()\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/_pytest/doctest.py:192:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nself = <DoctestItem 'somemodule.somefunction'>\r\n\r\n    def _disable_output_capturing_for_darwin(self):\r\n        \"\"\"\r\n            Disable output capturing. Otherwise, stdout is lost to doctest (#985)\r\n            \"\"\"\r\n        if platform.system() != \"Darwin\":\r\n            return\r\n        capman = self.config.pluginmanager.getplugin(\"capturemanager\")\r\n        if capman:\r\n>           out, err = capman.suspend_global_capture(in_=True)\r\nE           TypeError: cannot unpack non-iterable NoneType object\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/_pytest/doctest.py:206: TypeError\r\n```\r\n\r\n- [x] `pip list` of the virtual environment you are using\r\n\r\n```\r\n...\r\nmypy                     0.620\r\npytest                   3.7.3\r\npytest-cov               2.5.1\r\npytest-django            3.4.2\r\ntox                      3.2.1\r\n...\r\n```\r\n\r\n- [x] pytest and operating system versions\r\n\r\n`pytest v3.7.3` and \r\n\r\n```\r\n$ sw_vers\r\nProductName:\tMac OS X\r\nProductVersion:\t10.13.6\r\nBuildVersion:\t17G65\r\n```\r\n\r\n- [ ] Minimal example if possible\r\n",
        "issue_id": 3888,
        "pr_number": 3893,
        "pr_title": "travis: run tests on macOS",
        "pr_body": "Closes #3892 \r\nCloses #3888\r\n\r\nThanks for submitting a PR, your contribution is really appreciated!\r\n\r\nHere's a quick checklist that should be present in PRs (you can delete this text from the final description, this is\r\njust a guideline):\r\n\r\n- [ ] Create a new changelog file in the `changelog` folder, with a name like `<ISSUE NUMBER>.<TYPE>.rst`. See [changelog/README.rst](/changelog/README.rst) for details.\r\n- [x] Target the `master` branch for bug fixes, documentation updates and trivial changes.\r\n- [ ] Target the `features` branch for new features and removals/deprecations.\r\n- [ ] Include documentation when adding new features.\r\n- [ ] Include new tests or update existing tests when applicable.\r\n\r\nUnless your change is trivial or a small documentation fix (e.g.,  a typo or reword of a small section) please:\r\n\r\n- [ ] ~Add yourself to `AUTHORS` in alphabetical order;~ trivial change - no code\r\n",
        "issue_closed_at": "2018-08-28T20:06:18Z",
        "base_commit": "2a059b1c1bff392252c02413c89913dd672af168"
      },
      "summary": "### Summary:\n\nThis issue is a software regression identified after upgrading to version 3.7.3 of a testing framework, specifically affecting doctests on the macOS platform. The problem manifests as a failure in all doctests due to a `TypeError` that occurs when attempting to unpack a non-iterable `NoneType` object. This error is traced back to a function within the `_pytest` module, which is related to the disabling of output capturing specifically for the Darwin (macOS) operating system. \n\nKey symptoms include the consistent failure of doctests with a specific error traceback indicating issues in the `_pytest/doctest.py` file. The affected components are the doctest functionality within the pytest framework, particularly on macOS (Darwin). The impact is significant for users relying on doctests for validation, as the errors prevent successful testing operations. \n\nThe technical root of the problem is linked to the handling of output capture on macOS within the pytest's doctest module, which fails due to incorrect assumptions about the return value of a function responsible for managing output capture. The regression is specific to version 3.7.3 of pytest, as the previous version 3.7.2 did not exhibit the same issue.",
      "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: doctests regression with v3.7.3 on OS-X\n\nBody:\n- [x] Include a detailed description of the bug or suggestion\r\n\r\nAfter upgrading to v3.7.3, all doctests started failing with the exception:\r\n\r\n```\r\n<my-pyenv>/lib/python3.7/site-packages/_pytest/doctest.py:206: TypeError: cannot unpack non-iterable NoneType object\r\n```\r\n\r\nEverything is OK with v3.7.2.\r\n\r\nSlightly longer traceback (For the record, looking into the stacktrace, I see some references to \"darwin\"-specific functions):\r\n\r\n```\r\n___________________________________________________________________ [doctest] xxx ___________________________________________________________________\r\n\r\nself = <CallInfo when='call' exception: cannot unpack non-iterable NoneType object>, func = <function call_runtest_hook.<locals>.<lambda> at 0x1112f49d8>, when = 'call'\r\ntreat_keyboard_interrupt_as_exception = False\r\n\r\n    def __init__(self, func, when, treat_keyboard_interrupt_as_exception=False):\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<my-pyenv>/lib/python3.7/site-packages/_pytest/runner.py:201:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\n>   lambda: ihook(item=item, **kwds),\r\n    when=when,\r\n    treat_keyboard_interrupt_as_exception=item.config.getvalue(\"usepdb\"),\r\n        )\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/_pytest/runner.py:183:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nself = <_HookCaller 'pytest_runtest_call'>, args = (), kwargs = {'item': <DoctestItem 'somemodule.somefunction'>}, notincall = set()\r\n\r\n    def __call__(self, *args, **kwargs):\r\n        if args:\r\n            raise TypeError(\"hook calling supports only keyword arguments\")\r\n        assert not self.is_historic()\r\n        if self.argnames:\r\n            notincall = set(self.argnames) - set(['__multicall__']) - set(\r\n                kwargs.keys())\r\n            if notincall:\r\n                warnings.warn(\r\n                    \"Argument(s) {} which are declared in the hookspec \"\r\n                    \"can not be found in this hook call\"\r\n                    .format(tuple(notincall)),\r\n                    stacklevel=2,\r\n                )\r\n>       return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/pluggy/hooks.py:258:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nself = <_pytest.config.PytestPluginManager object at 0x1034317b8>, hook = <_HookCaller 'pytest_runtest_call'>\r\nmethods = [<HookImpl plugin_name='runner', plugin=<module '_pytest.runner' from '<my-pyenv......t 0x103d4f4e0>>, <HookImpl plugin_name='logging-plugin', plugin=<_pytest.logging.LoggingPlugin object at 0x10e8f9860>>]\r\nkwargs = {'item': <DoctestItem 'somemodule.somefunction'>}\r\n\r\n    def _hookexec(self, hook, methods, kwargs):\r\n        # called from all hookcaller instances.\r\n        # enable_tracing will set its own wrapping function at self._inner_hookexec\r\n>       return self._inner_hookexec(hook, methods, kwargs)\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/pluggy/manager.py:67:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nhook = <_HookCaller 'pytest_runtest_call'>\r\nmethods = [<HookImpl plugin_name='runner', plugin=<module '_pytest.runner' from '<my-pyenv......t 0x103d4f4e0>>, <HookImpl plugin_name='logging-plugin', plugin=<_pytest.logging.LoggingPlugin object at 0x10e8f9860>>]\r\nkwargs = {'item': <DoctestItem 'somemodule.somefunction'>}\r\n\r\n    self._inner_hookexec = lambda hook, methods, kwargs: \\\r\n        hook.multicall(\r\n            methods, kwargs,\r\n>           firstresult=hook.spec_opts.get('firstresult'),\r\n        )\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/pluggy/manager.py:61:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nhook_impls = [<HookImpl plugin_name='runner', plugin=<module '_pytest.runner' from '<my-pyenv......t 0x103d4f4e0>>, <HookImpl plugin_name='logging-plugin', plugin=<_pytest.logging.LoggingPlugin object at 0x10e8f9860>>]\r\ncaller_kwargs = {'item': <DoctestItem 'somemodule.somefunction'>}, firstresult = False\r\n\r\n    def _multicall(hook_impls, caller_kwargs, firstresult=False):\r\n        \"\"\"Execute a call into multiple python functions/methods and return the\r\n        result(s).\r\n\r\n        ``caller_kwargs`` comes from _HookCaller.__call__().\r\n        \"\"\"\r\n        __tracebackhide__ = True\r\n        results = []\r\n        excinfo = None\r\n        try:  # run impl and wrapper setup functions in a loop\r\n            teardowns = []\r\n            try:\r\n                for hook_impl in reversed(hook_impls):\r\n                    try:\r\n                        args = [caller_kwargs[argname] for argname in hook_impl.argnames]\r\n                    except KeyError:\r\n                        for argname in hook_impl.argnames:\r\n                            if argname not in caller_kwargs:\r\n                                raise HookCallError(\r\n                                    \"hook call must provide argument %r\" % (argname,))\r\n\r\n                    if hook_impl.hookwrapper:\r\n                        try:\r\n                            gen = hook_impl.function(*args)\r\n                            next(gen)   # first yield\r\n                            teardowns.append(gen)\r\n                        except StopIteration:\r\n                            _raise_wrapfail(gen, \"did not yield\")\r\n                    else:\r\n                        res = hook_impl.function(*args)\r\n                        if res is not None:\r\n                            results.append(res)\r\n                            if firstresult:  # halt further impl calls\r\n                                break\r\n            except BaseException:\r\n                excinfo = sys.exc_info()\r\n        finally:\r\n            if firstresult:  # first result hooks return a single value\r\n                outcome = _Result(results[0] if results else None, excinfo)\r\n            else:\r\n                outcome = _Result(results, excinfo)\r\n\r\n            # run all wrapper post-yield blocks\r\n            for gen in reversed(teardowns):\r\n                try:\r\n                    gen.send(outcome)\r\n                    _raise_wrapfail(gen, \"has second yield\")\r\n                except StopIteration:\r\n                    pass\r\n\r\n>           return outcome.get_result()\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/pluggy/callers.py:201:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nself = <pluggy.callers._Result object at 0x11116efd0>\r\n\r\n    def get_result(self):\r\n        \"\"\"Get the result(s) for this hook call.\r\n\r\n            If the hook was marked as a ``firstresult`` only a single value\r\n            will be returned otherwise a list of results.\r\n            \"\"\"\r\n        __tracebackhide__ = True\r\n        if self._excinfo is None:\r\n            return self._result\r\n        else:\r\n            ex = self._excinfo\r\n            if _py3:\r\n>               raise ex[1].with_traceback(ex[2])\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/pluggy/callers.py:76:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nhook_impls = [<HookImpl plugin_name='runner', plugin=<module '_pytest.runner' from '<my-pyenv......t 0x103d4f4e0>>, <HookImpl plugin_name='logging-plugin', plugin=<_pytest.logging.LoggingPlugin object at 0x10e8f9860>>]\r\ncaller_kwargs = {'item': <DoctestItem 'somemodule.somefunction'>}, firstresult = False\r\n\r\n    def _multicall(hook_impls, caller_kwargs, firstresult=False):\r\n        \"\"\"Execute a call into multiple python functions/methods and return the\r\n        result(s).\r\n\r\n        ``caller_kwargs`` comes from _HookCaller.__call__().\r\n        \"\"\"\r\n        __tracebackhide__ = True\r\n        results = []\r\n        excinfo = None\r\n        try:  # run impl and wrapper setup functions in a loop\r\n            teardowns = []\r\n            try:\r\n                for hook_impl in reversed(hook_impls):\r\n                    try:\r\n                        args = [caller_kwargs[argname] for argname in hook_impl.argnames]\r\n                    except KeyError:\r\n                        for argname in hook_impl.argnames:\r\n                            if argname not in caller_kwargs:\r\n                                raise HookCallError(\r\n                                    \"hook call must provide argument %r\" % (argname,))\r\n\r\n                    if hook_impl.hookwrapper:\r\n                        try:\r\n                            gen = hook_impl.function(*args)\r\n                            next(gen)   # first yield\r\n                            teardowns.append(gen)\r\n                        except StopIteration:\r\n                            _raise_wrapfail(gen, \"did not yield\")\r\n                    else:\r\n>                       res = hook_impl.function(*args)\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/pluggy/callers.py:180:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nitem = <DoctestItem 'somemodule.somefunction'>\r\n\r\n    def pytest_runtest_call(item):\r\n        _update_current_test_var(item, \"call\")\r\n        sys.last_type, sys.last_value, sys.last_traceback = (None, None, None)\r\n        try:\r\n>           item.runtest()\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/_pytest/runner.py:111:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nself = <DoctestItem 'somemodule.somefunction'>\r\n\r\n    def runtest(self):\r\n        _check_all_skipped(self.dtest)\r\n>       self._disable_output_capturing_for_darwin()\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/_pytest/doctest.py:192:\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\r\n\r\nself = <DoctestItem 'somemodule.somefunction'>\r\n\r\n    def _disable_output_capturing_for_darwin(self):\r\n        \"\"\"\r\n            Disable output capturing. Otherwise, stdout is lost to doctest (#985)\r\n            \"\"\"\r\n        if platform.system() != \"Darwin\":\r\n            return\r\n        capman = self.config.pluginmanager.getplugin(\"capturemanager\")\r\n        if capman:\r\n>           out, err = capman.suspend_global_capture(in_=True)\r\nE           TypeError: cannot unpack non-iterable NoneType object\r\n\r\n<my-pyenv>/lib/python3.7/site-packages/_pytest/doctest.py:206: TypeError\r\n```\r\n\r\n- [x] `pip list` of the virtual environment you are using\r\n\r\n```\r\n...\r\nmypy                     0.620\r\npytest                   3.7.3\r\npytest-cov               2.5.1\r\npytest-django            3.4.2\r\ntox                      3.2.1\r\n...\r\n```\r\n\r\n- [x] pytest and operating system versions\r\n\r\n`pytest v3.7.3` and \r\n\r\n```\r\n$ sw_vers\r\nProductName:\tMac OS X\r\nProductVersion:\t10.13.6\r\nBuildVersion:\t17G65\r\n```\r\n\r\n- [ ] Minimal example if possible\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/doctest.py\n  function: DoctestItem._disable_output_capturing_for_darwin\n"
    },
    {
      "similar_issue": {
        "issue_title": "[2.7.3] tmpdir doesn't work on Windows under tox",
        "issue_body": "py.test 2.7.3 changed it so that `tmpdir` ends up in a folder named `pytest-{user}` (https://github.com/pytest-dev/pytest/compare/2.7.2...2.7.3#diff-88a6976d3a46c4b9625271f78ccde817L46)\n\nOn Windows the only way to get the username is the environment variable `USERNAME`, whereas on UNIX there is the `pwd` module. By default, `tox` does not allow environment variables to passthrough.\n\nThe result is that if you use py.test under tox on Windows with `tmpdir`, you get a traceback: https://jenkins.cryptography.io/job/cryptography-master/TOXENV=py26,label=windows/1289/console\n",
        "issue_id": 1010,
        "pr_number": 1013,
        "pr_title": "Make tmpdir more resilient in case environment variables required by getpass are missing",
        "pr_body": "Fix #1010\n",
        "issue_closed_at": "2015-09-16T19:57:44Z",
        "base_commit": "2093889ac2f346c232ca86540a9802de58cb6f5b"
      },
      "summary": "### Summary:\n\nThis issue pertains to a compatibility problem between the py.test framework's version 2.7.3 and the tox testing environment on Windows operating systems. Specifically, the problem arises from a change in py.test 2.7.3, where the `tmpdir` functionality now places temporary directories in a path that includes the username, formatted as `pytest-{user}`. On UNIX systems, the `pwd` module is typically used to retrieve the username, while on Windows, the username is obtained from the `USERNAME` environment variable.\n\nKey symptoms include a traceback error when running py.test with `tmpdir` under tox on Windows, due to tox's default behavior of not allowing environment variables to be passed through. This issue directly affects the test execution process in Windows environments using the tox framework, potentially disrupting continuous integration pipelines or local testing processes.\n\nThe affected components include the py.test framework, tox, and the Windows operating system environment where these tests are executed. The severity of the issue can be considered moderate, as it specifically impacts the functionality of automated tests on Windows, which are critical for validating software changes.\n\nRelevant technical details include the reliance on environment variables to obtain user-specific paths on Windows and the default configuration of tox that restricts environment variable access. The resolution involved modifications in the `TempdirFactory.getbasetemp` function within the `py.test` library to restore compatibility and ensure correct temporary directory creation without causing errors.",
      "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: [2.7.3] tmpdir doesn't work on Windows under tox\n\nBody:\npy.test 2.7.3 changed it so that `tmpdir` ends up in a folder named `pytest-{user}` (https://github.com/pytest-dev/pytest/compare/2.7.2...2.7.3#diff-88a6976d3a46c4b9625271f78ccde817L46)\n\nOn Windows the only way to get the username is the environment variable `USERNAME`, whereas on UNIX there is the `pwd` module. By default, `tox` does not allow environment variables to passthrough.\n\nThe result is that if you use py.test under tox on Windows with `tmpdir`, you get a traceback: https://jenkins.cryptography.io/job/cryptography-master/TOXENV=py26,label=windows/1289/console\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/tmpdir.py\n  function: TempdirFactory.getbasetemp\n  function: TempdirFactory.getbasetemp\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 pytest testing framework, specifically concerning the behavior of the `pytest_report_collectionfinish` hook when used in conjunction with the `--collect-only` option. The problem arises because the `pytest_report_collectionfinish` hook, which is intended to execute after the test collection phase, does not trigger when the `--collect-only` option is specified. This option is typically used to list tests without actually executing them.\n\n1. **Problem Description in General Terms:**\n   The issue involves a hook in the pytest framework that fails to execute during a specific operation mode. When users attempt to collect tests without running them, a particular hook that should provide feedback or perform actions at the end of the collection does not function as expected.\n\n2. **Key Symptoms and Behaviors Observed:**\n   Users observe that the `pytest_report_collectionfinish` hook does not execute when they use the `--collect-only` mode. This mode is intended for scenarios where test cases are gathered and listed but not executed, leading to an expectation that all related hooks, including those that conclude the collection, should still operate.\n\n3. **Affected Components or Systems:**\n   The components affected include various modules within pytest, such as configuration, logging, main execution flow, Python-specific functionalities, terminal reporting, and unittest integration. These components are responsible for managing test collection, logging, and session handling.\n\n4. **Potential Impact or Severity:**\n   The impact of this issue is moderate, primarily affecting users who rely on hooks to perform tasks or generate reports following the collection phase when using the `--collect-only` option. It can disrupt workflows that depend on the completion of collection tasks and the subsequent reporting.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   The problem required changes in multiple parts of the pytest codebase, reflecting the interdependent nature of the testing framework's components. Key areas addressed include the configuration of plugins, logging mechanisms, session handling, test collection and filtering, Python-specific test handling, API interactions, and terminal output. The changes ensure that the `pytest_report_collectionfinish` hook now executes as expected, even when tests are only collected and not run.",
      "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": "KeyError: 'testpaths' exception raised when using --override-ini command line option",
        "issue_body": "## Summary of the issue\r\n\r\nWhen I use `--override-ini` feature while specifying particular test to run, `py.test` crashes with `KeyError: 'testpaths'` exception.\r\n\r\n## Description of a reproducer\r\n\r\nCreate minimal test case in `~/tmp` directory so that:\r\n\r\n```\r\n$ cd ~/tmp\r\n$ ls\r\ntest_foo.py\r\n$ cat test_foo.py\r\ndef test_foo():\r\n    assert True\r\n```\r\n\r\nExecution of this test case works as expected:\r\n\r\n```\r\n$ py.test \r\n============================== test session starts ===============================\r\nplatform linux -- Python 3.5.1, pytest-3.0.4, py-1.4.31, pluggy-0.4.0\r\nrootdir: /home/usmqe/tmp, inifile: \r\ncollected 1 items \r\n\r\ntest_foo.py .\r\n\r\n============================ 1 passed in 0.01 seconds ===========================\r\n```\r\n\r\nAnd there are no problems with invocations listed below either:\r\n\r\n* `py.test test_foo.py`\r\n* `py.test  --override-ini xfail_strict=True`\r\n\r\nBut when I both reconfigure any configuration option via `--override-ini` and specify a test case at the same time, py.test crashes:\r\n\r\n```\r\n$ py.test --override-ini xfail_strict=True test_foo.py \r\nTraceback (most recent call last):\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 1064, in getini\r\n    return self._inicache[name]\r\nKeyError: 'testpaths'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/usmqe/.local/bin/py.test\", line 11, in <module>\r\n    sys.exit(main())\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 47, in main\r\n    config = _prepareconfig(args, plugins)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 132, in _prepareconfig\r\n    pluginmanager=pluginmanager, args=args)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 745, in __call__\r\n    return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 339, in _hookexec\r\n    return self._inner_hookexec(hook, methods, kwargs)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 334, in <lambda>\r\n    _MultiCall(methods, kwargs, hook.spec_opts).execute()\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 613, in execute\r\n    return _wrapped_call(hook_impl.function(*args), self.execute)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 250, in _wrapped_call\r\n    wrap_controller.send(call_outcome)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/helpconfig.py\", line 32, in pytest_cmdline_parse\r\n    config = outcome.get_result()\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 279, in get_result\r\n    raise ex[1].with_traceback(ex[2])\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 265, in __init__\r\n    self.result = func()\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 614, in execute\r\n    res = hook_impl.function(*args)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 882, in pytest_cmdline_parse\r\n    self.parse(args)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 1045, in parse\r\n    args = self.getini('testpaths')\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 1066, in getini\r\n    self._inicache[name] = val = self._getini(name)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 1074, in _getini\r\n    value = self._get_override_ini_value(name)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 1123, in _get_override_ini_value\r\n    (key, user_ini_value) = ini_config.split(\"=\", 1)\r\nValueError: not enough values to unpack (expected 2, got 1)\r\n\r\n```\r\n\r\n## Enviroment\r\n\r\nI'm using Python 3.5.1 (from `rh-python35` collection on RHEL 7):\r\n\r\n```\r\n$ python --version\r\nPython 3.5.1\r\n$ rpm -qf $(which python)\r\nrh-python35-python-3.5.1-6.el7.x86_64\r\n```\r\n\r\nAnd Pytest 3.0.4:\r\n\r\n```\r\n$ py.test --version\r\nThis is pytest version 3.0.4, imported from /home/usmqe/.local/lib/python3.5/site-packages/pytest.py\r\n```\r\n\r\nThe rest of python environment:\r\n\r\n```\r\n$ pip list\r\nYou are using pip version 7.1.0, however version 9.0.1 is available.\r\nYou should consider upgrading via the 'pip install --upgrade pip' command.\r\ndocutils (0.12)\r\nJinja2 (2.8)\r\nMarkupSafe (0.23)\r\nmrglog (0.1.1)\r\npip (7.1.0)\r\nplumbum (1.6.2)\r\npy (1.4.31)\r\npytest (3.0.4)\r\nPyYAML (3.10)\r\nrequests (2.11.1)\r\nsetuptools (18.0.1)\r\nvirtualenv (13.1.2)\r\n```\r\n",
        "issue_id": 2105,
        "pr_number": 2108,
        "pr_title": "Add warning for incorrect passing args to `-o`.",
        "pr_body": "Closes #2105.",
        "issue_closed_at": "2016-12-01T12:49:24Z",
        "base_commit": "e612619aea1ce21646cd24934fb65e8c1302e531"
      },
      "summary": "### Summary:\n\nThis issue arises when using the `--override-ini` command line option in conjunction with specifying a particular test file to execute in pytest. The problem manifests as a `KeyError` related to the 'testpaths' configuration option. The error occurs due to a mishandling of configuration options when they are overridden and a specific test is simultaneously specified.\n\n1. **Problem Description in General Terms**: The problem occurs when users attempt to override pytest configuration settings using the `--override-ini` option while also specifying a particular test file to run. This combination leads to an exception being thrown, causing the test execution to crash.\n\n2. **Key Symptoms and Behaviors Observed**: The primary symptom is a `KeyError: 'testpaths'` exception, indicating that the configuration is unable to retrieve the expected 'testpaths' value. This is followed by a traceback that reveals the issue occurs during the configuration parsing process.\n\n3. **Affected Components or Systems**: The issue affects the pytest framework, specifically the configuration handling component within the `_pytest/config.py` module when interacting with the command-line interface.\n\n4. **Potential Impact or Severity**: This is a critical issue for users who rely on the `--override-ini` feature for test configuration, as it prevents the execution of tests when specific conditions are met. It disrupts the testing workflow, particularly for those who need to dynamically adjust configurations on a per-test basis.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The issue is rooted in the handling of INI configuration overrides, specifically within the `Config._get_override_ini_value` function. The problem arises when the override configuration string does not properly split into key-value pairs, leading to a failure in retrieving or setting configuration values. This indicates a need for more robust error handling and input validation in the configuration parsing logic. The problem was addressed by modifying functions in the `_pytest/config.py` and `_pytest/helpconfig.py` modules, ensuring correct processing of override configurations.",
      "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: KeyError: 'testpaths' exception raised when using --override-ini command line option\n\nBody:\n## Summary of the issue\r\n\r\nWhen I use `--override-ini` feature while specifying particular test to run, `py.test` crashes with `KeyError: 'testpaths'` exception.\r\n\r\n## Description of a reproducer\r\n\r\nCreate minimal test case in `~/tmp` directory so that:\r\n\r\n```\r\n$ cd ~/tmp\r\n$ ls\r\ntest_foo.py\r\n$ cat test_foo.py\r\ndef test_foo():\r\n    assert True\r\n```\r\n\r\nExecution of this test case works as expected:\r\n\r\n```\r\n$ py.test \r\n============================== test session starts ===============================\r\nplatform linux -- Python 3.5.1, pytest-3.0.4, py-1.4.31, pluggy-0.4.0\r\nrootdir: /home/usmqe/tmp, inifile: \r\ncollected 1 items \r\n\r\ntest_foo.py .\r\n\r\n============================ 1 passed in 0.01 seconds ===========================\r\n```\r\n\r\nAnd there are no problems with invocations listed below either:\r\n\r\n* `py.test test_foo.py`\r\n* `py.test  --override-ini xfail_strict=True`\r\n\r\nBut when I both reconfigure any configuration option via `--override-ini` and specify a test case at the same time, py.test crashes:\r\n\r\n```\r\n$ py.test --override-ini xfail_strict=True test_foo.py \r\nTraceback (most recent call last):\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 1064, in getini\r\n    return self._inicache[name]\r\nKeyError: 'testpaths'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/usmqe/.local/bin/py.test\", line 11, in <module>\r\n    sys.exit(main())\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 47, in main\r\n    config = _prepareconfig(args, plugins)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 132, in _prepareconfig\r\n    pluginmanager=pluginmanager, args=args)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 745, in __call__\r\n    return self._hookexec(self, self._nonwrappers + self._wrappers, kwargs)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 339, in _hookexec\r\n    return self._inner_hookexec(hook, methods, kwargs)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 334, in <lambda>\r\n    _MultiCall(methods, kwargs, hook.spec_opts).execute()\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 613, in execute\r\n    return _wrapped_call(hook_impl.function(*args), self.execute)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 250, in _wrapped_call\r\n    wrap_controller.send(call_outcome)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/helpconfig.py\", line 32, in pytest_cmdline_parse\r\n    config = outcome.get_result()\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 279, in get_result\r\n    raise ex[1].with_traceback(ex[2])\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 265, in __init__\r\n    self.result = func()\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/vendored_packages/pluggy.py\", line 614, in execute\r\n    res = hook_impl.function(*args)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 882, in pytest_cmdline_parse\r\n    self.parse(args)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 1045, in parse\r\n    args = self.getini('testpaths')\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 1066, in getini\r\n    self._inicache[name] = val = self._getini(name)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 1074, in _getini\r\n    value = self._get_override_ini_value(name)\r\n  File \"/home/usmqe/.local/lib/python3.5/site-packages/_pytest/config.py\", line 1123, in _get_override_ini_value\r\n    (key, user_ini_value) = ini_config.split(\"=\", 1)\r\nValueError: not enough values to unpack (expected 2, got 1)\r\n\r\n```\r\n\r\n## Enviroment\r\n\r\nI'm using Python 3.5.1 (from `rh-python35` collection on RHEL 7):\r\n\r\n```\r\n$ python --version\r\nPython 3.5.1\r\n$ rpm -qf $(which python)\r\nrh-python35-python-3.5.1-6.el7.x86_64\r\n```\r\n\r\nAnd Pytest 3.0.4:\r\n\r\n```\r\n$ py.test --version\r\nThis is pytest version 3.0.4, imported from /home/usmqe/.local/lib/python3.5/site-packages/pytest.py\r\n```\r\n\r\nThe rest of python environment:\r\n\r\n```\r\n$ pip list\r\nYou are using pip version 7.1.0, however version 9.0.1 is available.\r\nYou should consider upgrading via the 'pip install --upgrade pip' command.\r\ndocutils (0.12)\r\nJinja2 (2.8)\r\nMarkupSafe (0.23)\r\nmrglog (0.1.1)\r\npip (7.1.0)\r\nplumbum (1.6.2)\r\npy (1.4.31)\r\npytest (3.0.4)\r\nPyYAML (3.10)\r\nrequests (2.11.1)\r\nsetuptools (18.0.1)\r\nvirtualenv (13.1.2)\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/config.py\n  function: Config._get_override_ini_value\n\n_pytest/helpconfig.py\n  function: pytest_addoption\n"
    },
    {
      "similar_issue": {
        "issue_title": "Parametrized argument named similarly to fixture (contains it) breaks that fixture's parametrization",
        "issue_body": "Originally reported by: **Jacobo Giralt (BitBucket: [jgiralt](http://bitbucket.org/jgiralt), GitHub: [jgiralt](http://github.com/jgiralt))**\n\n---\n\n```\n#!python\n\nimport pytest\n\n@pytest.fixture(params=[1,2,3])\ndef foo(request):\n    return request.param\n\n@pytest.mark.parametrize('foobar', [4,5,6])\ndef test_issue(foo, foobar):\n    assert True\n```\n\n```\n#!python\n\nrequest = <SubRequest 'foo' for <Function 'test_issue[4]'>>\n\n    @pytest.fixture(params=[1,2,3])\n    def foo(request):\n>       return request.param\nAttributeError: SubRequest instance has no attribute 'param'\n```\n\nThe issue seems reproducible as long as the parametrized test argument contains the fixture name as a substring, e.g. foobar, barfoo, foox, xfoo, disappears as soon as I modify the fixture name to anything else.\n\nThis same code works in pytest-2.6.4 and fails for 2.7.\n\n---\n- Bitbucket: https://bitbucket.org/pytest-dev/pytest/issue/736\n",
        "issue_id": 736,
        "pr_number": 926,
        "pr_title": "Don't skip fixtures that are substrings of params",
        "pr_body": "Fix #736\n",
        "issue_closed_at": "2015-08-11T00:12:52Z",
        "base_commit": "681e502c12f5baa3f2da9c9de4a848813a872945"
      },
      "summary": "### Summary:\n\nThis issue is related to a conflict between parametrized test arguments and fixture names in pytest, a popular testing framework for Python. Specifically, when a test argument that is parametrized has a name containing a fixture's name as a substring, it causes a failure in the fixture's ability to retrieve parameter values. The issue manifests as an `AttributeError`, indicating that the `SubRequest` instance does not have the expected attribute `param`, which is critical for the fixture's operation.\n\n1. **Problem Description:**\n   In pytest, when a test is parametrized with an argument whose name includes the name of a fixture as a substring, it disrupts the fixture's parametrization process. This leads to an error where the fixture cannot access its defined parameters.\n\n2. **Key Symptoms and Behaviors Observed:**\n   The primary symptom is an `AttributeError` when attempting to access `request.param` within a fixture. This occurs because the name conflict between the parametrized test argument and the fixture causes an erroneous state in pytest's handling of test parameters.\n\n3. **Affected Components or Systems:**\n   The issue affects the fixture mechanism in pytest, particularly in versions starting from 2.7. The problem is evident in the `FixtureManager.pytest_generate_tests` function within the pytest codebase, suggesting a regression or change in behavior from previous versions (e.g., 2.6.4, where the code worked as expected).\n\n4. **Potential Impact or Severity:**\n   The severity of this issue is moderate, affecting test reliability and correctness. It could lead to misinterpretation of test results or hinder testing processes in projects depending on specific naming conventions for parametrized tests and fixtures.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   The problem arises from a naming conflict where substring matches between test arguments and fixture names interfere with pytest's internal mechanisms for managing test parameters. This indicates a need for careful naming conventions or a patch to handle such conflicts more gracefully within the pytest framework. The issue was documented in a Bitbucket issue (#736) and required a fix in the pytest source code to resolve the name clash and restore expected functionality.",
      "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"
    }
  ]
}