You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
150 lines
2.6 KiB
150 lines
2.6 KiB
package pserver_test
|
|
|
|
import (
|
|
"reflect"
|
|
"sync"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/PaddlePaddle/Paddle/go/pserver"
|
|
)
|
|
|
|
func TestFull(t *testing.T) {
|
|
s := pserver.NewService()
|
|
var p pserver.Parameter
|
|
p.Name = "param_a"
|
|
p.Content = []byte{1, 0, 0, 0, 2, 0, 0, 0, 3, 0, 0, 0}
|
|
p.ElementType = pserver.Int32
|
|
var dummy int
|
|
err := s.InitParam(pserver.ParameterWithConfig{p, nil}, &dummy)
|
|
if err != nil {
|
|
t.FailNow()
|
|
}
|
|
|
|
var p1 pserver.Parameter
|
|
p1.Name = "param_b"
|
|
p1.Content = []byte{0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
|
|
p1.ElementType = pserver.Float32
|
|
err = s.InitParam(pserver.ParameterWithConfig{p1, nil}, &dummy)
|
|
if err != nil {
|
|
t.FailNow()
|
|
}
|
|
|
|
err = s.FinishInitParams(0, &dummy)
|
|
if err != nil {
|
|
t.FailNow()
|
|
}
|
|
|
|
var param pserver.Parameter
|
|
err = s.GetParam("param_b", ¶m)
|
|
if err != nil {
|
|
t.FailNow()
|
|
}
|
|
|
|
if !reflect.DeepEqual(param, p1) {
|
|
t.FailNow()
|
|
}
|
|
|
|
g1, g2 := pserver.Gradient(p1), pserver.Gradient(p)
|
|
err = s.SendGrad(g1, &dummy)
|
|
if err != nil {
|
|
t.FailNow()
|
|
}
|
|
err = s.SendGrad(g2, &dummy)
|
|
|
|
if err != nil {
|
|
t.FailNow()
|
|
}
|
|
|
|
var param1 pserver.Parameter
|
|
err = s.GetParam("param_a", ¶m1)
|
|
if err != nil {
|
|
t.FailNow()
|
|
}
|
|
|
|
// don't compare content, since it's already changed by
|
|
// gradient update.
|
|
param1.Content = nil
|
|
p.Content = nil
|
|
|
|
if !reflect.DeepEqual(param1, p) {
|
|
t.FailNow()
|
|
}
|
|
}
|
|
|
|
func TestMultipleInit(t *testing.T) {
|
|
s := pserver.NewService()
|
|
var dummy int
|
|
err := s.FinishInitParams(0, &dummy)
|
|
if err != nil {
|
|
t.FailNow()
|
|
}
|
|
|
|
err = s.FinishInitParams(0, &dummy)
|
|
if err != pserver.ErrAlreadyInitialized {
|
|
t.FailNow()
|
|
}
|
|
}
|
|
|
|
func TestUninitialized(t *testing.T) {
|
|
s := pserver.NewService()
|
|
var dummy int
|
|
err := s.SendGrad(pserver.Gradient{}, &dummy)
|
|
if err != pserver.ErrUninitialized {
|
|
t.FailNow()
|
|
}
|
|
}
|
|
|
|
func TestBlockUntilInitialized(t *testing.T) {
|
|
s := pserver.NewService()
|
|
ch := make(chan struct{}, 2)
|
|
var wg sync.WaitGroup
|
|
wg.Add(1)
|
|
go func() {
|
|
var param pserver.Parameter
|
|
err := s.GetParam("param_a", ¶m)
|
|
if err != nil {
|
|
t.FailNow()
|
|
}
|
|
wg.Done()
|
|
ch <- struct{}{}
|
|
}()
|
|
|
|
wg.Add(1)
|
|
go func() {
|
|
var dummy int
|
|
err := s.Save("", &dummy)
|
|
if err != nil {
|
|
t.FailNow()
|
|
}
|
|
wg.Done()
|
|
ch <- struct{}{}
|
|
}()
|
|
|
|
time.Sleep(50 * time.Millisecond)
|
|
|
|
select {
|
|
case <-ch:
|
|
// some function returned before initialization is completed.
|
|
t.FailNow()
|
|
default:
|
|
}
|
|
|
|
var p pserver.Parameter
|
|
p.Name = "param_a"
|
|
p.Content = []byte{1, 0, 0, 0, 2, 0, 0, 0, 3, 0, 0, 0}
|
|
p.ElementType = pserver.Int32
|
|
var dummy int
|
|
err := s.InitParam(pserver.ParameterWithConfig{p, nil}, &dummy)
|
|
if err != nil {
|
|
t.FailNow()
|
|
}
|
|
|
|
err = s.FinishInitParams(0, &dummy)
|
|
if err != nil {
|
|
t.FailNow()
|
|
}
|
|
|
|
wg.Wait()
|
|
}
|