This repository was archived by the owner on Jul 2, 2026. It is now read-only.
Commit da47bf4
committed
fix(download): use staging + atomic rename in extract_archive_atomic
v1.0.6 serialised concurrent tar extractions via an mkdir-based lock,
but the polling loop's early-exit on \`[[ -x bin_path ]]\` observed the
file the moment tar created the inode with its archived perms — well
before tar finished writing it. The early-exiting process then went on
to \`exec\` the partially-written binary, surfacing as
\`Text file busy\` (ETXTBSY) in CI logs.
Replace the lock with the same pattern \`download_tool_from_archive\`
already uses: extract into a per-invocation staging dir on the same
filesystem, then atomically rename the top-level entry into place.
Parallel callers now see the binary as either fully-absent or
fully-present — never mid-write.1 parent 5a37489 commit da47bf4
2 files changed
Lines changed: 41 additions & 18 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
30 | 30 | | |
31 | 31 | | |
32 | 32 | | |
33 | | - | |
34 | | - | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
35 | 37 | | |
36 | 38 | | |
37 | 39 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
201 | 201 | | |
202 | 202 | | |
203 | 203 | | |
204 | | - | |
205 | | - | |
206 | | - | |
207 | | - | |
208 | | - | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
209 | 218 | | |
210 | 219 | | |
211 | 220 | | |
212 | 221 | | |
213 | 222 | | |
214 | 223 | | |
215 | 224 | | |
216 | | - | |
217 | | - | |
218 | | - | |
219 | | - | |
220 | | - | |
221 | | - | |
222 | | - | |
223 | | - | |
224 | | - | |
225 | | - | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
226 | 247 | | |
227 | | - | |
| 248 | + | |
228 | 249 | | |
0 commit comments