databricks-cli/bundle/config/mutator/python
shreyas-goenka 4bf88b4209
Support multiple locations for diagnostics (#1610)
## Changes
This PR changes `diag.Diagnostics` to allow including multiple locations
associated with the diagnostic message. The diagnostics that now return
multiple locations with this PR are:
1. Warning for unknown keys in config.
2. Use of experimental.run_as
3. Accidental sync.exludes that exclude all files.

## Tests
Existing unit tests pass. New unit test case to assert on error message
when multiple locations are included.

Example output:
```
➜  bundle-playground-2 ~/cli2/cli/cli bundle validate              
Warning: You are using the legacy mode of run_as. The support for this mode is experimental and might be removed in a future release of the CLI. In order to run the DLT pipelines in your DAB as the run_as user this mode changes the owners of the pipelines to the run_as identity, which requires the user deploying the bundle to be a workspace admin, and also a Metastore admin if the pipeline target is in UC.
  at experimental.use_legacy_run_as
  in resources.yml:10:22
     databricks.yml:13:22

Name: fix run_if
Target: default
Workspace:
  User: shreyas.goenka@databricks.com
  Path: /Users/shreyas.goenka@databricks.com/.bundle/fix run_if/default

Found 1 warning
```
2024-07-23 17:20:11 +00:00
..
log_writer.go Add ApplyPythonMutator (#1430) 2024-06-20 08:43:08 +00:00
python_diagnostics.go Support multiple locations for diagnostics (#1610) 2024-07-23 17:20:11 +00:00
python_diagnostics_test.go Support multiple locations for diagnostics (#1610) 2024-07-23 17:20:11 +00:00
python_mutator.go PythonMutator: allow insert 'resources' and 'resources.jobs' (#1555) 2024-07-03 08:33:23 +00:00
python_mutator_test.go Support multiple locations for diagnostics (#1610) 2024-07-23 17:20:11 +00:00