{
  "id": "sqlfluff__sqlfluff-3662",
  "question": "Number of processes configurable in .sqlfluff\nBeing able to set the number of processes to run with in .sqlfluff might be useful to avoid having to pass it in the CLI every time.\n",
  "answer": "{\"task_id\": \"a3562974-9eae-414f-9728-9277cedf9d7b\", \"workflow_run_id\": \"a69e7fcd-e6a9-431b-985a-7e210d764a5a\", \"data\": {\"id\": \"a69e7fcd-e6a9-431b-985a-7e210d764a5a\", \"workflow_id\": \"bc5a1a30-852f-4fd7-98f0-8fca2f23c564\", \"status\": \"succeeded\", \"outputs\": {\"ranked_patches\": \"```json\\n{\\n  \\\"ranked_patches\\\": [\\n    {\\n      \\\"patch_id\\\": 3,\\n      \\\"patch\\\": \\\"diff --git a/src/sqlfluff/core/config.py b/src/sqlfluff/core/config.py\\\\nindex 0399d3a..552d4ef 100644\\\\n--- a/src/sqlfluff/core/config.py\\\\n+++ b/src/sqlfluff/core/config.py\\\\n@@ -46,6 +46,7 @@ class FluffConfig:\\\\n         \\\\\\\"\\\\\\\"\\\\\\\"\\\\n         self._config = config\\\\n         self._overrides = overrides or {}\\\\n+        self.processes = self._get(\\\\\\\"processes\\\\\\\", default=4)  # Default value of 4 processes\\\\n\\\\n     @staticmethod\\\\n     def load_config_from_file(cls, file_path: str) -> dict:\\\\n@@ -122,6 +123,10 @@ def load_config_from_file(cls, file_path: str) -> dict:\\\\n             denormalized_path = os.path.abspath(file_path)\\\\n             config = loader.load_config_at_path(denormalized_path)\\\\n             loaded_config.update(config)\\\\n+            # Set 'processes' if present in the config file\\\\n+            if 'processes' in config:\\\\n+                loaded_config['processes'] = int(config['processes'])\\\\n+\\\\n         return loaded_config\\\\n \\\\n     def process_raw_file(self, file_path, config):\\\\n\\\",\\n      \\\"rank\\\": 1,\\n      \\\"score\\\": 0.95,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.95,\\n        \\\"code_quality\\\": 0.95,\\n        \\\"risk_level\\\": 0.05,\\n        \\\"best_practices\\\": 0.95,\\n        \\\"test_coverage\\\": 0.9\\n      },\\n      \\\"reasoning\\\": \\\"This patch correctly introduces a default value for processes and ensures that the configuration is read properly. It handles the default case well and aligns with best practices by using a default parameter in the _get method.\\\",\\n      \\\"recommendation\\\": \\\"Highly recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 1,\\n      \\\"patch\\\": \\\"diff --git a/src/sqlfluff/core/config.py b/src/sqlfluff/core/config.py\\\\nindex 0399d3a..d4df70f 100644\\\\n--- a/src/sqlfluff/core/config.py\\\\n+++ b/src/sqlfluff/core/config.py\\\\n@@ -46,6 +46,7 @@ class FluffConfig:\\\\n         \\\\\\\"\\\\\\\"\\\\\\\"\\\\n         self._config = config\\\\n         self._overrides = overrides or {}\\\\n+        self.processes = None  # Add default value for processes\\\\n         self._processes = self._get(\\\\\\\"processes\\\\\\\")\\\\n\\\\n     @staticmethod\\\\n@@ -122,6 +123,10 @@ def load_config_from_file(cls, file_path: str) -> dict:\\\\n             denormalized_path = os.path.abspath(file_path)\\\\n             config = loader.load_config_at_path(denormalized_path)\\\\n             loaded_config.update(config)\\\\n+            # Read 'processes' from the config file\\\\n+            if 'processes' in config:\\\\n+                loaded_config['processes'] = int(config['processes'])\\\\n+\\\\n         return loaded_config\\\\n \\\\n     def process_raw_file(self, file_path, config):\\\\n\\\",\\n      \\\"rank\\\": 2,\\n      \\\"score\\\": 0.85,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.85,\\n        \\\"code_quality\\\": 0.85,\\n        \\\"risk_level\\\": 0.1,\\n        \\\"best_practices\\\": 0.85,\\n        \\\"test_coverage\\\": 0.8\\n      },\\n      \\\"reasoning\\\": \\\"This patch introduces a processes attribute but does not set a default value, which could lead to None being used unintentionally. It correctly reads from the config file but lacks the robustness of handling defaults.\\\",\\n      \\\"recommendation\\\": \\\"Recommended with caution\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 4,\\n      \\\"patch\\\": \\\"diff --git a/src/sqlfluff/cli/commands.py b/src/sqlfluff/cli/commands.py\\\\nindex f28e9d7..d8b0dbc 100644\\\\n--- a/src/sqlfluff/cli/commands.py\\\\n+++ b/src/sqlfluff/cli/commands.py\\\\n@@ -82,8 +82,9 @@ def lint(config, paths, output_stream=None):\\\\n     \\\\\\\"\\\\\\\"\\\\\\\"\\\\n     output_stream = output_stream or sys.stdout\\\\n     linter, paths = prepare_linter_with_paths(config, paths)\\\\n-    num_processes = config.get(\\\\\\\"processes\\\\\\\")\\\\n+    config_processes = config.get(\\\\\\\"processes\\\\\\\")\\\\n+    num_processes = num_processes or config_processes\\\\n\\\\n     uow = []\\\\n \\\\n@@ -152,8 +153,9 @@ def fix(config, paths, output_stream=None):\\\\n     \\\\\\\"\\\\\\\"\\\\\\\"\\\\n     output_stream = output_stream or sys.stdout\\\\n     linter, paths = prepare_linter_with_paths(config, paths)\\\\n-    num_processes = config.get(\\\\\\\"processes\\\\\\\")\\\\n+    config_processes = config.get(\\\\\\\"processes\\\\\\\")\\\\n+    num_processes = num_processes or config_processes\\\\n\\\\n     r_count = resolve_fixes(\\\\n         path_iterator=paths,\\\\n\\\",\\n      \\\"rank\\\": 3,\\n      \\\"score\\\": 0.75,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.8,\\n        \\\"code_quality\\\": 0.75,\\n        \\\"risk_level\\\": 0.15,\\n        \\\"best_practices\\\": 0.75,\\n        \\\"test_coverage\\\": 0.7\\n      },\\n      \\\"reasoning\\\": \\\"This patch modifies the CLI commands to use a config value for processes but does not address the default value or initialization in the config class. It introduces a new variable unnecessarily, which could lead to confusion.\\\",\\n      \\\"recommendation\\\": \\\"Not recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 2,\\n      \\\"patch\\\": \\\"diff --git a/src/sqlfluff/cli/commands.py b/src/sqlfluff/cli/commands.py\\\\nindex f28e9d7..cb8e2d3 100644\\\\n--- a/src/sqlfluff/cli/commands.py\\\\n+++ b/src/sqlfluff/cli/commands.py\\\\n@@ -82,7 +82,7 @@ def lint(config, paths, output_stream=None):\\\\n     \\\\\\\"\\\\\\\"\\\\\\\"\\\\n     output_stream = output_stream or sys.stdout\\\\n     linter, paths = prepare_linter_with_paths(config, paths)\\\\n-    num_processes = config.get(\\\\\\\"processes\\\\\\\")\\\\n+    num_processes = num_processes or config.get(\\\\\\\"processes\\\\\\\")\\\\n\\\\n     uow = []\\\\n \\\\n@@ -152,7 +152,7 @@ def fix(config, paths, output_stream=None):\\\\n     \\\\\\\"\\\\\\\"\\\\\\\"\\\\n     output_stream = output_stream or sys.stdout\\\\n     linter, paths = prepare_linter_with_paths(config, paths)\\\\n-    num_processes = config.get(\\\\\\\"processes\\\\\\\")\\\\n+    num_processes = num_processes or config.get(\\\\\\\"processes\\\\\\\")\\\\n\\\\n     r_count = resolve_fixes(\\\\n         path_iterator=paths,\\\\n\\\",\\n      \\\"rank\\\": 4,\\n      \\\"score\\\": 0.7,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.75,\\n        \\\"code_quality\\\": 0.7,\\n        \\\"risk_level\\\": 0.2,\\n        \\\"best_practices\\\": 0.7,\\n        \\\"test_coverage\\\": 0.65\\n      },\\n      \\\"reasoning\\\": \\\"This patch attempts to use the config value for processes but does not handle initialization or defaults properly. It assumes num_processes is already defined, which could lead to errors if not handled elsewhere.\\\",\\n      \\\"recommendation\\\": \\\"Not recommended\\\"\\n    }\\n  ],\\n  \\\"evaluation_summary\\\": \\\"Patch 3 is the best choice as it correctly handles default values and integrates well with existing code. Patch 1 is a close second but lacks default handling. Patches 4 and 2 modify CLI commands without addressing core configuration issues, making them less reliable.\\\"\\n}\\n```\", \"generated_tests\": \"```json\\n{\\n  \\\"reproduction_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_reproduce_original_issue\\\",\\n      \\\"test_code\\\": \\\"def test_reproduce_original_issue():\\\\n    # Test setting number of processes in .sqlfluff config file\\\\n    config_file = 'test_config_file.ini'\\\\n    with open(config_file, 'w') as file:\\\\n        file.write('[sqlfluff]\\\\\\\\nprocesses = 2')\\\\n    \\\\n    # Ensure the processes value is read from the config file\\\\n    assert FluffConfig.load_config_from_file(config_file)['processes'] == 2\\\",\\n      \\\"description\\\": \\\"Reproduce the original issue by setting the number of processes in the .sqlfluff config file\\\",\\n      \\\"expected_behavior\\\": \\\"The processes value should be read correctly from the config file\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_edge_cases\\\",\\n      \\\"test_code\\\": \\\"def test_edge_cases():\\\\n    # Test edge cases with number of processes\\\\n    # Case 1: Processes not specified in config file, default value should be used\\\\n    assert FluffConfig.load_config_from_file('empty_config.ini')['processes'] == 4\\\\n    \\\\n    # Case 2: Processes value is a negative number, should handle accordingly\\\\n    with pytest.raises(ValueError):\\\\n        FluffConfig.load_config_from_file('negative_processes.ini')\\\",\\n      \\\"description\\\": \\\"Test edge cases related to the number of processes configuration\\\",\\n      \\\"expected_behavior\\\": \\\"Default value should be used when processes are not specified, and negative processes should raise a ValueError\\\"\\n    }\\n  ],\\n  \\\"validation_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_patch_validation\\\",\\n      \\\"test_code\\\": \\\"def test_patch_validation():\\\\n    # Test that lint and fix commands use the configured number of processes\\\\n    config_file = 'test_config_file.ini'\\\\n    with open(config_file, 'w') as file:\\\\n        file.write('[sqlfluff]\\\\\\\\nprocesses = 2')\\\\n    \\\\n    # Ensure the 'lint' and 'fix' commands use the configured processes value\\\\n    assert lint(FluffConfig.load_config_from_file(config_file), ['test_file.sql']) == 'Linting completed with 2 processes'\\\\n    assert fix(FluffConfig.load_config_from_file(config_file), ['test_file.sql']) == 'Fixing completed with 2 processes'\\\",\\n      \\\"description\\\": \\\"Validate that the patches correctly use the configured number of processes\\\",\\n      \\\"expected_behavior\\\": \\\"The 'lint' and 'fix' commands should use the configured processes value from the .sqlfluff config file\\\"\\n    }\\n  ],\\n  \\\"test_summary\\\": \\\"Comprehensive test cases generated to reproduce the original issue, test edge cases, and validate the patches\\\"\\n}\\n```\"}, \"error\": \"\", \"elapsed_time\": 264.119139, \"total_tokens\": 18035, \"total_steps\": 9, \"created_at\": 1753339925, \"finished_at\": 1753340189}}"
}