1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2025-01-17 23:06:30 -05:00
v2fly/common/task/periodic_test.go

43 lines
838 B
Go
Raw Normal View History

2018-05-27 07:02:29 -04:00
package task_test
2018-02-08 10:19:43 -05:00
import (
"sync/atomic"
2018-02-08 10:19:43 -05:00
"testing"
"time"
"github.com/v2fly/v2ray-core/v5/common"
. "github.com/v2fly/v2ray-core/v5/common/task"
2018-02-08 10:19:43 -05:00
)
func TestPeriodicTaskStop(t *testing.T) {
var value uint64
2018-05-27 07:02:29 -04:00
task := &Periodic{
2018-02-08 10:19:43 -05:00
Interval: time.Second * 2,
Execute: func() error {
atomic.AddUint64(&value, 1)
2018-02-08 10:19:43 -05:00
return nil
},
}
common.Must(task.Start())
time.Sleep(time.Second * 5)
common.Must(task.Close())
value1 := atomic.LoadUint64(&value)
if value1 != 3 {
t.Fatal("expected 3, but got ", value1)
2019-01-31 14:57:01 -05:00
}
2018-02-08 10:19:43 -05:00
time.Sleep(time.Second * 4)
value2 := atomic.LoadUint64(&value)
if value2 != 3 {
t.Fatal("expected 3, but got ", value2)
2019-01-31 14:57:01 -05:00
}
common.Must(task.Start())
time.Sleep(time.Second * 3)
value3 := atomic.LoadUint64(&value)
if value3 != 5 {
t.Fatal("Expected 5, but ", value3)
}
common.Must(task.Close())
2018-02-08 10:19:43 -05:00
}