Commit 46244f0
committed
fix(engine): defer to scanner.scan when build_args is missing
Scanners with custom ``scan()`` flows that don't fit the standard
``build_args(ScanPaths) -> list[str]`` contract (linters that walk
the workspace and invoke their tool per file) used to AttributeError
inside ``_run_in_container`` when the engine routed them through the
container path. Combined with PR #117's silent-drop loophole, that
made ``lint-dockerfile`` disappear from canonical results entirely
when hadolint was not installed locally.
Engine change: in ``_run_scanner``, the auto/docker branch now
checks for ``build_args`` or ``container_args`` before entering
``_run_in_container``. When neither is present:
* backend=auto: log a debug message and fall through to the local
path (which calls ``scanner.scan(path, config)`` directly).
* backend=docker: raise a clear RuntimeError naming the constraint
("scanner has container_image but no build_args/container_args
method") so users know to either implement build_args or relax
the backend.
HadolintLinter cleanup: collapse the per-Dockerfile subprocess loop
into a single ``hadolint --format json file1 file2 ...`` invocation.
Hadolint accepts multiple paths and emits one combined JSON array
with each finding's source ``file`` field intact, so the parser
still produces correct ``location`` strings without threading the
path back through the caller. Drops one process spawn per Dockerfile
on every scan.
Roadmap: docs/developer/SDK-ROADMAP.md adds a FileDiscoveryScanner
template entry under Known Issues. The engine fallback gives every
linter a working escape hatch today, but the real abstraction would
be a base class that handles workspace walks, file globbing,
container vs local routing, and batched invocation centrally so the
six existing linters stop reimplementing it. Deferred until a
second linter contributor copy-pastes the boilerplate; trigger to
revisit documented inline.
Two new regression tests in ``TestDockerExecutionBackend``:
test_auto_backend_defers_to_scan_when_no_build_args (the
lint-dockerfile fix path) and
test_docker_backend_rejects_scanner_without_build_args (the loud
error when the user opted into container-only). 1519 SDK tests pass.1 parent a8c54c9 commit 46244f0
4 files changed
Lines changed: 201 additions & 34 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
950 | 950 | | |
951 | 951 | | |
952 | 952 | | |
953 | | - | |
| 953 | + | |
| 954 | + | |
| 955 | + | |
| 956 | + | |
| 957 | + | |
| 958 | + | |
| 959 | + | |
| 960 | + | |
| 961 | + | |
| 962 | + | |
| 963 | + | |
| 964 | + | |
| 965 | + | |
| 966 | + | |
| 967 | + | |
954 | 968 | | |
955 | 969 | | |
956 | 970 | | |
| |||
969 | 983 | | |
970 | 984 | | |
971 | 985 | | |
| 986 | + | |
| 987 | + | |
| 988 | + | |
| 989 | + | |
| 990 | + | |
| 991 | + | |
| 992 | + | |
| 993 | + | |
| 994 | + | |
| 995 | + | |
| 996 | + | |
| 997 | + | |
| 998 | + | |
| 999 | + | |
| 1000 | + | |
972 | 1001 | | |
973 | 1002 | | |
974 | 1003 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
20 | 20 | | |
21 | 21 | | |
22 | 22 | | |
23 | | - | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
24 | 31 | | |
25 | 32 | | |
26 | 33 | | |
| |||
31 | 38 | | |
32 | 39 | | |
33 | 40 | | |
34 | | - | |
35 | | - | |
36 | | - | |
37 | | - | |
| 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 | + | |
38 | 69 | | |
39 | | - | |
| 70 | + | |
| 71 | + | |
40 | 72 | | |
41 | 73 | | |
42 | 74 | | |
| |||
58 | 90 | | |
59 | 91 | | |
60 | 92 | | |
61 | | - | |
62 | | - | |
63 | | - | |
64 | | - | |
65 | | - | |
66 | | - | |
67 | | - | |
68 | | - | |
69 | | - | |
70 | | - | |
71 | | - | |
72 | | - | |
73 | | - | |
74 | | - | |
75 | | - | |
76 | | - | |
77 | | - | |
78 | | - | |
79 | 93 | | |
80 | | - | |
| 94 | + | |
81 | 95 | | |
82 | | - | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
83 | 101 | | |
84 | 102 | | |
85 | 103 | | |
86 | 104 | | |
87 | 105 | | |
88 | 106 | | |
89 | | - | |
90 | | - | |
| 107 | + | |
91 | 108 | | |
92 | 109 | | |
93 | | - | |
| 110 | + | |
94 | 111 | | |
95 | 112 | | |
96 | | - | |
97 | | - | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
98 | 120 | | |
99 | 121 | | |
100 | | - | |
| 122 | + | |
| 123 | + | |
101 | 124 | | |
102 | 125 | | |
103 | 126 | | |
| |||
109 | 132 | | |
110 | 133 | | |
111 | 134 | | |
112 | | - | |
| 135 | + | |
113 | 136 | | |
114 | 137 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
222 | 222 | | |
223 | 223 | | |
224 | 224 | | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
| 269 | + | |
| 270 | + | |
| 271 | + | |
| 272 | + | |
| 273 | + | |
| 274 | + | |
| 275 | + | |
| 276 | + | |
| 277 | + | |
| 278 | + | |
| 279 | + | |
| 280 | + | |
| 281 | + | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
225 | 301 | | |
226 | 302 | | |
227 | 303 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
624 | 624 | | |
625 | 625 | | |
626 | 626 | | |
| 627 | + | |
| 628 | + | |
| 629 | + | |
| 630 | + | |
| 631 | + | |
| 632 | + | |
| 633 | + | |
| 634 | + | |
| 635 | + | |
| 636 | + | |
| 637 | + | |
| 638 | + | |
| 639 | + | |
| 640 | + | |
| 641 | + | |
| 642 | + | |
| 643 | + | |
| 644 | + | |
| 645 | + | |
| 646 | + | |
| 647 | + | |
| 648 | + | |
| 649 | + | |
| 650 | + | |
| 651 | + | |
| 652 | + | |
| 653 | + | |
| 654 | + | |
| 655 | + | |
| 656 | + | |
| 657 | + | |
| 658 | + | |
| 659 | + | |
| 660 | + | |
| 661 | + | |
| 662 | + | |
| 663 | + | |
| 664 | + | |
| 665 | + | |
627 | 666 | | |
628 | 667 | | |
629 | 668 | | |
| |||
0 commit comments