container/init: close setup pipe early
All checks were successful
Test / Create distribution (push) Successful in 34s
Test / Sandbox (push) Successful in 2m32s
Test / Sandbox (race detector) (push) Successful in 4m30s
Test / Hpkg (push) Successful in 4m48s
Test / Hakurei (race detector) (push) Successful in 6m17s
Test / Hakurei (push) Successful in 3m17s
Test / Flake checks (push) Successful in 1m21s
All checks were successful
Test / Create distribution (push) Successful in 34s
Test / Sandbox (push) Successful in 2m32s
Test / Sandbox (race detector) (push) Successful in 4m30s
Test / Hpkg (push) Successful in 4m48s
Test / Hakurei (race detector) (push) Successful in 6m17s
Test / Hakurei (push) Successful in 3m17s
Test / Flake checks (push) Successful in 1m21s
This prevents leaking the setup pipe. Signed-off-by: Ophestra <cat@gensokyo.uk>
This commit is contained in:
@@ -67,6 +67,39 @@ func main() {
|
||||
case "hash": // this eases the pain of passing the hash to python
|
||||
fmt.Print(flagBpfHash)
|
||||
|
||||
case "fd":
|
||||
if len(args) != 2 {
|
||||
log.Fatal("invalid argument")
|
||||
}
|
||||
prefix := fmt.Sprintf("/proc/%s/fd/", args[1])
|
||||
|
||||
var fail bool
|
||||
if entries, err := os.ReadDir(prefix); err != nil {
|
||||
log.Fatal(err.Error())
|
||||
} else {
|
||||
for _, ent := range entries {
|
||||
var fd int
|
||||
if fd, err = strconv.Atoi(ent.Name()); err != nil {
|
||||
log.Fatal(err.Error())
|
||||
}
|
||||
|
||||
// skip standard streams
|
||||
if fd <= 2 {
|
||||
continue
|
||||
}
|
||||
fail = true
|
||||
|
||||
var d string
|
||||
if d, err = os.Readlink(prefix + ent.Name()); err != nil {
|
||||
log.Fatal(err.Error())
|
||||
}
|
||||
log.Printf("[FAIL] extra fd %d -> %s", fd, d)
|
||||
}
|
||||
}
|
||||
if fail {
|
||||
log.Fatal("[FAIL] file descriptors leaked")
|
||||
}
|
||||
|
||||
default:
|
||||
log.Fatal("invalid argument")
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user