Commit 08d0a96
authored
feat: Add --fail-fast option to stop on first failure (pdsh -k compatible) (#103)
* feat: Add --fail-fast option to stop on first failure (pdsh -k compatible)
Add a new --fail-fast / -k option that stops execution immediately when
any node fails (connection error or non-zero exit code). This provides
pdsh compatibility and is useful for critical operations where partial
execution is unacceptable.
Implementation details:
- Uses tokio::sync::watch channel for cancellation signaling
- Uses tokio::select! to race between execution and cancellation
- Cancels pending tasks waiting in semaphore queue
- Reports which node caused the failure with error details
- Works with existing parallel execution infrastructure
Features:
- Short option -k for pdsh compatibility
- Long option --fail-fast for clarity
- Can be combined with --require-all-success and --check-all-nodes
- Supports all parallelism settings (including --parallel N)
Closes #94
* fix(quality): Use floor_char_boundary() for safe UTF-8 string truncation
Priority: MEDIUM
Issue: String slicing with byte index could panic on multi-byte UTF-8 chars
The error message truncation in execute_with_fail_fast() used direct
byte indexing (&first_line[..47]) which can panic if the index falls
in the middle of a multi-byte UTF-8 character.
Fixed by using floor_char_boundary(47) to find the largest valid char
boundary at or before byte 47, ensuring safe string truncation for all
Unicode content including CJK characters and emoji.
* docs: Add fail-fast option documentation to manpage and ARCHITECTURE.md
- Add --fail-fast / -k option description in manpage OPTIONS section
- Add fail-fast examples in manpage EXAMPLES section
- Add fail-fast mode implementation details in ARCHITECTURE.md
* fix(test): Prefer debug binary in connect_timeout_test to avoid stale cache
The test helper was finding stale release binaries in CI, causing tests to
fail because the old binary didn't have --connect-timeout option. Changed
to prefer debug binary since `cargo test` builds debug binaries.1 parent 290741e commit 08d0a96
File tree
9 files changed
+689
-7
lines changed- docs/man
- src
- app
- commands
- executor
- tests
9 files changed
+689
-7
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
393 | 393 | | |
394 | 394 | | |
395 | 395 | | |
| 396 | + | |
| 397 | + | |
| 398 | + | |
| 399 | + | |
| 400 | + | |
| 401 | + | |
| 402 | + | |
| 403 | + | |
| 404 | + | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
| 417 | + | |
| 418 | + | |
| 419 | + | |
| 420 | + | |
| 421 | + | |
| 422 | + | |
| 423 | + | |
| 424 | + | |
| 425 | + | |
396 | 426 | | |
397 | 427 | | |
398 | 428 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
15 | 15 | | |
16 | 16 | | |
17 | 17 | | |
| 18 | + | |
18 | 19 | | |
19 | 20 | | |
20 | 21 | | |
| |||
219 | 220 | | |
220 | 221 | | |
221 | 222 | | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
222 | 230 | | |
223 | 231 | | |
224 | 232 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
247 | 247 | | |
248 | 248 | | |
249 | 249 | | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
250 | 269 | | |
251 | 270 | | |
252 | 271 | | |
| |||
1240 | 1259 | | |
1241 | 1260 | | |
1242 | 1261 | | |
| 1262 | + | |
| 1263 | + | |
| 1264 | + | |
| 1265 | + | |
| 1266 | + | |
| 1267 | + | |
| 1268 | + | |
| 1269 | + | |
| 1270 | + | |
| 1271 | + | |
| 1272 | + | |
| 1273 | + | |
| 1274 | + | |
| 1275 | + | |
| 1276 | + | |
| 1277 | + | |
| 1278 | + | |
| 1279 | + | |
| 1280 | + | |
| 1281 | + | |
| 1282 | + | |
| 1283 | + | |
| 1284 | + | |
1243 | 1285 | | |
1244 | 1286 | | |
1245 | 1287 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
404 | 404 | | |
405 | 405 | | |
406 | 406 | | |
| 407 | + | |
407 | 408 | | |
408 | 409 | | |
409 | 410 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
23 | 23 | | |
24 | 24 | | |
25 | 25 | | |
26 | | - | |
| 26 | + | |
27 | 27 | | |
28 | 28 | | |
29 | 29 | | |
| |||
196 | 196 | | |
197 | 197 | | |
198 | 198 | | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
199 | 206 | | |
200 | 207 | | |
201 | 208 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
46 | 46 | | |
47 | 47 | | |
48 | 48 | | |
| 49 | + | |
49 | 50 | | |
50 | 51 | | |
51 | 52 | | |
| |||
212 | 213 | | |
213 | 214 | | |
214 | 215 | | |
215 | | - | |
| 216 | + | |
| 217 | + | |
216 | 218 | | |
217 | 219 | | |
218 | 220 | | |
| |||
0 commit comments