initial import
This commit is contained in:
126
core/service/servicegroup_test.go
Normal file
126
core/service/servicegroup_test.go
Normal file
@@ -0,0 +1,126 @@
|
||||
package service
|
||||
|
||||
import (
|
||||
"sync"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
var (
|
||||
number = 1
|
||||
mutex sync.Mutex
|
||||
done = make(chan struct{})
|
||||
)
|
||||
|
||||
type mockedService struct {
|
||||
quit chan struct{}
|
||||
multiplier int
|
||||
}
|
||||
|
||||
func newMockedService(multiplier int) *mockedService {
|
||||
return &mockedService{
|
||||
quit: make(chan struct{}),
|
||||
multiplier: multiplier,
|
||||
}
|
||||
}
|
||||
|
||||
func (s *mockedService) Start() {
|
||||
mutex.Lock()
|
||||
number = number * s.multiplier
|
||||
mutex.Unlock()
|
||||
done <- struct{}{}
|
||||
<-s.quit
|
||||
}
|
||||
|
||||
func (s *mockedService) Stop() {
|
||||
close(s.quit)
|
||||
}
|
||||
|
||||
func TestServiceGroup(t *testing.T) {
|
||||
multipliers := []int{2, 3, 5, 7}
|
||||
want := 1
|
||||
|
||||
group := NewServiceGroup()
|
||||
for _, multiplier := range multipliers {
|
||||
want *= multiplier
|
||||
service := newMockedService(multiplier)
|
||||
group.Add(service)
|
||||
}
|
||||
|
||||
go group.Start()
|
||||
|
||||
for i := 0; i < len(multipliers); i++ {
|
||||
<-done
|
||||
}
|
||||
|
||||
group.Stop()
|
||||
|
||||
mutex.Lock()
|
||||
defer mutex.Unlock()
|
||||
assert.Equal(t, want, number)
|
||||
}
|
||||
|
||||
func TestServiceGroup_WithStart(t *testing.T) {
|
||||
multipliers := []int{2, 3, 5, 7}
|
||||
want := 1
|
||||
|
||||
var wait sync.WaitGroup
|
||||
var lock sync.Mutex
|
||||
wait.Add(len(multipliers))
|
||||
group := NewServiceGroup()
|
||||
for _, multiplier := range multipliers {
|
||||
var mul = multiplier
|
||||
group.Add(WithStart(func() {
|
||||
lock.Lock()
|
||||
want *= mul
|
||||
lock.Unlock()
|
||||
wait.Done()
|
||||
}))
|
||||
}
|
||||
|
||||
go group.Start()
|
||||
wait.Wait()
|
||||
group.Stop()
|
||||
|
||||
lock.Lock()
|
||||
defer lock.Unlock()
|
||||
assert.Equal(t, 210, want)
|
||||
}
|
||||
|
||||
func TestServiceGroup_WithStarter(t *testing.T) {
|
||||
multipliers := []int{2, 3, 5, 7}
|
||||
want := 1
|
||||
|
||||
var wait sync.WaitGroup
|
||||
var lock sync.Mutex
|
||||
wait.Add(len(multipliers))
|
||||
group := NewServiceGroup()
|
||||
for _, multiplier := range multipliers {
|
||||
var mul = multiplier
|
||||
group.Add(WithStarter(mockedStarter{
|
||||
fn: func() {
|
||||
lock.Lock()
|
||||
want *= mul
|
||||
lock.Unlock()
|
||||
wait.Done()
|
||||
},
|
||||
}))
|
||||
}
|
||||
|
||||
go group.Start()
|
||||
wait.Wait()
|
||||
group.Stop()
|
||||
|
||||
lock.Lock()
|
||||
defer lock.Unlock()
|
||||
assert.Equal(t, 210, want)
|
||||
}
|
||||
|
||||
type mockedStarter struct {
|
||||
fn func()
|
||||
}
|
||||
|
||||
func (s mockedStarter) Start() {
|
||||
s.fn()
|
||||
}
|
||||
Reference in New Issue
Block a user