mirror of
https://github.com/refraction-networking/utls.git
synced 2025-04-06 21:47:36 +03:00
[release-branch.go1.18] internal/fuzz: don't use dirty coverage maps during minimization
When minimizing a value, if the value cannot be minimized (i.e. it is the final value is the same value as was sent for minimization) return the initial coverage map, rather than the coverageSnapshot, which is actually the coverage map for the final minimization step and may not accurately reflect whether the input actually expands the coverage set or not. Updates #48326 Change-Id: I01f0eebe5841e808b6799647d2e5fe3aa45cd2e0 Reviewed-on: https://go-review.googlesource.com/c/go/+/391614 Reviewed-by: Bryan Mills <bcmills@google.com> Trust: Roland Shoemaker <roland@golang.org> Run-TryBot: Roland Shoemaker <roland@golang.org> Auto-Submit: Roland Shoemaker <roland@golang.org> TryBot-Result: Gopher Robot <gobot@golang.org> (cherry picked from commit bd71dee2b4c0a44f9c32e9eb23d990b54ce06bae) Reviewed-on: https://go-review.googlesource.com/c/go/+/391797 Trust: Dmitri Shuralyov <dmitshur@golang.org> Run-TryBot: Dmitri Shuralyov <dmitshur@golang.org>
This commit is contained in:
parent
782cb3f6fb
commit
0a35b692ac
1 changed files with 12 additions and 1 deletions
|
@ -800,6 +800,7 @@ func (ws *workerServer) minimize(ctx context.Context, args minimizeArgs) (resp m
|
|||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
inpHash := sha256.Sum256(mem.valueCopy())
|
||||
if args.Timeout != 0 {
|
||||
var cancel func()
|
||||
ctx, cancel = context.WithTimeout(ctx, args.Timeout)
|
||||
|
@ -811,12 +812,22 @@ func (ws *workerServer) minimize(ctx context.Context, args minimizeArgs) (resp m
|
|||
success, err := ws.minimizeInput(ctx, vals, mem, args)
|
||||
if success {
|
||||
writeToMem(vals, mem)
|
||||
outHash := sha256.Sum256(mem.valueCopy())
|
||||
mem.header().rawInMem = false
|
||||
resp.WroteToMem = true
|
||||
if err != nil {
|
||||
resp.Err = err.Error()
|
||||
} else {
|
||||
resp.CoverageData = coverageSnapshot
|
||||
// If the values didn't change during minimization then coverageSnapshot is likely
|
||||
// a dirty snapshot which represents the very last step of minimization, not the
|
||||
// coverage for the initial input. In that case just return the coverage we were
|
||||
// given initially, since it more accurately represents the coverage map for the
|
||||
// input we are returning.
|
||||
if outHash != inpHash {
|
||||
resp.CoverageData = coverageSnapshot
|
||||
} else {
|
||||
resp.CoverageData = args.KeepCoverage
|
||||
}
|
||||
}
|
||||
}
|
||||
return resp
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue