2020-04-29 21:32:39 +00:00
|
|
|
// Package runutil includes helpers for scheduling runnable, periodic functions.
|
2021-09-18 17:26:11 +00:00
|
|
|
package async
|
2019-12-13 23:14:56 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"reflect"
|
|
|
|
"runtime"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
|
|
|
// RunEvery runs the provided command periodically.
|
|
|
|
// It runs in a goroutine, and can be cancelled by finishing the supplied context.
|
|
|
|
func RunEvery(ctx context.Context, period time.Duration, f func()) {
|
|
|
|
funcName := runtime.FuncForPC(reflect.ValueOf(f).Pointer()).Name()
|
|
|
|
ticker := time.NewTicker(period)
|
|
|
|
go func() {
|
|
|
|
for {
|
|
|
|
select {
|
|
|
|
case <-ticker.C:
|
|
|
|
log.WithField("function", funcName).Trace("running")
|
|
|
|
f()
|
|
|
|
case <-ctx.Done():
|
|
|
|
log.WithField("function", funcName).Debug("context is closed, exiting")
|
|
|
|
ticker.Stop()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
}
|