Commit ecc3fb8
authored
* docs: design spec for Set-NBDCIMInterface enum null-clearing
Follow-up to PR #398, which left 5 enum-string parameters on
Set-NBDCIMInterface without null-clearing support. The initially-preferred
[AllowNull()] pattern was empirically disproven — PowerShell coerces
\$null to '' before ValidateSet runs, so null values are rejected.
Approved approach: empty-string sentinel in ValidateSet + AllowEmptyString
+ translate '' to \$null before JSON serialization (same end result as
the numeric [Nullable[T]] fields from PR #398).
Scope is deliberately narrow: one function, five parameters, one new
translation loop in process {}.
* feat: enum null-clearing on Set-NBDCIMInterface (#398 follow-up)
Allows callers to clear any of the five enum-string fields (Duplex,
POE_Mode, POE_Type, RF_Role, Mode) on an existing interface by
passing '' (empty string) as the parameter value. The PATCH body
emits "<field>": null, which NetBox accepts as clear-the-field.
Pattern: [AllowEmptyString()] + '' added to each ValidateSet, then
a new 7-line translation loop at the top of process {} converts
empty-string sentinel values to \$null so BuildURIComponents +
ConvertTo-Json produce a JSON null. Same end result as the 9
numeric [Nullable[T]] parameters from PR #398.
The initially-preferred [AllowNull()] pattern was empirically
disproven — PowerShell coerces \$null to '' before ValidateSet
runs, so '-Duplex \$null' throws 'argument does not belong to set'.
Option B (empty-string sentinel) works reliably on both PS 5.1
and PS 7.
Adds 5 null-clearing tests in Tests/DCIM.Interfaces.Tests.ps1 in
a new Context nested inside Context "Set-NBDCIMInterface". Full
unit regression: 2291 baseline + 5 new = 2296 passed / 0 failed.
Closes the scope-limitation explicitly deferred in PR #398.
* docs: align spec loop variable name with implementation (/Users/elvis/.nix-profile -> $clearable)
Per Gemini review on PR #401 — trivial documentation consistency fix.
1 parent 917bf16 commit ecc3fb8
3 files changed
Lines changed: 160 additions & 5 deletions
File tree
- Functions/DCIM/Interfaces
- Tests
- docs/superpowers/specs
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
158 | 158 | | |
159 | 159 | | |
160 | 160 | | |
161 | | - | |
| 161 | + | |
| 162 | + | |
162 | 163 | | |
163 | 164 | | |
164 | 165 | | |
| |||
168 | 169 | | |
169 | 170 | | |
170 | 171 | | |
171 | | - | |
| 172 | + | |
| 173 | + | |
172 | 174 | | |
173 | 175 | | |
174 | | - | |
| 176 | + | |
| 177 | + | |
175 | 178 | | |
176 | 179 | | |
177 | 180 | | |
| |||
180 | 183 | | |
181 | 184 | | |
182 | 185 | | |
183 | | - | |
| 186 | + | |
| 187 | + | |
184 | 188 | | |
185 | 189 | | |
186 | 190 | | |
| |||
207 | 211 | | |
208 | 212 | | |
209 | 213 | | |
210 | | - | |
| 214 | + | |
| 215 | + | |
211 | 216 | | |
212 | 217 | | |
213 | 218 | | |
| |||
274 | 279 | | |
275 | 280 | | |
276 | 281 | | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
277 | 293 | | |
278 | 294 | | |
279 | 295 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
647 | 647 | | |
648 | 648 | | |
649 | 649 | | |
| 650 | + | |
| 651 | + | |
| 652 | + | |
| 653 | + | |
| 654 | + | |
| 655 | + | |
| 656 | + | |
| 657 | + | |
| 658 | + | |
| 659 | + | |
| 660 | + | |
| 661 | + | |
| 662 | + | |
| 663 | + | |
| 664 | + | |
| 665 | + | |
| 666 | + | |
| 667 | + | |
| 668 | + | |
| 669 | + | |
| 670 | + | |
| 671 | + | |
| 672 | + | |
| 673 | + | |
| 674 | + | |
| 675 | + | |
| 676 | + | |
650 | 677 | | |
651 | 678 | | |
652 | 679 | | |
| |||
Lines changed: 112 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
0 commit comments