Commit 2f1627d
authored
Error when bundle root path contains glob (#3096)
## Changes
This PR adds an error when the bundle root path contains a glob
character.
```
Error: Bundle root path contains glob pattern characters
The path to the bundle root [TEST_TMP_DIR]/[abc] contains glob pattern character "[". Please remove the character from this path to use bundle commands.
Found 1 error
```
## Why
We provide full paths to `filepath.Glob` to figure out which paths to
include. If the file path itself happens to contain a glob pattern, then
`filepath.Glob` interprets that as a glob pattern, even though we should
not be parsing glob patterns there.
Escaping those glob patterns is also not possible because escaping is
not supported on windows. ref: https://pkg.go.dev/path/filepath#Match
Thus, we error here to inform users to modify their root paths before
doing a bundle deployment.
Note:
1. We could support this but that would mean writing our own glob
function. We can use the `filepath.Match` function to match the patterns
themselves but we would have to walk the paths. The ROI for this option
is low at the moment because our custom function would have to have the
same semantics as the `filepath.Glob` function which would take some
time to get right.
2. This PR does not completely solve the problem since there are some
other places as well where glob patterns might be accidentally parsed.
However, this PR addresses the most important usecase i.e. making during
the `includes` are correct and complete. Other usecases like libraries
not being uploaded correctly are less important and even those will be
very likely caught by this PR unless the user only has a single
`databricks.yml` in their bundle. refs:
https://github.com/databricks/cli/blob/d177292b5b2e5ce779c5d6c5d42feeec00cc533a/bundle/artifacts/expand_globs.go#L68
https://github.com/databricks/cli/blob/d177292b5b2e5ce779c5d6c5d42feeec00cc533a/bundle/libraries/expand_glob_references.go#L42
## Tests
New unit and acceptance tests.1 parent 3812c9a commit 2f1627d
File tree
8 files changed
+119
-0
lines changed- acceptance/bundle/includes/glob_in_root_path
- [abc]
- bundle/config/loader
8 files changed
+119
-0
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
| 6 | + | |
6 | 7 | | |
7 | 8 | | |
8 | 9 | | |
| |||
Whitespace-only changes.
Lines changed: 5 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
24 | 24 | | |
25 | 25 | | |
26 | 26 | | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
27 | 39 | | |
28 | 40 | | |
29 | 41 | | |
| |||
39 | 51 | | |
40 | 52 | | |
41 | 53 | | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
42 | 72 | | |
43 | 73 | | |
44 | 74 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
| 12 | + | |
12 | 13 | | |
13 | 14 | | |
14 | 15 | | |
| |||
111 | 112 | | |
112 | 113 | | |
113 | 114 | | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
0 commit comments