{
  "original_problem": {
    "instance_id": "pylint-dev__pylint-7114",
    "repo": "pylint-dev/pylint",
    "created_at": "2022-07-03T04:36:40Z",
    "problem_statement": "Linting fails if module contains module of the same name\n### Steps to reproduce\r\n\r\nGiven multiple files:\r\n```\r\n.\r\n`-- a/\r\n    |-- a.py\r\n    `-- b.py\r\n```\r\nWhich are all empty, running `pylint a` fails:\r\n\r\n```\r\n$ pylint a\r\n************* Module a\r\na/__init__.py:1:0: F0010: error while code parsing: Unable to load file a/__init__.py:\r\n[Errno 2] No such file or directory: 'a/__init__.py' (parse-error)\r\n$\r\n```\r\n\r\nHowever, if I rename `a.py`, `pylint a` succeeds:\r\n\r\n```\r\n$ mv a/a.py a/c.py\r\n$ pylint a\r\n$\r\n```\r\nAlternatively, I can also `touch a/__init__.py`, but that shouldn't be necessary anymore.\r\n\r\n### Current behavior\r\n\r\nRunning `pylint a` if `a/a.py` is present fails while searching for an `__init__.py` file.\r\n\r\n### Expected behavior\r\n\r\nRunning `pylint a` if `a/a.py` is present should succeed.\r\n\r\n### pylint --version output\r\n\r\nResult of `pylint --version` output:\r\n\r\n```\r\npylint 3.0.0a3\r\nastroid 2.5.6\r\nPython 3.8.5 (default, Jan 27 2021, 15:41:15) \r\n[GCC 9.3.0]\r\n```\r\n\r\n### Additional info\r\n\r\nThis also has some side-effects in module resolution. For example, if I create another file `r.py`:\r\n\r\n```\r\n.\r\n|-- a\r\n|   |-- a.py\r\n|   `-- b.py\r\n`-- r.py\r\n```\r\n\r\nWith the content:\r\n\r\n```\r\nfrom a import b\r\n```\r\n\r\nRunning `pylint -E r` will run fine, but `pylint -E r a` will fail. Not just for module a, but for module r as well.\r\n\r\n```\r\n************* Module r\r\nr.py:1:0: E0611: No name 'b' in module 'a' (no-name-in-module)\r\n************* Module a\r\na/__init__.py:1:0: F0010: error while code parsing: Unable to load file a/__init__.py:\r\n[Errno 2] No such file or directory: 'a/__init__.py' (parse-error)\r\n```\r\n\r\nAgain, if I rename `a.py` to `c.py`, `pylint -E r a` will work perfectly.\n",
    "patch": "diff --git a/pylint/lint/expand_modules.py b/pylint/lint/expand_modules.py\n--- a/pylint/lint/expand_modules.py\n+++ b/pylint/lint/expand_modules.py\n@@ -82,8 +82,10 @@ def expand_modules(\n             continue\n         module_path = get_python_path(something)\n         additional_search_path = [\".\", module_path] + path\n-        if os.path.exists(something):\n-            # this is a file or a directory\n+        if os.path.isfile(something) or os.path.exists(\n+            os.path.join(something, \"__init__.py\")\n+        ):\n+            # this is a file or a directory with an explicit __init__.py\n             try:\n                 modname = \".\".join(\n                     modutils.modpath_from_file(something, path=additional_search_path)\n@@ -103,9 +105,7 @@ def expand_modules(\n                 )\n                 if filepath is None:\n                     continue\n-            except (ImportError, SyntaxError) as ex:\n-                # The SyntaxError is a Python bug and should be\n-                # removed once we move away from imp.find_module: https://bugs.python.org/issue10588\n+            except ImportError as ex:\n                 errors.append({\"key\": \"fatal\", \"mod\": modname, \"ex\": ex})\n                 continue\n         filepath = os.path.normpath(filepath)\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_2052",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about redundant aliasing in imports, which is unrelated to module resolution or directory structure issues."
      },
      {
        "idx": 2,
        "id": "similar_5667",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "This issue deals with configuration file parsing errors, which is unrelated to module naming or directory structure."
      },
      {
        "idx": 3,
        "id": "similar_3525",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves cyclic imports due to type annotations, which is unrelated to directory structure or module naming conflicts."
      },
      {
        "idx": 4,
        "id": "similar_4593",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "This issue is about documentation warnings, which does not relate to module resolution or directory structure issues."
      },
      {
        "idx": 5,
        "id": "similar_2635",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue concerns configuration management with plugins, unrelated to module naming or directory structure problems."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "no complaints about \"from collections import OrderedDict as OrderedDict\"",
        "issue_body": "pylint does not complain if you use `import as` but don't change the name.\r\n\r\n### Steps to reproduce\r\nRun pylint on this file:\r\n```py\r\n\"\"\"frobnicate\"\"\"\r\n\r\nfrom collections import OrderedDict as OrderedDict\r\n\r\n\r\nSOME_DICT = OrderedDict()\r\n```\r\n\r\n### Current behavior\r\n\r\n10/10 rating\r\n\r\n### Expected behavior\r\n\r\nLess than 10/10 rating\r\n\r\n### pylint --version output\r\n\r\n```\r\nNo config file found, using default configuration\r\npylint 1.8.4, \r\nastroid 1.6.3\r\nPython 3.6.3 (default, Oct  3 2017, 21:45:48) \r\n[GCC 7.2.0]\r\n```",
        "issue_id": 2052,
        "pr_number": 2060,
        "pr_title": "fix for #2052.",
        "pr_body": "Add checker to warn when imported package is renamed as original one.\r\ne.g below imports\r\nfrom collections import OrderedDict as OrderedDict\r\nimport os.path as path\r\n\r\n### Fixes / new features\r\nFixes #2052 \r\n- \r\n",
        "issue_closed_at": "2018-05-07T08:40:13Z",
        "base_commit": "e090ea0acfa54c70b78d6345be1d32a8ddd36d74"
      },
      "summary": "### Summary:\nThis issue is concerning the behavior of the static code analysis tool, pylint, when handling import statements in Python code. Specifically, pylint fails to flag or penalize the use of redundant aliasing in import statements, where a module or class is imported with an alias that is identical to its original name. \n\n1. **Problem Description in General Terms:**\n   The problem arises from pylint's inability to detect and report potentially unnecessary aliasing in import statements, which does not contribute to the code's readability or maintainability, thus bypassing its primary function of promoting better coding practices.\n\n2. **Key Symptoms and Behaviors Observed:**\n   The primary symptom observed is pylint providing a perfect score (10/10 rating) to a Python script that utilizes redundant aliasing in its import statement, which ideally should result in a deduction in the score or at least a warning.\n\n3. **Affected Components or Systems:**\n   The issue specifically affects pylint, particularly the components responsible for analyzing import statements. The relevant components are located in `pylint/checkers/imports.py`, including functions such as `_make_graph`, `ImportsChecker.close`, `ImportsChecker.visit_importfrom`, and `ImportsChecker._check_deprecated_module`.\n\n4. **Potential Impact or Severity:**\n   While not critical, the issue impacts the quality of code analysis provided by pylint, potentially leading to missed opportunities for code improvement. It affects developers relying on pylint to enforce best practices in codebases, particularly concerning import statement management.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   - The problem is observed when using Python 3.6.3 with pylint version 1.8.4 and astroid 1.6.3.\n   - The default configuration of pylint is used, suggesting the issue might not be configuration-specific but rather inherent to the tool's analysis logic related to import statements.\n   - The redundant aliasing occurs in a simple import statement: `from collections import OrderedDict as OrderedDict`, which is flagged as acceptable by pylint when it arguably should not be.",
      "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: no complaints about \"from collections import OrderedDict as OrderedDict\"\n\nBody:\npylint does not complain if you use `import as` but don't change the name.\r\n\r\n### Steps to reproduce\r\nRun pylint on this file:\r\n```py\r\n\"\"\"frobnicate\"\"\"\r\n\r\nfrom collections import OrderedDict as OrderedDict\r\n\r\n\r\nSOME_DICT = OrderedDict()\r\n```\r\n\r\n### Current behavior\r\n\r\n10/10 rating\r\n\r\n### Expected behavior\r\n\r\nLess than 10/10 rating\r\n\r\n### pylint --version output\r\n\r\n```\r\nNo config file found, using default configuration\r\npylint 1.8.4, \r\nastroid 1.6.3\r\nPython 3.6.3 (default, Oct  3 2017, 21:45:48) \r\n[GCC 7.2.0]\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:\npylint/checkers/imports.py\n  function: _make_graph\n  function: ImportsChecker.close\n  function: ImportsChecker.visit_importfrom\n  function: ImportsChecker._check_deprecated_module\n"
    },
    {
      "similar_issue": {
        "issue_title": "Add a flag to disable config parsing",
        "issue_body": "### Current problem\r\n\r\nHere's a sample broken `.pylintrc`, placed in the root folder:\r\n\r\n```ini\r\n[pylint]\r\ntest = '%A'\r\n```\r\n\r\nThis is what happens when I try to use pylint now:\r\n```console\r\n$ pylint myfile.py\r\nTraceback (most recent call last):\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/bin/pylint\", line 8, in <module>\r\n    sys.exit(run_pylint())\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/__init__.py\", line 24, in run_pylint\r\n    PylintRun(sys.argv[1:])\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/lint/run.py\", line 324, in __init__\r\n    linter.load_config_file()\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/config/option_manager_mixin.py\", line 319, in load_config_file\r\n    for option, value in parser.items(section):\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 860, in items\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 860, in <listcomp>\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 856, in <lambda>\r\n    value_getter = lambda option: self._interpolation.before_get(self,\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 395, in before_get\r\n    self._interpolate_some(parser, option, L, value, section, defaults, 1)\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 442, in _interpolate_some\r\n    raise InterpolationSyntaxError(\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n\r\n$ pylint --help   \r\nTraceback (most recent call last):\r\n[...]\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n\r\n$ pylint       \r\nTraceback (most recent call last):\r\n[...]\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n```\r\n\r\nIs it possible to add a flag that disables config parsing entirely, so that the pylint isn't completely broken when this happens? `--ignore-config-file` for example?\r\n\r\nP.S. this is a feature I want, and I'd be willing to contribute it.",
        "issue_id": 5667,
        "pr_number": 6351,
        "pr_title": "Add exception handling for broken config files",
        "pr_body": "Extends the error handling of bad config files, to catch even more errors.\r\n\r\n## Type of Changes\r\n\r\n|     | Type                   |\r\n| --- | ---------------------- |\r\n| ✓   | :bug: Bug fix          |\r\n\r\n## Description\r\n\r\nCloses #5667\r\n",
        "issue_closed_at": "2022-04-15T20:15:52Z",
        "base_commit": "98bb5bf8ebf15fbce960533e5983a71351a1fe3f"
      },
      "summary": "### Summary:\nThis issue pertains to a problem encountered in the pylint tool when dealing with improperly formatted configuration files, specifically `.pylintrc` files. The existing configuration parsing mechanism in pylint fails gracefully when encountering syntax errors, such as malformed interpolations, within the configuration file. The error manifests as an unhandled `InterpolationSyntaxError` exception, which is raised during the attempt to parse configuration settings that contain incorrect formatting, such as a standalone '%' character not followed by the expected characters.\n\nKey symptoms and behaviors include traceback errors in the console output when attempting to run pylint commands, effectively rendering the tool unusable for any linting tasks when such a configuration error is present. The primary component affected is the configuration parsing functionality within pylint, particularly related to handling and interpreting configuration files.\n\nThe potential impact of this issue is significant, as it can cause complete operational failure of pylint, preventing users from running the tool until the configuration file is corrected. This affects developers who rely on pylint for code quality checks and could lead to delays or hindered development workflows.\n\nTo address this, a proposed solution involves introducing a feature to bypass configuration file parsing entirely through a command-line flag (e.g., `--ignore-config-file`). This would allow users to continue using pylint without being blocked by configuration file errors and provide a temporary workaround until configuration issues are resolved. The patch involves modifications to the configuration file parsing logic in `pylint/config/config_file_parser.py`, specifically within the `_ConfigurationFileParser.parse_config_file` function.",
      "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: Add a flag to disable config parsing\n\nBody:\n### Current problem\r\n\r\nHere's a sample broken `.pylintrc`, placed in the root folder:\r\n\r\n```ini\r\n[pylint]\r\ntest = '%A'\r\n```\r\n\r\nThis is what happens when I try to use pylint now:\r\n```console\r\n$ pylint myfile.py\r\nTraceback (most recent call last):\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/bin/pylint\", line 8, in <module>\r\n    sys.exit(run_pylint())\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/__init__.py\", line 24, in run_pylint\r\n    PylintRun(sys.argv[1:])\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/lint/run.py\", line 324, in __init__\r\n    linter.load_config_file()\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/config/option_manager_mixin.py\", line 319, in load_config_file\r\n    for option, value in parser.items(section):\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 860, in items\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 860, in <listcomp>\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 856, in <lambda>\r\n    value_getter = lambda option: self._interpolation.before_get(self,\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 395, in before_get\r\n    self._interpolate_some(parser, option, L, value, section, defaults, 1)\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 442, in _interpolate_some\r\n    raise InterpolationSyntaxError(\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n\r\n$ pylint --help   \r\nTraceback (most recent call last):\r\n[...]\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n\r\n$ pylint       \r\nTraceback (most recent call last):\r\n[...]\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n```\r\n\r\nIs it possible to add a flag that disables config parsing entirely, so that the pylint isn't completely broken when this happens? `--ignore-config-file` for example?\r\n\r\nP.S. this is a feature I want, and I'd be willing to contribute it.\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:\npylint/config/config_file_parser.py\n  function: _ConfigurationFileParser.parse_config_file\n"
    },
    {
      "similar_issue": {
        "issue_title": "Imports within TYPE_CHECKING can induce \"cyclic-import\"",
        "issue_body": "Suppose you have two modules: a.py and b.py.  `a` imports `b`, but `b` needs `a` in order to do type annotations, then this is usually done by importing `a` within a `TYPE_CHECKING` block.  Unfortunately, this causes pylint to report `cyclic-import`.\r\n\r\nPossibly related to https://github.com/PyCQA/pylint/issues/3285",
        "issue_id": 3525,
        "pr_number": 4703,
        "pr_title": "Fix cyclic import with TYPE_CHECKING",
        "pr_body": "## Description\r\nImports guarded by `typing.TYPE_CHECKING` should be added to the `excluded_edges` map so that they don't result in `cyclic-import` errors.\r\n\r\n## Type of Changes\r\n\r\n|     | Type                   |\r\n| --- | ---------------------- |\r\n| ✓   | :bug: Bug fix          |\r\n\r\n## Related Issue\r\nCloses #3525",
        "issue_closed_at": "2021-07-19T19:57:13Z",
        "base_commit": "3a6f08e4a1155e5098c3bec2d779cb3e654a1b11"
      },
      "summary": "### Summary:\nThis issue pertains to the problem of cyclic imports being reported by the static code analysis tool, pylint, when handling type annotations in Python code. Specifically, the problem arises when two Python modules depend on each other: one module (`a.py`) imports the other module (`b.py`) during runtime, while `b.py` requires importing `a.py` for type checking purposes. To facilitate this, developers typically use the `TYPE_CHECKING` construct to conditionally import `a.py` only when type checking is performed. However, this setup leads to pylint incorrectly flagging a `cyclic-import` error, which indicates that there is a circular dependency between the modules.\n\nKey symptoms and behaviors observed include pylint erroneously reporting a cyclic import due to the use of conditional imports for type annotations, which are not executed at runtime but are recognized during static analysis.\n\nThe affected components are the Python modules involved in the cyclic import scenario and the pylint tool itself, particularly its import checking functionality.\n\nThe potential impact of this issue is primarily on the development process, where developers may face unnecessary warnings or errors from pylint, potentially causing confusion or distraction. This could lead to developers spending additional time troubleshooting non-issues or making unnecessary changes to their code to suppress false positives.\n\nRelevant technical details include the use of the `TYPE_CHECKING` construct from the `typing` module in Python, which is designed to support conditional type imports without affecting runtime behavior. The issue likely stems from pylint's import checking logic not adequately differentiating between runtime imports and those used solely for type checking. The resolution involves updates to pylint's import checking functions, specifically the `_get_imported_module` and `_add_imported_module` functions within the `pylint/checkers/imports.py` file, to better handle this use case.",
      "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: Imports within TYPE_CHECKING can induce \"cyclic-import\"\n\nBody:\nSuppose you have two modules: a.py and b.py.  `a` imports `b`, but `b` needs `a` in order to do type annotations, then this is usually done by importing `a` within a `TYPE_CHECKING` block.  Unfortunately, this causes pylint to report `cyclic-import`.\r\n\r\nPossibly related to https://github.com/PyCQA/pylint/issues/3285\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:\npylint/checkers/imports.py\n  function: ImportsChecker._get_imported_module\n  function: ImportsChecker._add_imported_module\n  function: ImportsChecker._add_imported_module\n"
    },
    {
      "similar_issue": {
        "issue_title": "useless-type-doc issued for undocumented parameters that have PEP484 type annotations",
        "issue_body": "<!--\r\n  Hi there! Thank you for discovering and submitting an issue.\r\n\r\n  Before you submit this, make sure that the issue doesn't already exist\r\n  or if it is not closed.\r\n\r\n  Is your issue fixed on the preview release?:\r\n    pip install pylint astroid --pre -U\r\n-->\r\n\r\nThis likely relates to (and solves) issue #4117.\r\n\r\n### Steps to reproduce\r\n\r\nCall pylint with the docparams extension enabled on the following code:\r\n\r\n```python\r\n'''demonstrate FP with useless-type-doc'''\r\n\r\ndef function(public_param: int, _some_private_param: bool = False) -> None:\r\n    '''does things\r\n\r\n    Args:\r\n        public_param: an ordinary parameter\r\n    '''\r\n    for _ in range(public_param):\r\n        ...\r\n    if _some_private_param:\r\n        ...\r\n    else:\r\n        ...\r\n```\r\n\r\n### Current behavior\r\n\r\n```\r\n$ python3 -m pylint --load-plugins=pylint.extensions.docparams --rcfile=/dev/null bug.py\r\n************* Module bug\r\nbug.py:4:0: W9020: \"_some_private_param\" useless ignored parameter type documentation (useless-type-doc)\r\n\r\n------------------------------------------------------------------\r\nYour code has been rated at 8.33/10 (previous run: 5.00/10, +3.33)\r\n```\r\n\r\n### Expected behavior\r\n\r\nPylint should issue no errors.\r\n\r\nIt would be reasonable for pylint to issue this error if the type information appeared in the docstring, however, pylint is actually responding to the type annotation (as in PEP484). The docparams module should only issue errors in response to docstrings (or lack thereof), and not PEP484 annotations.\r\n\r\n### pylint --version output\r\n\r\nResult of `pylint --version` output:\r\n\r\n```\r\npylint 2.8.1\r\nastroid 2.5.6\r\nPython 3.8.3 (default, Jul  6 2020, 09:12:34)\r\n[Clang 10.0.1 (clang-1001.0.46.4)]\r\n```\r\n",
        "issue_id": 4593,
        "pr_number": 4614,
        "pr_title": "Fix false positive useless type annotation for pep484 typing",
        "pr_body": "## Description\r\n\r\nFix false positive ``useless-type-doc`` on ignored argument using ``pylint.extensions.docparams``\r\n  when a function was typed using pep484 but not inside the docstring.\r\n\r\n\r\n## Type of Changes\r\n\r\n<!-- Leave the corresponding lines for the applicable type of change: -->\r\n\r\n|     | Type                   |\r\n| --- | ---------------------- |\r\n| ✓   | :bug: Bug fix          |\r\n\r\n## Related Issue\r\n\r\n  Closes #4117\r\n  Closes #4593",
        "issue_closed_at": "2021-06-25T12:34:49Z",
        "base_commit": "bebdf9b3aee66c5d8937ed2a8993db398995c6b3"
      },
      "summary": "### Summary:\n\nThis issue is related to the Pylint tool, specifically when using the `docparams` extension. The problem arises when Pylint erroneously flags a warning for \"useless-type-doc\" on parameters that are documented with PEP484 type annotations but lack corresponding type information in their docstrings. The key symptom of this issue is the generation of a warning for parameters that have valid type annotations, suggesting that the type documentation is redundant or ignored, even though this is not the case. The affected components are the Pylint extensions responsible for checking documentation, particularly `_check_docs_utils.py` and `docparams.py`.\n\nThe potential impact includes false positives in code analysis, causing unnecessary noise in the user's feedback loop and potentially leading to confusion or incorrect modifications to the code base. The issue is considered of moderate severity as it affects the accuracy of static code analysis but does not impede functionality. \n\nThe technical details reveal that this issue is linked to how the `docparams` module interprets type annotations and docstring content, suggesting that the module should differentiate between PEP484 annotations and actual docstring content to avoid issuing incorrect warnings. The problem was isolated to specific functions and lines within the Pylint extension codebase, indicating a need for a targeted patch to correct the behavior.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: useless-type-doc issued for undocumented parameters that have PEP484 type annotations\n\nBody:\n<!--\r\n  Hi there! Thank you for discovering and submitting an issue.\r\n\r\n  Before you submit this, make sure that the issue doesn't already exist\r\n  or if it is not closed.\r\n\r\n  Is your issue fixed on the preview release?:\r\n    pip install pylint astroid --pre -U\r\n-->\r\n\r\nThis likely relates to (and solves) issue #4117.\r\n\r\n### Steps to reproduce\r\n\r\nCall pylint with the docparams extension enabled on the following code:\r\n\r\n```python\r\n'''demonstrate FP with useless-type-doc'''\r\n\r\ndef function(public_param: int, _some_private_param: bool = False) -> None:\r\n    '''does things\r\n\r\n    Args:\r\n        public_param: an ordinary parameter\r\n    '''\r\n    for _ in range(public_param):\r\n        ...\r\n    if _some_private_param:\r\n        ...\r\n    else:\r\n        ...\r\n```\r\n\r\n### Current behavior\r\n\r\n```\r\n$ python3 -m pylint --load-plugins=pylint.extensions.docparams --rcfile=/dev/null bug.py\r\n************* Module bug\r\nbug.py:4:0: W9020: \"_some_private_param\" useless ignored parameter type documentation (useless-type-doc)\r\n\r\n------------------------------------------------------------------\r\nYour code has been rated at 8.33/10 (previous run: 5.00/10, +3.33)\r\n```\r\n\r\n### Expected behavior\r\n\r\nPylint should issue no errors.\r\n\r\nIt would be reasonable for pylint to issue this error if the type information appeared in the docstring, however, pylint is actually responding to the type annotation (as in PEP484). The docparams module should only issue errors in response to docstrings (or lack thereof), and not PEP484 annotations.\r\n\r\n### pylint --version output\r\n\r\nResult of `pylint --version` output:\r\n\r\n```\r\npylint 2.8.1\r\nastroid 2.5.6\r\nPython 3.8.3 (default, Jul  6 2020, 09:12:34)\r\n[Clang 10.0.1 (clang-1001.0.46.4)]\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:\npylint/extensions/_check_docs_utils.py\n  function: Docstring.__init__\n\npylint/extensions/docparams.py\n  line: line 23\n  function: DocstringParameterChecker._compare_ignored_args\n"
    },
    {
      "similar_issue": {
        "issue_title": "pylint custom configuration overrides plugin defaults settings.",
        "issue_body": "pylint overrides default configuration set by plugins using parameters set by rc file or command line arguments:\r\nhttps://github.com/PyCQA/pylint/blob/fcc01516ae176ad3fdedc4497328105f3314e376/pylint/lint.py#L1568-L1571\r\n\r\npylint-django extends good-names in `register()` method [1]:\r\n```python\r\n    name_checker = get_checker(linter, NameChecker)\r\n    name_checker.config.good_names += ('qs', 'urlpatterns', 'register', 'app_name', 'handler500')\r\n    # we don't care about South migrations\r\n    linter.config.black_list += ('migrations', 'south_migrations')\r\n```\r\n\r\nCurrently plugin is not able to avoid overriding of configuration. pylint should provide a hook for plugins which is executed *after* configuration is set. Currently there are multiple open issues in pylint-django project affected by this defect: \r\n* https://github.com/PyCQA/pylint-django/issues/181 \r\n* https://github.com/PyCQA/pylint-django/issues/167\r\n\r\n### Steps to reproduce\r\n1. Install django and pylint-django using pip\r\n2. Create empty project: `django-admin startproject myproject`\r\n3. Execute pylint with pylint-django plugin and with default configuration:\r\n```\r\npylint --load-plugins=pylint_django myproject/myproject/urls.py\r\n\r\n------------------------------------\r\nYour code has been rated at 10.00/10\r\n```\r\n4. Execute pylint with django-pylint and custom configuration:\r\n```\r\npylint --load-plugins=pylint_django --good-names=foo,bar  myproject/myproject/urls.py\r\n\r\n************* Module myproject.urls\r\nmyproject/myproject/urls.py:19:0: C0103: Constant name \"urlpatterns\" doesn't conform to UPPER_CASE naming style (invalid-name)\r\n\r\n-------------------------------------------------------------------\r\nYour code has been rated at 6.67/10 (previous run: 10.00/10, -3.33)\r\n```\r\n### Current behavior\r\nCurrently, configuration provided by pylint-django is overriden by custom configuration (see [1] pylint-django configuration)\r\n\r\n### Expected behavior\r\nCustom configuration should not override pylint-django customization\r\n\r\n### pylint --version output\r\npylint 2.1.1\r\nastroid 2.0.4\r\nPython 3.6.4 (default, Jan  7 2018, 15:53:53)\r\n[GCC 6.4.0]\r\n\r\n[1] https://github.com/PyCQA/pylint-django/blob/c5b5bfdef66453575074b36018ee716411bcb0a4/pylint_django/plugin.py#L18-L22\r\n",
        "issue_id": 2635,
        "pr_number": 2644,
        "pr_title": "Load plugin configuration hook",
        "pr_body": "<!--\r\n\r\nThank you for submitting a PR to pylint!\r\n\r\nTo ease the process of reviewing your PR, do make sure to complete the following boxes.\r\n\r\nYou can also read more about contributing to pylint in this document:\r\nhttps://github.com/PyCQA/pylint/blob/master/doc/development_guide/contribute.rst#repository\r\n-->\r\n\r\n## Steps\r\n\r\n- [✓] Add yourself to CONTRIBUTORS if you are a new contributor.\r\n- [✓] Add a ChangeLog entry describing what your PR does.\r\n- [✓] If it's a new feature or an important bug fix, add a What's New entry in `doc/whatsnew/<current release.rst>`.\r\n- [✓] Write a good description on what the PR does.\r\n\r\n## Description\r\n\r\nAdded ``load_configuration()`` hook for plugins.\r\n    \r\nNew optional hook for plugins is added: ``load_configuration()``. This hook is called by pylint after configuration is loaded to prevent against overwriting plugin specific configuration via user-based configuration. Plugins are supposed to adjust configuration e.g. by extending ``good_names`` or extending ``black_list``, etc...\r\n\r\n\r\n## Type of Changes\r\n<!-- Leave the corresponding lines for the applicable type of change: -->\r\n|   | Type |\r\n| ------------- | ------------- |\r\n| ✓ | :bug: Bug fix  |\r\n| ✓ | :sparkles: New feature |\r\n|    | :hammer: Refactoring  |\r\n| ✓ | :scroll: Docs |\r\n\r\n## Related Issue\r\nCloses #2635  \r\n<!-- \r\nIf this PR fixes a particular issue, use the following to automatically close that issue\r\nonce this PR gets merged:\r\n\r\nCloses ####\r\n-->\r\n",
        "issue_closed_at": "2018-12-20T08:11:51Z",
        "base_commit": "75cecdb1b88cc759223e83fd325aeafd09fec37e"
      },
      "summary": "### Summary:\n\nThis issue pertains to a configuration management problem within the `pylint` tool when used in conjunction with plugins, specifically `pylint-django`. The problem arises because custom configurations provided through an rc file or command line arguments are overriding the default settings set by the plugins, which is not the intended behavior. \n\n1. **Problem Description in General Terms:** \n   The core issue is that custom configurations specified by the user can inadvertently override plugin-specific configurations. This is particularly problematic in scenarios where plugins are designed to extend or modify default configurations to better suit specific environments or frameworks (such as Django in this case).\n\n2. **Key Symptoms and Behaviors Observed:** \n   - When executing `pylint` with the `pylint-django` plugin and no custom configurations, the code is rated perfectly (10.00/10).\n   - However, when a custom configuration is applied, the plugin's configuration is overridden, leading to unexpected linting results, such as warnings about naming conventions that should have been suppressed by the plugin.\n\n3. **Affected Components or Systems:** \n   - The issue affects the `pylint` tool, specifically its ability to execute plugins like `pylint-django` correctly without interference from user-defined configurations.\n   - The `pylint-django` plugin, which extends certain naming conventions and ignores specific files, is directly impacted.\n\n4. **Potential Impact or Severity:**\n   - The impact of this issue is significant for developers relying on `pylint` plugins to provide framework-specific linting rules. It can lead to inaccurate linting results, potentially affecting code quality assessments and developer workflows.\n   - Multiple open issues in the `pylint-django` project highlight the severity and urgency of resolving this problem.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   - The issue arises because `pylint` does not provide a mechanism or hook for plugins to enforce their configurations after the user's custom configurations have been applied.\n   - The proposed solution involves implementing such a hook to ensure plugin configurations are preserved, maintaining the integrity of the plugin's intended functionality.\n\nIn summary, this issue highlights a critical gap in `pylint`'s configuration management system when using plugins, necessitating a modification to ensure plugin settings are not overridden by custom 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: pylint custom configuration overrides plugin defaults settings.\n\nBody:\npylint overrides default configuration set by plugins using parameters set by rc file or command line arguments:\r\nhttps://github.com/PyCQA/pylint/blob/fcc01516ae176ad3fdedc4497328105f3314e376/pylint/lint.py#L1568-L1571\r\n\r\npylint-django extends good-names in `register()` method [1]:\r\n```python\r\n    name_checker = get_checker(linter, NameChecker)\r\n    name_checker.config.good_names += ('qs', 'urlpatterns', 'register', 'app_name', 'handler500')\r\n    # we don't care about South migrations\r\n    linter.config.black_list += ('migrations', 'south_migrations')\r\n```\r\n\r\nCurrently plugin is not able to avoid overriding of configuration. pylint should provide a hook for plugins which is executed *after* configuration is set. Currently there are multiple open issues in pylint-django project affected by this defect: \r\n* https://github.com/PyCQA/pylint-django/issues/181 \r\n* https://github.com/PyCQA/pylint-django/issues/167\r\n\r\n### Steps to reproduce\r\n1. Install django and pylint-django using pip\r\n2. Create empty project: `django-admin startproject myproject`\r\n3. Execute pylint with pylint-django plugin and with default configuration:\r\n```\r\npylint --load-plugins=pylint_django myproject/myproject/urls.py\r\n\r\n------------------------------------\r\nYour code has been rated at 10.00/10\r\n```\r\n4. Execute pylint with django-pylint and custom configuration:\r\n```\r\npylint --load-plugins=pylint_django --good-names=foo,bar  myproject/myproject/urls.py\r\n\r\n************* Module myproject.urls\r\nmyproject/myproject/urls.py:19:0: C0103: Constant name \"urlpatterns\" doesn't conform to UPPER_CASE naming style (invalid-name)\r\n\r\n-------------------------------------------------------------------\r\nYour code has been rated at 6.67/10 (previous run: 10.00/10, -3.33)\r\n```\r\n### Current behavior\r\nCurrently, configuration provided by pylint-django is overriden by custom configuration (see [1] pylint-django configuration)\r\n\r\n### Expected behavior\r\nCustom configuration should not override pylint-django customization\r\n\r\n### pylint --version output\r\npylint 2.1.1\r\nastroid 2.0.4\r\nPython 3.6.4 (default, Jan  7 2018, 15:53:53)\r\n[GCC 6.4.0]\r\n\r\n[1] https://github.com/PyCQA/pylint-django/blob/c5b5bfdef66453575074b36018ee716411bcb0a4/pylint_django/plugin.py#L18-L22\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:\npylint/lint.py\n  function: ChildLinter._run_linter\n  function: PyLinter.load_plugin_modules\n  function: Run.__init__\n  function: Run.__init__\n"
    }
  ]
}