{
  "Selected_candidate": {
    "pr_number": 10988,
    "pr_title": " Consider testpaths for initial conftests",
    "pr_body": "The `testpaths` option is meant to be identical to execute pytest passing the 'testpaths' directories explicitly.\r\n\r\nThis also fixes #10169, given I had to change the same part of the code in order to get tests to pass on Python 3.7. \r\n\r\nFix #430\r\nFix #10169 \r\nFix #10987",
    "issue_id": 10169,
    "issue_title": "Pytest trying to check if custom argument is a file crashes due to filename being too long",
    "issue_body": "I have a custom flag defined in conftest.py, and when I try to assign it to a value that is too long pytest crashes before ever getting to my code. This reproduces even if the flag isn't defined, and even if the current working directory is `/`.\r\n\r\nFailing example:\r\n```bash\r\n/> pytest --xxxxx_flags=\" --xxxxxxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxxxxx\"     \r\nTraceback (most recent call last):\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/bin/pytest\", line 8, in <module>\r\n    sys.exit(console_main())\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/_pytest/config/__init__.py\", line 188, in console_main\r\n    code = main()\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/_pytest/config/__init__.py\", line 146, in main\r\n    config = _prepareconfig(args, plugins)\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/_pytest/config/__init__.py\", line 325, in _prepareconfig\r\n    config = pluginmanager.hook.pytest_cmdline_parse(\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/pluggy/_hooks.py\", line 265, in __call__\r\n    return self._hookexec(self.name, self.get_hookimpls(), kwargs, firstresult)\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/pluggy/_manager.py\", line 80, in _hookexec\r\n    return self._inner_hookexec(hook_name, methods, kwargs, firstresult)\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/pluggy/_callers.py\", line 55, in _multicall\r\n    gen.send(outcome)\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/_pytest/helpconfig.py\", line 102, in pytest_cmdline_parse\r\n    config: Config = outcome.get_result()\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/pluggy/_result.py\", line 60, in get_result\r\n    raise ex[1].with_traceback(ex[2])\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/pluggy/_callers.py\", line 39, in _multicall\r\n    res = hook_impl.function(*args)\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/_pytest/config/__init__.py\", line 1013, in pytest_cmdline_parse\r\n    self.parse(args)\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/_pytest/config/__init__.py\", line 1301, in parse\r\n    self._preparse(args, addopts=addopts)\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/_pytest/config/__init__.py\", line 1203, in _preparse\r\n    self.hook.pytest_load_initial_conftests(\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/pluggy/_hooks.py\", line 265, in __call__\r\n    return self._hookexec(self.name, self.get_hookimpls(), kwargs, firstresult)\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/pluggy/_manager.py\", line 80, in _hookexec\r\n    return self._inner_hookexec(hook_name, methods, kwargs, firstresult)\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/pluggy/_callers.py\", line 60, in _multicall\r\n    return outcome.get_result()\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/pluggy/_result.py\", line 60, in get_result\r\n    raise ex[1].with_traceback(ex[2])\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/pluggy/_callers.py\", line 39, in _multicall\r\n    res = hook_impl.function(*args)\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/_pytest/config/__init__.py\", line 1080, in pytest_load_initial_conftests\r\n    self.pluginmanager._set_initial_conftests(\r\n  File \"/home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/_pytest/config/__init__.py\", line 525, in _set_initial_conftests\r\n    if anchor.exists():  # we found some file object\r\n  File \"/usr/lib/python3.8/pathlib.py\", line 1407, in exists\r\n    self.stat()\r\n  File \"/usr/lib/python3.8/pathlib.py\", line 1198, in stat\r\n    return self._accessor.stat(self)\r\nOSError: [Errno 36] File name too long: '/--xxxxx_flags= --xxxxxxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxxxxx'\r\n```\r\n\r\nIf I reduce the length of the flag, I get the expected behavior for my project, and this different and expected error from my pytest MVP:\r\n```bash\r\n/> pytest --xxxxx_flags=\" --xxxxxxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxx\"\r\n=========================================================================== test session starts ============================================================================\r\nplatform linux -- Python 3.8.10, pytest-7.0.0, pluggy-1.0.0\r\nrootdir: /\r\nplugins: flaky-3.7.0, colcon-core-0.10.0, cov-2.8.1\r\ncollected 0 items                                                                                                                                                          \r\n\r\n============================================================================= warnings summary =============================================================================\r\nhome/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/_pytest/cacheprovider.py:433\r\n  /home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/_pytest/cacheprovider.py:433: PytestCacheWarning: could not create cache path /.pytest_cache/v/cache/nodeids\r\n    config.cache.set(\"cache/nodeids\", sorted(self.cached_nodeids))\r\n\r\nhome/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/_pytest/stepwise.py:52\r\n  /home/ANT.AMAZON.COM/jdckmz/.local/lib/python3.8/site-packages/_pytest/stepwise.py:52: PytestCacheWarning: could not create cache path /.pytest_cache/v/cache/stepwise\r\n    session.config.cache.set(STEPWISE_CACHE_DIR, [])\r\n\r\n-- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html\r\n=========================================================================== 2 warnings in 0.01s ============================================================================\r\nERROR: file or directory not found: --xxxxx_flags= --xxxxxxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxx --xxxxxxxxxxxxxxxxxxxxxx\r\n```\r\n\r\nI did a little digging into my version of pytest (7.0.0) to make sure I wasn't doing something wrong, but it looks like there is a blind call to `pathlib.Path.exists()` with a path constructed from the argument in `__init__.py`:\r\n```python\r\n    #\r\n    # Internal API for local conftest plugin handling.\r\n    #\r\n    def _set_initial_conftests(\r\n        self, namespace: argparse.Namespace, rootpath: Path\r\n    ) -> None:\r\n    ...\r\n    testpaths = namespace.file_or_dir\r\n    foundanchor = False\r\n    for testpath in testpaths:\r\n            path = str(testpath)\r\n            i = path.find(\"::\")\r\n            if i != -1:\r\n                path = path[:i]\r\n            anchor = absolutepath(current / path)\r\n            if anchor.exists():  # this throws OSError which is never caught\r\n```\r\nIt seems to me like there should be a try or something here, since in cases like mine the argument may not be a file at all, and that can cause OS level errors.\r\n\r\nOperating System: Ubuntu 20.04 LTS\r\n```\r\n> pytest --version\r\npytest 7.0.0\r\n> python3 --version\r\nPython 3.8.10\r\n```\r\n```\r\n> pip list\r\n/usr/lib/python3/dist-packages/secretstorage/dhcrypto.py:15: CryptographyDeprecationWarning: int_from_bytes is deprecated, use int.from_bytes instead\r\n  from cryptography.utils import int_from_bytes\r\n/usr/lib/python3/dist-packages/secretstorage/util.py:19: CryptographyDeprecationWarning: int_from_bytes is deprecated, use int.from_bytes instead\r\n  from cryptography.utils import int_from_bytes\r\nPackage                       Version\r\n----------------------------- --------------------\r\naiohttp                       3.8.1\r\naiosignal                     1.2.0\r\nalabaster                     0.7.12\r\napturl                        0.5.2\r\nargcomplete                   1.8.1\r\nastroid                       2.9.3\r\nasync-timeout                 4.0.2\r\natomicwrites                  1.4.0\r\nattrs                         21.4.0\r\nautobahn                      17.10.1\r\nAutomat                       0.8.0\r\naws-requests-auth             0.4.3\r\nawscli                        1.22.52\r\nawscrt                        0.13.0\r\nawsiotsdk                     1.9.0\r\nBabel                         2.9.1\r\nbcrypt                        3.2.0\r\nbeautifulsoup4                4.8.2\r\nblack                         22.1.0\r\nblinker                       1.4\r\nboto3                         1.20.52\r\nbotocore                      1.23.52\r\nBrlapi                        0.7.0\r\ncached-property               1.5.1\r\ncatkin-pkg-modules            0.5.2\r\ncbor                          1.0.0\r\ncertifi                       2021.10.8\r\ncffi                          1.15.0\r\nchardet                       4.0.0\r\ncharset-normalizer            2.0.11\r\nclick                         8.0.3\r\ncmakelang                     0.6.13\r\ncmakelint                     1.4.2\r\ncolcon-argcomplete            0.3.3\r\ncolcon-bash                   0.4.2\r\ncolcon-cd                     0.1.1\r\ncolcon-cmake                  0.2.26\r\ncolcon-common-extensions      0.3.0\r\ncolcon-core                   0.10.0\r\ncolcon-defaults               0.2.6\r\ncolcon-devtools               0.2.3\r\ncolcon-library-path           0.2.1\r\ncolcon-metadata               0.2.5\r\ncolcon-notification           0.2.13\r\ncolcon-output                 0.2.12\r\ncolcon-package-information    0.3.3\r\ncolcon-package-selection      0.2.10\r\ncolcon-parallel-executor      0.2.4\r\ncolcon-pkg-config             0.1.0\r\ncolcon-powershell             0.3.7\r\ncolcon-python-setup-py        0.2.7\r\ncolcon-recursive-crawl        0.2.1\r\ncolcon-ros                    0.3.23\r\ncolcon-test-result            0.3.8\r\ncolcon-zsh                    0.4.0\r\ncolorama                      0.4.3\r\ncommand-not-found             0.3\r\nconstantly                    15.1.0\r\ncontrol                       0.9.1\r\ncov-core                      1.15.0\r\ncoverage                      4.5.2\r\ncryptography                  36.0.1\r\ncupshelpers                   1.0\r\ncycler                        0.11.0\r\nCython                        0.29.14\r\ndbus-python                   1.2.16\r\ndefer                         1.0.6\r\ndistlib                       0.3.4\r\ndistro                        1.4.0\r\ndistro-info                   0.23ubuntu1\r\ndocker                        5.0.3\r\ndocker-compose                1.25.0\r\ndockerpty                     0.4.1\r\ndocopt                        0.6.2\r\ndocutils                      0.15.2\r\nduplicity                     0.8.12.0\r\nEasyCluster                   0.22.2\r\nempy                          3.3.2\r\nentrypoints                   0.3\r\nevdev                         1.3.0\r\nfasteners                     0.14.1\r\nfilelock                      3.7.1\r\nfilemagic                     1.6\r\nflake8                        3.7.9\r\nflaky                         3.7.0\r\nfonttools                     4.29.1\r\nfrozenlist                    1.3.0\r\nfuture                        0.18.2\r\ngitdb                         4.0.9\r\ngitdb2                        4.0.2\r\ngithub.py                     0.5.0\r\nGitPython                     3.1.26\r\ngpg                           1.13.1-unknown\r\ngreenlet                      1.1.2\r\nhtml5lib                      1.0.1\r\nhttplib2                      0.14.0\r\nhyperlink                     19.0.0\r\nidna                          3.3\r\nifcfg                         0.18\r\nimagesize                     1.3.0\r\nimportlib-metadata            4.10.1\r\nincremental                   16.10.1\r\ninfluxdb                      5.3.1\r\niniconfig                     1.1.1\r\nisort                         5.10.1\r\nJinja2                        3.0.3\r\njmespath                      0.10.0\r\njsonschema                    3.2.0\r\nkeyring                       18.0.1\r\nkeyrings.alt                  3.4.0\r\nkiwisolver                    1.3.2\r\nlanguage-selector             0.1\r\nlark-parser                   0.8.1\r\nlaunchpadlib                  1.10.13\r\nlazr.restfulclient            0.14.2\r\nlazr.uri                      1.0.3\r\nlazy-object-proxy             1.7.1\r\nlockfile                      0.12.2\r\nlouis                         3.12.0\r\nlxml                          4.5.0\r\nlz4                           3.0.2+dfsg\r\nmacaroonbakery                1.3.1\r\nMako                          1.1.0\r\nMarkupSafe                    2.0.1\r\nmatplotlib                    3.5.1\r\nmccabe                        0.6.1\r\nmock                          3.0.5\r\nmonotonic                     1.5\r\nmore-itertools                8.12.0\r\nmpi4py                        3.0.3\r\nmsgpack                       1.0.3\r\nmulti-key-dict                2.0.3\r\nmultidict                     6.0.2\r\nmypy-extensions               0.4.3\r\nnetifaces                     0.10.4\r\nnose2                         0.9.1\r\nnotify2                       0.3\r\nnumpy                         1.22.2\r\noauthlib                      3.1.0\r\nolefile                       0.46\r\npackaging                     21.3\r\npandas                        1.4.0\r\nparamiko                      2.9.2\r\npathspec                      0.9.0\r\npbr                           5.8.1\r\npexpect                       4.8.0\r\nPillow                        9.0.1\r\npip                           22.1.2\r\npipenv                        2022.6.7\r\nplatformdirs                  2.5.0\r\npluggy                        1.0.0\r\nprotobuf                      3.19.4\r\npsutil                        5.8.0\r\nptyprocess                    0.7.0\r\npy                            1.11.0\r\npy-ubjson                     0.14.0\r\npyasn1                        0.4.8\r\npyasn1-modules                0.2.1\r\npybind11                      2.8.0\r\npycairo                       1.16.2\r\npycodestyle                   2.8.0\r\npycparser                     2.21\r\npycrypto                      2.6.1\r\npycups                        1.9.73\r\npydocstyle                    2.1.1\r\npydot                         1.4.1\r\npyelftools                    0.28\r\npyflakes                      2.1.1\r\nPygments                      2.11.2\r\nPyGObject                     3.36.0\r\nPyHamcrest                    1.9.0\r\nPyJWT                         1.7.1\r\npylint                        2.12.2\r\npymacaroons                   0.13.0\r\nPyNaCl                        1.5.0\r\npyOpenSSL                     19.0.0\r\npyparsing                     3.0.7\r\npypng                         0.0.20\r\nPyQRCode                      1.2.1\r\nPyQt5                         5.14.1\r\npyquaternion                  0.9.9\r\npyRFC3339                     1.1\r\npyrsistent                    0.15.5\r\npyserial                      3.5\r\npytest                        7.0.0\r\npytest-cov                    2.8.1\r\npython-apt                    2.0.0+ubuntu0.20.4.7\r\npython-dateutil               2.8.2\r\npython-debian                 0.1.36ubuntu1\r\npython-dotenv                 0.19.2\r\npython-jenkins                1.7.0\r\npython-magic                  0.4.16\r\npython-snappy                 0.5.3\r\nPyTrie                        0.2\r\npytz                          2021.3\r\npyxdg                         0.26\r\nPyYAML                        5.3.1\r\nreportlab                     3.5.34\r\nrequests                      2.27.1\r\nrequests-unixsocket           0.2.0\r\nroman                         2.0.0\r\nrosdistro-modules             0.9.0\r\nrospkg-modules                1.4.0\r\nrplidar                       0.9.2\r\nrsa                           4.7.2\r\ns3transfer                    0.5.1\r\nscipy                         1.8.0\r\nscreen-resolution-extra       0.0.0\r\nSecretStorage                 2.3.1\r\nservice-identity              18.1.0\r\nsetproctitle                  1.1.10\r\nsetuptools                    45.2.0\r\nsimplejson                    3.16.0\r\nsip                           4.19.21\r\nsix                           1.16.0\r\nsmmap                         5.0.0\r\nsmmap2                        3.0.1\r\nsnowballstemmer               2.2.0\r\nsoupsieve                     1.9.5\r\nSphinx                        4.4.0\r\nsphinx-autoapi                1.8.4\r\nsphinxcontrib-applehelp       1.0.2\r\nsphinxcontrib-devhelp         1.0.2\r\nsphinxcontrib-dotnetdomain    0.4\r\nsphinxcontrib-golangdomain    0.2.0.dev0\r\nsphinxcontrib-htmlhelp        2.0.0\r\nsphinxcontrib-jsmath          1.0.1\r\nsphinxcontrib-qthelp          1.0.3\r\nsphinxcontrib-serializinghtml 1.1.5\r\nsphinxcontrib-websupport      1.2.4\r\nSQLAlchemy                    1.4.35\r\nssh-import-id                 5.10\r\ntensorrt                      8.0.1.6\r\ntexttable                     1.6.2\r\ntoml                          0.10.2\r\ntomli                         2.0.1\r\ntripy                         1.0.0\r\nTwisted                       18.9.0\r\ntxaio                         2.10.0\r\ntyped-ast                     1.5.2\r\ntyping_extensions             4.0.1\r\nu-msgpack-python              2.1\r\nubuntu-advantage-tools        27.9\r\nubuntu-drivers-common         0.0.0\r\nufw                           0.36\r\nunattended-upgrades           0.1\r\nUnidecode                     1.3.2\r\nurllib3                       1.26.8\r\nusb-creator                   0.3.7\r\nvirtualenv                    20.14.1\r\nvirtualenv-clone              0.5.7\r\nwadllib                       1.3.3\r\nwcwidth                       0.1.8\r\nwebencodings                  0.5.1\r\nwebsocket-client              1.2.3\r\nwheel                         0.34.2\r\nwrapt                         1.13.3\r\nwsaccel                       0.6.2\r\nxdot                          1.1\r\nxkit                          0.0.0\r\nxmltodict                     0.12.0\r\nyarl                          1.7.2\r\nzipp                          3.7.0\r\nzope.interface                4.7.1\r\nzstandard                     0.17.0\r\n```\r\n- [x] a detailed description of the bug or problem you are having\r\n- [x] output of `pip list` from the virtual environment you are using\r\n- [x] pytest and operating system versions\r\n- [x] minimal example if possible\r\n",
    "issue_closed_at": "2023-05-12T12:59:01Z",
    "base_commit": "78403237cf5026f23618ea7a867bf8b674116e6f",
    "changes": [
      {
        "file": "src/_pytest/config/__init__.py",
        "type": "function",
        "name": "pytest_configure",
        "class_name": "PytestPluginManager",
        "code": "def pytest_configure(self, config: \"Config\") -> None:\n        \"\"\":meta private:\"\"\"\n        # XXX now that the pluginmanager exposes hookimpl(tryfirst...)\n        # we should remove tryfirst/trylast as markers.\n        config.addinivalue_line(\n            \"markers\",\n            \"tryfirst: mark a hook implementation function such that the \"\n            \"plugin machinery will try to call it first/as early as possible. \"\n            \"DEPRECATED, use @pytest.hookimpl(tryfirst=True) instead.\",\n        )\n        config.addinivalue_line(\n            \"markers\",\n            \"trylast: mark a hook implementation function such that the \"\n            \"plugin machinery will try to call it last/as late as possible. \"\n            \"DEPRECATED, use @pytest.hookimpl(trylast=True) instead.\",\n        )\n        self._configured = True"
      },
      {
        "file": "src/_pytest/config/__init__.py",
        "type": "function",
        "name": "_set_initial_conftests",
        "class_name": "PytestPluginManager",
        "code": "def _set_initial_conftests(\n        self, namespace: argparse.Namespace, rootpath: Path\n    ) -> None:\n        \"\"\"Load initial conftest files given a preparsed \"namespace\".\n\n        As conftest files may add their own command line options which have\n        arguments ('--my-opt somepath') we might get some false positives.\n        All builtin and 3rd party plugins will have been loaded, however, so\n        common options will not confuse our logic here.\n        \"\"\"\n        current = Path.cwd()\n        self._confcutdir = (\n            absolutepath(current / namespace.confcutdir)\n            if namespace.confcutdir\n            else None\n        )\n        self._noconftest = namespace.noconftest\n        self._using_pyargs = namespace.pyargs\n        testpaths = namespace.file_or_dir\n        foundanchor = False\n        for testpath in testpaths:\n            path = str(testpath)\n            # remove node-id syntax\n            i = path.find(\"::\")\n            if i != -1:\n                path = path[:i]\n            anchor = absolutepath(current / path)\n            if anchor.exists():  # we found some file object\n                self._try_load_conftest(anchor, namespace.importmode, rootpath)\n                foundanchor = True\n        if not foundanchor:\n            self._try_load_conftest(current, namespace.importmode, rootpath)"
      },
      {
        "file": "src/_pytest/config/__init__.py",
        "type": "function",
        "name": "_set_initial_conftests",
        "class_name": "PytestPluginManager",
        "code": "def _set_initial_conftests(\n        self, namespace: argparse.Namespace, rootpath: Path\n    ) -> None:\n        \"\"\"Load initial conftest files given a preparsed \"namespace\".\n\n        As conftest files may add their own command line options which have\n        arguments ('--my-opt somepath') we might get some false positives.\n        All builtin and 3rd party plugins will have been loaded, however, so\n        common options will not confuse our logic here.\n        \"\"\"\n        current = Path.cwd()\n        self._confcutdir = (\n            absolutepath(current / namespace.confcutdir)\n            if namespace.confcutdir\n            else None\n        )\n        self._noconftest = namespace.noconftest\n        self._using_pyargs = namespace.pyargs\n        testpaths = namespace.file_or_dir\n        foundanchor = False\n        for testpath in testpaths:\n            path = str(testpath)\n            # remove node-id syntax\n            i = path.find(\"::\")\n            if i != -1:\n                path = path[:i]\n            anchor = absolutepath(current / path)\n            if anchor.exists():  # we found some file object\n                self._try_load_conftest(anchor, namespace.importmode, rootpath)\n                foundanchor = True\n        if not foundanchor:\n            self._try_load_conftest(current, namespace.importmode, rootpath)"
      },
      {
        "file": "src/_pytest/config/__init__.py",
        "type": "function",
        "name": "_processopt",
        "class_name": null,
        "code": "def _processopt(self, opt: \"Argument\") -> None:\n        for name in opt._short_opts + opt._long_opts:\n            self._opt2dest[name] = opt.dest\n\n        if hasattr(opt, \"default\"):\n            if not hasattr(self.option, opt.dest):\n                setattr(self.option, opt.dest, opt.default)"
      }
    ]
  },
  "Justification": "Candidate B is the most relevant as it deals with pytest crashing due to a custom argument handling issue. The CURRENT bug report indicates that there are complications in loading modules and executing functions correctly due to namespace issues with the `pmxbot.logging.Logger`. Both reports involve complexities in the pytest invocation and setup that lead to exception handling failures—more specifically, issues relating to how pytest handles configurations that could lead to incorrect module loading or function execution. Addressing Candidate B gives insights into ensuring proper argument parsing and handling in pytest, which is critical for resolving problems with the module initialization in the CURRENT bug.",
  "instance_id": "pytest-dev__pytest-11148",
  "repo": "pytest-dev/pytest",
  "created_at": "2023-06-29T00:04:33Z",
  "problem_statement": "Module imported twice under import-mode=importlib\nIn pmxbot/pmxbot@7f189ad, I'm attempting to switch pmxbot off of pkg_resources style namespace packaging to PEP 420 namespace packages. To do so, I've needed to switch to `importlib` for the `import-mode` and re-organize the tests to avoid import errors on the tests.\r\n\r\nYet even after working around these issues, the tests are failing when the effect of `core.initialize()` doesn't seem to have had any effect.\r\n\r\nInvestigating deeper, I see that initializer is executed and performs its actions (setting a class variable `pmxbot.logging.Logger.store`), but when that happens, there are two different versions of `pmxbot.logging` present, one in `sys.modules` and another found in `tests.unit.test_commands.logging`:\r\n\r\n```\r\n=========================================================================== test session starts ===========================================================================\r\nplatform darwin -- Python 3.11.1, pytest-7.2.0, pluggy-1.0.0\r\ncachedir: .tox/python/.pytest_cache\r\nrootdir: /Users/jaraco/code/pmxbot/pmxbot, configfile: pytest.ini\r\nplugins: black-0.3.12, mypy-0.10.3, jaraco.test-5.3.0, checkdocs-2.9.0, flake8-1.1.1, enabler-2.0.0, jaraco.mongodb-11.2.1, pmxbot-1122.14.3.dev13+g7f189ad\r\ncollected 421 items / 180 deselected / 241 selected                                                                                                                       \r\nrun-last-failure: rerun previous 240 failures (skipped 14 files)\r\n\r\ntests/unit/test_commands.py E\r\n>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> traceback >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>\r\n\r\ncls = <class 'tests.unit.test_commands.TestCommands'>\r\n\r\n    @classmethod\r\n    def setup_class(cls):\r\n        path = os.path.dirname(os.path.abspath(__file__))\r\n        configfile = os.path.join(path, 'testconf.yaml')\r\n        config = pmxbot.dictlib.ConfigDict.from_yaml(configfile)\r\n        cls.bot = core.initialize(config)\r\n>       logging.Logger.store.message(\"logged\", \"testrunner\", \"some text\")\r\nE       AttributeError: type object 'Logger' has no attribute 'store'\r\n\r\ntests/unit/test_commands.py:37: AttributeError\r\n>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> entering PDB >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>\r\n\r\n>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> PDB post_mortem (IO-capturing turned off) >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>\r\n> /Users/jaraco/code/pmxbot/pmxbot/tests/unit/test_commands.py(37)setup_class()\r\n-> logging.Logger.store.message(\"logged\", \"testrunner\", \"some text\")\r\n(Pdb) logging.Logger\r\n<class 'pmxbot.logging.Logger'>\r\n(Pdb) logging\r\n<module 'pmxbot.logging' from '/Users/jaraco/code/pmxbot/pmxbot/pmxbot/logging.py'>\r\n(Pdb) import sys\r\n(Pdb) sys.modules['pmxbot.logging']\r\n<module 'pmxbot.logging' from '/Users/jaraco/code/pmxbot/pmxbot/pmxbot/logging.py'>\r\n(Pdb) sys.modules['pmxbot.logging'] is logging\r\nFalse\r\n```\r\n\r\nI haven't yet made a minimal reproducer, but I wanted to first capture this condition.\r\n\n",
  "patch": "diff --git a/src/_pytest/pathlib.py b/src/_pytest/pathlib.py\n--- a/src/_pytest/pathlib.py\n+++ b/src/_pytest/pathlib.py\n@@ -523,6 +523,8 @@ def import_path(\n \n     if mode is ImportMode.importlib:\n         module_name = module_name_from_path(path, root)\n+        with contextlib.suppress(KeyError):\n+            return sys.modules[module_name]\n \n         for meta_importer in sys.meta_path:\n             spec = meta_importer.find_spec(module_name, [str(path.parent)])\n"
}