blob: fd51484a0f773b70b4ea20d77f35a798c01a185d [file] [log] [blame]
// Copyright 2025 The Go Authors. All rights reserved.
// Use of this source code is governed by a MIT
// license that can be found in the LICENSE file.
/*
* Project: kubernetes
* Issue or PR : https://github.com/kubernetes/kubernetes/pull/5316
* Buggy version: c868b0bbf09128960bc7c4ada1a77347a464d876
* fix commit-id: cc3a433a7abc89d2f766d4c87eaae9448e3dc091
* Flaky: 100/100
*/
package main
import (
"errors"
"math/rand"
"os"
"runtime"
"runtime/pprof"
"time"
)
func init() {
register("Kubernetes5316", Kubernetes5316)
}
func finishRequest_kubernetes5316(timeout time.Duration, fn func() error) {
ch := make(chan bool)
errCh := make(chan error)
go func() { // G2
if err := fn(); err != nil {
errCh <- err
} else {
ch <- true
}
}()
select {
case <-ch:
case <-errCh:
case <-time.After(timeout):
}
}
func Kubernetes5316() {
prof := pprof.Lookup("goroutineleak")
defer func() {
// Wait a bit because the child goroutine relies on timed operations.
time.Sleep(100 * time.Millisecond)
// Yield several times to allow the child goroutine to run
for i := 0; i < yieldCount; i++ {
runtime.Gosched()
}
prof.WriteTo(os.Stdout, 2)
}()
go func() {
fn := func() error {
time.Sleep(2 * time.Millisecond)
if rand.Intn(10) > 5 {
return errors.New("Error")
}
return nil
}
go finishRequest_kubernetes5316(time.Microsecond, fn) // G1
}()
}