From acd1d9ea4274d6f0d1aa021abaf94bdca6c30575 Mon Sep 17 00:00:00 2001 From: Congqi Xia Date: Fri, 29 Nov 2024 11:54:11 +0800 Subject: [PATCH] fix: Return thread watcher goroutine after closed Resolves #38090 Signed-off-by: Congqi Xia --- internal/util/metrics/thread.go | 1 + internal/util/metrics/thread_test.go | 41 ++++++++++++++++++++++++++++ 2 files changed, 42 insertions(+) create mode 100644 internal/util/metrics/thread_test.go diff --git a/internal/util/metrics/thread.go b/internal/util/metrics/thread.go index 9e3489fa078c8..dea0fda8ae5d8 100644 --- a/internal/util/metrics/thread.go +++ b/internal/util/metrics/thread.go @@ -75,6 +75,7 @@ func (thw *threadWatcher) watchThreadNum() { metrics.ThreadNum.Set(float64(threadNum)) case <-thw.ch: log.Info("thread watcher exit") + return } } } diff --git a/internal/util/metrics/thread_test.go b/internal/util/metrics/thread_test.go new file mode 100644 index 0000000000000..16dbd6c1388b5 --- /dev/null +++ b/internal/util/metrics/thread_test.go @@ -0,0 +1,41 @@ +// Licensed to the LF AI & Data foundation under one +// or more contributor license agreements. See the NOTICE file +// distributed with this work for additional information +// regarding copyright ownership. The ASF licenses this file +// to you under the Apache License, Version 2.0 (the +// "License"); you may not use this file except in compliance +// with the License. You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package metrics + +import ( + "testing" + "time" + + "github.com/stretchr/testify/assert" +) + +func TestThreadWatcher(t *testing.T) { + watcher := NewThreadWatcher() + + watcher.Start() + + ch := make(chan struct{}) + go func() { + defer close(ch) + watcher.Stop() + }() + select { + case <-ch: + case <-time.After(time.Second * 5): + assert.FailNow(t, "watcher failed to close after 5 seconds") + } +}