Commit 9c348a3
fix(cli): handle invalid JSON input in CLI options gracefully
Previously, providing malformed JSON to CLI options (such as `--strategies`)
resulted in a raw Python traceback (`JSONDecodeError`) surfacing to the user.
Additionally, whitespace-only input was implicitly converted to `None`,
causing the CLI to send `null` in the API request body, which could be
rejected by the GitLab API.
This change updates `JsonAttribute` to:
- Catch `ValueError` and `TypeError` during JSON parsing.
- Raise a `GitlabParsingError`, which the CLI catches to display a
user-friendly error message.
- Treat whitespace-only strings as invalid JSON rather than `None`,
requiring the user to be explicit (e.g. passing `'[]'` or `'{}'`).
Tests have been updated to verify the new error handling behavior.1 parent fc0f3f4 commit 9c348a3
File tree
3 files changed
+29
-6
lines changed- gitlab
- tests
- functional/cli
- unit
3 files changed
+29
-6
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| 7 | + | |
| 8 | + | |
7 | 9 | | |
8 | 10 | | |
9 | 11 | | |
| |||
59 | 61 | | |
60 | 62 | | |
61 | 63 | | |
62 | | - | |
63 | | - | |
64 | | - | |
| 64 | + | |
65 | 65 | | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
66 | 70 | | |
67 | 71 | | |
68 | 72 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
141 | 141 | | |
142 | 142 | | |
143 | 143 | | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | | - | |
| 3 | + | |
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| |||
131 | 131 | | |
132 | 132 | | |
133 | 133 | | |
134 | | - | |
135 | | - | |
| 134 | + | |
| 135 | + | |
136 | 136 | | |
137 | 137 | | |
138 | 138 | | |
| |||
0 commit comments