{
  "id": "sqlfluff__sqlfluff-5074",
  "question": "Inconsistent output depending on --processes flag when --ignore linting is used\n### Search before asking\n\n- [X] I searched the [issues](https://github.com/sqlfluff/sqlfluff/issues) and found no similar issues.\n\n\n### What Happened\n\nDepending on the value you set for the `--processes` flag when also using `--ignore linting`, different output with different exit codes are generated.\n\n### Expected Behaviour\n\nThe same exit code should be generated, independently of the `--processes` flag. Furthermore, from https://docs.sqlfluff.com/en/stable/production.html#using-sqlfluff-on-a-whole-sql-codebase I would expect that exit codes should be either `0` or `65`, not `1`.\n\n### Observed Behaviour\n\nSee the How to reproduce section.\n\n### How to reproduce\n\nCreate a `test.sql` file with the following content:\r\n\r\n```SQL\r\nCREATE TABLE example (\r\n    id TEXT DEFAULT 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. In condimentum congue est, ac orci aliquam.' PRIMARY KEY\r\n);\r\n```\r\n\r\nThe line is too long according to SQLFluff, caused by the large default value, so let's see the the output of SQLFluff.\r\n\r\nRunning\r\n\r\n```SHELL\r\nsqlfluff fix --dialect postgres --ignore linting --processes 2\r\n```\r\n\r\nresults in \r\n\r\n```\r\n==== finding fixable violations ====\r\n==== no fixable linting violations found ====                                                                                                                                                                      \r\nAll Finished 📜 🎉!\r\n  [1 unfixable linting violations found]\r\n```\r\n\r\nwith exit code `1`. Running the same with one process instead:\r\n\r\n```SHELL\r\nsqlfluff fix --dialect postgres --ignore linting --processes 1\r\n```\r\n\r\nresults in\r\n\r\n```\r\n==== finding fixable violations ====\r\n==== no fixable linting violations found ====                                                                                                                                                                      \r\nAll Finished 📜 🎉!\r\n```\r\n\r\nand exit code `0`\r\n\r\nSame behaviour for `lint` and `format` commands.\n\n### Dialect\n\nPostgres\n\n### Version\n\n2.2.0, Python 3.10.6\n\n### Configuration\n\nNone, it's all in the CLI flags.\n\n### Are you willing to work on and submit a PR to address the issue?\n\n- [ ] Yes I am willing to submit a PR!\n\n### Code of Conduct\n\n- [X] I agree to follow this project's [Code of Conduct](https://github.com/sqlfluff/sqlfluff/blob/main/CODE_OF_CONDUCT.md)\n\n",
  "answer": "{\"task_id\": \"8960bf63-8a63-4cd3-ba5a-60b8cf70223e\", \"workflow_run_id\": \"cac8d130-a08f-4384-815c-a3e83bd248ed\", \"data\": {\"id\": \"cac8d130-a08f-4384-815c-a3e83bd248ed\", \"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/linter/linter.py b/src/sqlfluff/core/linter/linter.py\\\\nindex 3c4f3e1..7a8c9f2 100644\\\\n--- a/src/sqlfluff/core/linter/linter.py\\\\n+++ b/src/sqlfluff/core/linter/linter.py\\\\n@@ -467,7 +467,9 @@ class Linter:\\\\n             tasks = [(fc, config) for fc in self.file_cache]\\\\n             results = []\\\\n \\\\n-            for task_result in pool.starmap(self.lint_paths, tasks):\\\\n+            for task_result in pool.starmap(self.lint_paths, tasks):\\\\n+                # Apply ignore rules before aggregating results\\\\n+                task_result = [res for res in task_result if not res.ignore]\\\\n                 result.add(task_result)\\\\n \\\\n             # Close the pool to prevent any new tasks from being submitted\\\\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 correctly addresses the issue by filtering out ignored violations before aggregating results in a multi-threaded environment. It ensures consistent behavior across different processing modes and minimizes the risk of introducing new bugs.\\\",\\n      \\\"recommendation\\\": \\\"Highly recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 3,\\n      \\\"patch\\\": \\\"diff --git a/src/sqlfluff/core/linter/linting_result.py b/src/sqlfluff/core/linter/linting_result.py\\\\nindex 4eb2d33..5dc9e71 100644\\\\n--- a/src/sqlfluff/core/linter/linting_result.py\\\\n+++ b/src/sqlfluff/core/linter/linting_result.py\\\\n@@ -75,7 +75,9 @@ class LintingResult:\\\\n             key=lambda v: v.line_no + (0.1 if v.type == \\\\\\\"fixable\\\\\\\" else 0)\\\\n         )\\\\n \\\\n-        for v in new_violations:\\\\n+        # Filter out ignored violations before adding\\\\n+        filtered_violations = [v for v in new_violations if not v.ignore]\\\\n+        for v in filtered_violations:\\\\n             self.added.add(repr(v))  # pragma: no cover\\\\n             self.violations.append(v)\\\\n\\\",\\n      \\\"rank\\\": 2,\\n      \\\"score\\\": 0.9,\\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 filters out ignored violations before adding them to the linting result, ensuring that only relevant violations are considered. It is a solid approach but slightly less direct than patch 1 in addressing the specific issue.\\\",\\n      \\\"recommendation\\\": \\\"Recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 4,\\n      \\\"patch\\\": \\\"diff --git a/src/sqlfluff/cli/commands.py b/src/sqlfluff/cli/commands.py\\\\nindex 232c3ef..3bf9e76 100644\\\\n--- a/src/sqlfluff/cli/commands.py\\\\n+++ b/src/sqlfluff/cli/commands.py\\\\n@@ -216,6 +216,8 @@ def fix_command(config, paths, code_only=False, fix=False):\\\\n     click.echo(\\\\\\\"==== finding fixable violations ====\\\\\\\")\\\\n     result = linter.lint_paths(paths, fix=fix)\\\\n \\\\n+    # Ensure consistent ignore rule application\\\\n+    result.violations = [v for v in result.violations if not v.ignore]\\\\n     return_code, _ = interpret_result(result, verbose)\\\\n \\\\n     if return_code:\\\\n\\\",\\n      \\\"rank\\\": 3,\\n      \\\"score\\\": 0.85,\\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 ensures consistent ignore rule application at the command level, which is effective but may not address all underlying inconsistencies in the processing logic.\\\",\\n      \\\"recommendation\\\": \\\"Moderately recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 2,\\n      \\\"patch\\\": \\\"diff --git a/src/sqlfluff/core/linter/linted_file.py b/src/sqlfluff/core/linter/linted_file.py\\\\nindex d123e4f..b43265d 100644\\\\n--- a/src/sqlfluff/core/linter/linted_file.py\\\\n+++ b/src/sqlfluff/core/linter/linted_file.py\\\\n@@ -130,7 +130,7 @@ class LintedFile:\\\\n \\\\n     def get_violations(self, rules=None):\\\\n         \\\\\\\"\\\\\\\"\\\\\\\"Obtain the violations, with filtering on rules and ignore options.\\\\\\\"\\\\\\\"\\\\\\\"\\\\n-        return [v for v in self.violations if v.ignore is False]\\\\n+        return [v for v in self.violations if not v.ignore]\\\\n \\\\n \\\\n # Result storage for SQLFluff\\\\n\\\",\\n      \\\"rank\\\": 4,\\n      \\\"score\\\": 0.8,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.75,\\n        \\\"code_quality\\\": 0.8,\\n        \\\"risk_level\\\": 0.25,\\n        \\\"best_practices\\\": 0.75,\\n        \\\"test_coverage\\\": 0.7\\n      },\\n      \\\"reasoning\\\": \\\"This patch modifies the filtering logic in the LintedFile class, which is a minor improvement in code readability but does not directly address the multi-threading issue. It is the least effective in solving the problem at hand.\\\",\\n      \\\"recommendation\\\": \\\"Least recommended\\\"\\n    }\\n  ],\\n  \\\"evaluation_summary\\\": \\\"Patch 1 is the most effective solution, directly addressing the issue by ensuring consistent filtering of ignored violations in a multi-threaded environment. Patch 3 also provides a good solution by filtering violations before adding them to the result, but it is slightly less direct. Patch 4 addresses the issue at the command level, which is less comprehensive. Patch 2 offers a minor improvement in code readability but does not effectively solve the problem.\\\"\\n}\\n```\", \"generated_tests\": \"{\\n  \\\"reproduction_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_reproduce_issue_multi_processes\\\",\\n      \\\"test_code\\\": \\\"def test_reproduce_issue_multi_processes():\\\\n    # Test SQL file content with long line creating linting violation\\\\n    # Run 'sqlfluff fix' with '--processes 2 --ignore linting' flags\\\\n    # Assert that the exit code is 1\\\\n    # This should reproduce the original issue where different exit codes are generated based on '--processes' flag\\\",\\n      \\\"description\\\": \\\"Reproduce the issue by running 'sqlfluff fix' with '--processes 2' flag\\\",\\n      \\\"expected_behavior\\\": \\\"The test should fail with exit code 1 as per the original issue\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_reproduce_issue_single_process\\\",\\n      \\\"test_code\\\": \\\"def test_reproduce_issue_single_process():\\\\n    # Test SQL file content with long line creating linting violation\\\\n    # Run 'sqlfluff fix' with '--processes 1 --ignore linting' flags\\\\n    # Assert that the exit code is 0\\\\n    # This should reproduce the original issue where different exit codes are generated based on '--processes' flag\\\",\\n      \\\"description\\\": \\\"Reproduce the issue by running 'sqlfluff fix' with '--processes 1' flag\\\",\\n      \\\"expected_behavior\\\": \\\"The test should pass with exit code 0 as per the original issue\\\"\\n    }\\n  ],\\n  \\\"validation_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_patch_validation_p1\\\",\\n      \\\"test_code\\\": \\\"def test_patch_validation_p1():\\\\n    # Create a linted SQL file\\\\n    # Apply ignore linting rules\\\\n    # Apply the first patch across relevant sections\\\\n    # Verify that ignored violations are filtered correctly before aggregating results\\\\n    # Assert that only non-ignored violations are included in the final result\\\",\\n      \\\"description\\\": \\\"Validate the first patch which ensures consistent ignore rule application\\\",\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_patch_validation_p2\\\",\\n      \\\"test_code\\\": \\\"def test_patch_validation_p2():\\\\n    # Create a linted SQL file\\\\n    # Apply ignore linting rules\\\\n    # Apply the second patch across relevant sections\\\\n    # Verify that ignored violations are filtered correctly within LintedFile class\\\\n    # Assert that only non-ignored violations are returned when getting violations\\\",\\n      \\\"description\\\": \\\"Validate the second patch which ensures consistent ignore rule application in LintedFile class\\\",\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_patch_validation_p3\\\",\\n      \\\"test_code\\\": \\\"def test_patch_validation_p3():\\\\n    # Create a linted SQL file with new violations\\\\n    # Apply ignore linting rules\\\\n    # Apply the third patch across relevant sections\\\\n    # Verify that ignored violations are filtered correctly before adding new violations\\\\n    # Assert that only non-ignored violations are added to the linting result\\\",\\n      \\\"description\\\": \\\"Validate the third patch which ensures filtering out ignored violations before adding to linting result\\\",\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_patch_validation_p4\\\",\\n      \\\"test_code\\\": \\\"def test_patch_validation_p4():\\\\n    # Set up linting process with ignore rules in place\\\\n    # Apply the fourth patch in the fix_command function\\\\n    # Confirm that the exit state is correctly set based on consistent filtering of violations\\\\n    # Assert that the program exits with the correct exit code\\\",\\n      \\\"description\\\": \\\"Validate the fourth patch which ensures consistent ignore rule application in fix_command function\\\",\\n    }\\n  ],\\n  \\\"test_summary\\\": \\\"The reproduction tests aim to recreate the original issue by running 'sqlfluff fix' with different '--processes' flags and observing the generated exit codes. The validation tests focus on applying the provided patches to ensure that ignored violations are filtered consistently across processing modes, thereby validating the fixes.\\\"\\n}\"}, \"error\": \"\", \"elapsed_time\": 352.278202, \"total_tokens\": 25776, \"total_steps\": 9, \"created_at\": 1753333285, \"finished_at\": 1753333638}}"
}