{
  "id": "sqlfluff__sqlfluff-2386",
  "question": "Double backticks in Lint description\n![image](https://user-images.githubusercontent.com/80432516/150420352-57452c80-ad25-423b-8251-645e541579ad.png)\r\n(n.b. this affects a lot more rules than L051)\r\n\r\nThis was introduced in #2234 in which docstrings such as\r\n```\r\n`INNER JOIN` must be fully qualified.\r\n```\r\nwere replaced with \r\n```\r\n``INNER JOIN`` must be fully qualified.\r\n```\r\nso that they appear as code blocks in Sphinx for docs.\r\n![image](https://user-images.githubusercontent.com/80432516/150420294-eb9d3127-db1d-457c-a637-d614e0267277.png)\r\n\r\nHowever, our rules will use the first line of these docstrings in the event that no `description` is provided to the lint results.\r\n\r\nThis doesn't look great on the CLI so we should fix this. As far as I'm aware there are two approaches for this:\r\n1. Pass a `description` to all the `LintResult`s.\r\n2. Update the code that gets the default description from the docstring to do something like, replace the double backticks with a single one, or remove them, or do something clever like make them bold for the CLI and remove them for non-CLI.\r\n\r\nMy strong preference is number 2, but I'm open to discussion as to how exactly we do this 😄 \r\n\r\n@barrywhart @tunetheweb \n",
  "answer": "{\"task_id\": \"20f3873a-254c-41f1-8559-1561e59c8023\", \"workflow_run_id\": \"3ce39124-7a86-4e5e-a8b3-7b378feee35e\", \"data\": {\"id\": \"3ce39124-7a86-4e5e-a8b3-7b378feee35e\", \"workflow_id\": \"bc5a1a30-852f-4fd7-98f0-8fca2f23c564\", \"status\": \"succeeded\", \"outputs\": {\"ranked_patches\": \"```json\\n{\\n  \\\"ranked_patches\\\": [\\n    {\\n      \\\"patch_id\\\": 1,\\n      \\\"patch\\\": \\\"diff --git a/src/sqlfluff/core/rules/base.py b/src/sqlfluff/core/rules/base.py\\\\nindex a0f480c..c852e5e 100644\\\\n--- a/src/sqlfluff/core/rules/base.py\\\\n+++ b/src/sqlfluff/core/rules/base.py\\\\n@@ -47,7 +47,7 @@ class BaseRule:\\\\n         Return the description of the rule.\\\\n         If no explicit description present, use the docstring.\\\\n         \\\\\\\"\\\\\\\"\\\\\\\"\\\\n-        return self._description or self.__doc__.strip()\\\\n+        return self._description or self.__doc__.strip().replace(\\\\\\\"``\\\\\\\", \\\\\\\"`\\\\\\\")\\\\n \\\\n     @property\\\\n     def description(self):\\\\n\\\",\\n      \\\"rank\\\": 1,\\n      \\\"score\\\": 0.95,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.9,\\n        \\\"code_quality\\\": 0.95,\\n        \\\"risk_level\\\": 0.1,\\n        \\\"best_practices\\\": 0.9,\\n        \\\"test_coverage\\\": 0.85\\n      },\\n      \\\"reasoning\\\": \\\"This patch directly addresses the issue by replacing double backticks with single backticks in the BaseRule description property. It is a straightforward and low-risk solution that aligns with the preferred approach of modifying the default description extraction.\\\",\\n      \\\"recommendation\\\": \\\"Highly recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 3,\\n      \\\"patch\\\": \\\"diff --git a/src/sqlfluff/core/linter/linter.py b/src/sqlfluff/core/linter/linter.py\\\\nindex 9df5c62..0c2e7d5 100644\\\\n--- a/src/sqlfluff/core/linter/linter.py\\\\n+++ b/src/sqlfluff/core/linter/linter.py\\\\n@@ -214,7 +214,10 @@ class Linter:\\\\n         # Load config\\\\n         config = config or self.config.get_section(\\\\\\\"rules\\\\\\\")\\\\n\\\\n+        def clean_description(description):\\\\n+            return description.replace(\\\\\\\"``\\\\\\\", \\\\\\\"`\\\\\\\")\\\\n+\\\\n         for found in self.sql_base_file_loader(sql_file_reference):\\\\n             # Find the ruleset\\\\n             blocked = False\\\\n@@ -223,7 +226,7 @@ class Linter:\\\\n                 if not res.source:\\\\n                     # Set some of the attributes of the result\\\\n                     found.result_description = (\\\\n-                        res.rule.description[:100] if res.rule.description else None\\\\n+                        clean_description(res.rule.description[:100]) if res.rule.description else None\\\\n                     )\\\\n                     # Only set this if we don't already have it\\\\n                     found = found.copy()\\\\n\\\",\\n      \\\"rank\\\": 2,\\n      \\\"score\\\": 0.85,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.85,\\n        \\\"code_quality\\\": 0.9,\\n        \\\"risk_level\\\": 0.15,\\n        \\\"best_practices\\\": 0.85,\\n        \\\"test_coverage\\\": 0.8\\n      },\\n      \\\"reasoning\\\": \\\"This patch introduces a helper function to clean the description when setting it in the Linter class. It effectively addresses the issue but adds a bit more complexity compared to patch 1.\\\",\\n      \\\"recommendation\\\": \\\"Recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 4,\\n      \\\"patch\\\": \\\"diff --git a/src/sqlfluff/cli/formatters.py b/src/sqlfluff/cli/formatters.py\\\\nindex 2d4f8ab..3f4e91b 100644\\\\n--- a/src/sqlfluff/cli/formatters.py\\\\n+++ b/src/sqlfluff/cli/formatters.py\\\\n@@ -78,6 +78,9 @@ def format_violation(violation: SQLLintViolation) -> str:\\\\n     \\\\\\\"\\\\\\\"\\\\\\\"\\\\n     Format a violation for output in the cli.\\\\n     \\\\\\\"\\\\\\\"\\\\\\\"\\\\n+\\\\n+    def clean_description(description):\\\\n+        return description.replace(\\\\\\\"``\\\\\\\", \\\\\\\"`\\\\\\\")\\\\n\\\\n     pos_txt = \\\\\\\"{: >6} | {: >4}:\\\\\\\".format(violation.line_no, violation.line_pos)\\\\n     rule_txt = \\\\\\\"{:6} | \\\\\\\"\\\\\\\".format(violation.rule)\\\\n@@ -86,7 +89,7 @@ def format_violation(violation: SQLLintViolation) -> str:\\\\n     display_text = violation.description\\\\n     if violation.line_pos is not None:\\\\n         display_text += \\\\\\\" [{},{}]\\\\\\\".format(violation.line_no, violation.line_pos)\\\\n-    message = \\\\\\\"{}{} {}\\\\\\\".format(pos_txt, rule_txt, display_text)\\\\n+    message = \\\\\\\"{}{} {}\\\\\\\".format(pos_txt, rule_txt, clean_description(display_text))\\\\n     return message\\\\n \\\\n \\\\n\\\",\\n      \\\"rank\\\": 3,\\n      \\\"score\\\": 0.8,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.8,\\n        \\\"code_quality\\\": 0.85,\\n        \\\"risk_level\\\": 0.2,\\n        \\\"best_practices\\\": 0.8,\\n        \\\"test_coverage\\\": 0.75\\n      },\\n      \\\"reasoning\\\": \\\"This patch modifies the CLI formatter to clean descriptions before outputting them. While it addresses the issue for CLI output, it doesn't solve the problem at the source, making it less comprehensive.\\\",\\n      \\\"recommendation\\\": \\\"Consider if CLI-specific formatting is needed\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 2,\\n      \\\"patch\\\": \\\"diff --git a/src/sqlfluff/core/rules/base.py b/src/sqlfluff/core/rules/base.py\\\\nindex a0f480c..9c852e3 100644\\\\n--- a/src/sqlfluff/core/rules/base.py\\\\n+++ b/src/sqlfluff/core/rules/base.py\\\\n@@ -47,7 +47,7 @@ class BaseRule:\\\\n         Return the description of the rule.\\\\n         If no explicit description present, use the docstring.\\\\n         \\\\\\\"\\\\\\\"\\\\\\\"\\\\n-        return self._description or self.__doc__.strip()\\\\n+        return self._description or self.__doc__.strip().replace(\\\\\\\"``\\\\\\\", \\\\\\\"\\\\\\\")\\\\n \\\\n     @property\\\\n     def description(self):\\\\n\\\",\\n      \\\"rank\\\": 4,\\n      \\\"score\\\": 0.7,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.7,\\n        \\\"code_quality\\\": 0.75,\\n        \\\"risk_level\\\": 0.25,\\n        \\\"best_practices\\\": 0.7,\\n        \\\"test_coverage\\\": 0.7\\n      },\\n      \\\"reasoning\\\": \\\"This patch removes double backticks entirely, which may not be the desired behavior as it could alter the intended emphasis or formatting of the text. It is less aligned with the original intent of the docstring formatting.\\\",\\n      \\\"recommendation\\\": \\\"Not recommended unless removal is acceptable\\\"\\n    }\\n  ],\\n  \\\"evaluation_summary\\\": \\\"Patch 1 is the best solution as it directly addresses the issue by replacing double backticks with single backticks in the BaseRule description property, maintaining the intended formatting. Patch 3 is a good alternative but adds complexity by introducing a helper function. Patch 4 addresses the issue at the CLI level, which is less comprehensive. Patch 2 removes double backticks entirely, which may not preserve the intended formatting.\\\"\\n}\\n```\", \"generated_tests\": \"{\\n  \\\"reproduction_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_reproduce_original_issue\\\",\\n      \\\"test_code\\\": \\\"def test_reproduce_original_issue():\\\\n    # Original issue: double backticks in Lint description causing formatting problem\\\\n    sample_description = '``INNER JOIN`` must be fully qualified.'\\\\n    rule = BaseRule()\\\\n    rule._description = sample_description\\\\n    assert rule.description == '`INNER JOIN` must be fully qualified.'\\\",\\n      \\\"description\\\": \\\"This test reproduces the original issue of double backticks in the lint description\\\",\\n      \\\"expected_behavior\\\": \\\"The test should fail before applying the patches and pass after applying the patches\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_edge_case_1\\\",\\n      \\\"test_code\\\": \\\"def test_edge_case_1():\\\\n    # Test with a description containing multiple double backticks\\\\n    sample_description = '``This is a ``test`` with multiple ``backticks``.`'\\\\n    rule = BaseRule()\\\\n    rule._description = sample_description\\\\n    assert rule.description == '`This is a `test` with multiple `backticks`.`'\\\",\\n      \\\"description\\\": \\\"Edge case test with multiple double backticks in the lint description\\\",\\n      \\\"expected_behavior\\\": \\\"The test should fail before applying the patches and pass after applying the patches\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_edge_case_2\\\",\\n      \\\"test_code\\\": \\\"def test_edge_case_2():\\\\n    # Test with no explicit description provided, only using docstring\\\\n    class TestRule(BaseRule):\\\\n        \\\\\\\"\\\\\\\"\\\\\\\"``This is a test with no explicit description``\\\\\\\"\\\\\\\"\\\\\\\"\\\\n    rule = TestRule()\\\\n    assert rule.description == '`This is a test with no explicit description`'\\\",\\n      \\\"description\\\": \\\"Edge case test where no explicit description is provided, using docstring with double backticks\\\",\\n      \\\"expected_behavior\\\": \\\"The test should fail before applying the patches and pass after applying the patches\\\"\\n    }\\n  ],\\n  \\\"validation_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_patch_validation\\\",\\n      \\\"test_code\\\": \\\"def test_patch_validation():\\\\n    # Test to validate that the patches fix the double backticks issue\\\\n    rule = BaseRule()\\\\n    sample_description = '``INNER JOIN`` must be fully qualified.'\\\\n    rule._description = sample_description\\\\n    assert rule.description == '`INNER JOIN` must be fully qualified.'\\\",\\n      \\\"description\\\": \\\"This test validates that the patches work correctly to replace double backticks with single backticks\\\"\\n    }\\n  ],\\n  \\\"test_summary\\\": \\\"Generated reproduction and validation tests for the original issue related to double backticks in the lint description.\\\"\\n}\"}, \"error\": \"\", \"elapsed_time\": 467.337547, \"total_tokens\": 27858, \"total_steps\": 9, \"created_at\": 1753344451, \"finished_at\": 1753344919}}"
}