From 8e7980a29e3fca60d73756de102acaa538af97f8 Mon Sep 17 00:00:00 2001 From: datelier <57349093+datelier@users.noreply.github.com> Date: Fri, 18 Nov 2022 14:32:20 +0900 Subject: [PATCH] fix deepsource: Unsafe defer of os.Close (#1836) * fix deepsource: Unsafe defer of os.Close * apply suggestion Co-authored-by: Yusuke Kato --- .../src/singleflight/singleflight_bench_test.go | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/hack/benchmark/src/singleflight/singleflight_bench_test.go b/hack/benchmark/src/singleflight/singleflight_bench_test.go index 9eff4d1f18..29b5a4bc01 100644 --- a/hack/benchmark/src/singleflight/singleflight_bench_test.go +++ b/hack/benchmark/src/singleflight/singleflight_bench_test.go @@ -24,6 +24,7 @@ import ( "testing" "time" + "github.com/vdaas/vald/internal/errors" "github.com/vdaas/vald/internal/singleflight" stdsingleflight "golang.org/x/sync/singleflight" ) @@ -261,12 +262,18 @@ func Benchmark_group_Do_with_vald_internal_singleflight(b *testing.B) { } } -func toCSV(name string, r []Result) error { - f, err := os.OpenFile(name, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, fs.ModePerm) +func toCSV(name string, r []Result) (err error) { + var f *os.File + f, err = os.OpenFile(name, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, fs.ModePerm) if err != nil { return err } - defer f.Close() + defer func() { + e := f.Close() + if e != nil { + err = errors.Wrap(err, e.Error()) + } + }() _, err = fmt.Fprintln(f, "goroutine,duration,hit_rate") if err != nil { return err