gearman-go/client/client_test.go

207 lines
4.3 KiB
Go
Raw Normal View History

package client
import (
"errors"
"flag"
"os"
2013-08-29 16:51:23 +08:00
"testing"
"time"
)
2013-08-30 11:20:51 +08:00
const (
TestStr = "Hello world"
)
var (
client *Client
runIntegrationTests bool
)
func TestMain(m *testing.M) {
integrationsTestFlag := flag.Bool("integration", false, "Run the integration tests (in addition to the unit tests)")
flag.Parse()
if integrationsTestFlag != nil {
runIntegrationTests = *integrationsTestFlag
}
code := m.Run()
os.Exit(code)
}
2013-08-29 18:08:05 +08:00
func TestClientAddServer(t *testing.T) {
if !runIntegrationTests {
t.Skip("To run this test, use: go test -integration")
}
2013-08-29 16:51:23 +08:00
t.Log("Add local server 127.0.0.1:4730")
var err error
if client, err = New(Network, "127.0.0.1:4730"); err != nil {
2013-09-22 22:02:05 +08:00
t.Fatal(err)
2013-08-29 16:51:23 +08:00
}
2013-08-29 18:08:05 +08:00
client.ErrorHandler = func(e error) {
2013-08-29 16:51:23 +08:00
t.Log(e)
}
}
2013-01-14 17:59:48 +08:00
func TestClientEcho(t *testing.T) {
if !runIntegrationTests {
t.Skip("To run this test, use: go test -integration")
}
2013-08-30 11:20:51 +08:00
echo, err := client.Echo([]byte(TestStr))
2013-08-29 16:51:23 +08:00
if err != nil {
t.Error(err)
return
}
2013-08-30 11:20:51 +08:00
if string(echo) != TestStr {
t.Errorf("Echo error, %s expected, %s got", TestStr, echo)
return
}
2013-01-14 17:59:48 +08:00
}
func TestClientDoBg(t *testing.T) {
if !runIntegrationTests {
t.Skip("To run this test, use: go test -integration")
}
handle, err := client.DoBg("ToUpper", []byte("abcdef"), JobLow)
2013-08-30 11:41:18 +08:00
if err != nil {
t.Error(err)
return
}
if handle == "" {
2013-08-29 16:51:23 +08:00
t.Error("Handle is empty.")
2013-08-30 11:20:51 +08:00
} else {
t.Log(handle)
2013-08-29 16:51:23 +08:00
}
}
2013-01-14 17:59:48 +08:00
func TestClientDo(t *testing.T) {
if !runIntegrationTests {
t.Skip("To run this test, use: go test -integration")
}
2013-08-29 18:08:05 +08:00
jobHandler := func(job *Response) {
2013-08-29 16:51:23 +08:00
str := string(job.Data)
if str == "ABCDEF" {
t.Log(str)
} else {
t.Errorf("Invalid data: %s", job.Data)
}
return
}
2013-08-30 11:41:18 +08:00
handle, err := client.Do("ToUpper", []byte("abcdef"),
JobLow, jobHandler)
2013-08-30 11:41:18 +08:00
if err != nil {
t.Error(err)
return
}
if handle == "" {
2013-08-29 16:51:23 +08:00
t.Error("Handle is empty.")
} else {
t.Log(handle)
}
}
2013-01-14 17:59:48 +08:00
func TestClientMultiDo(t *testing.T) {
if !runIntegrationTests {
t.Skip("To run this test, use: go test -integration")
}
// This integration test requires that examples/pl/worker_multi.pl be running.
//
// Test invocation is:
// go test -integration -timeout 10s -run '^TestClient(AddServer|MultiDo)$'
//
// Send 1000 requests to go through all race conditions
const nreqs = 1000
errCh := make(chan error)
gotCh := make(chan string, nreqs)
olderrh := client.ErrorHandler
client.ErrorHandler = func(e error) { errCh <- e }
client.ResponseTimeout = 5 * time.Second
defer func() { client.ErrorHandler = olderrh }()
nextJobCh := make(chan struct{})
defer close(nextJobCh)
go func() {
for range nextJobCh {
start := time.Now()
handle, err := client.Do("PerlToUpper", []byte("abcdef"), JobNormal, func(r *Response) { gotCh <- string(r.Data) })
if err == ErrLostConn && time.Since(start) > client.ResponseTimeout {
errCh <- errors.New("Impossible 'lost conn', deadlock bug detected")
} else if err != nil {
errCh <- err
}
if handle == "" {
errCh <- errors.New("Handle is empty.")
}
}
}()
for i := 0; i < nreqs; i++ {
select {
case err := <-errCh:
t.Fatal(err)
case nextJobCh <- struct{}{}:
}
}
remaining := nreqs
for remaining > 0 {
select {
case err := <-errCh:
t.Fatal(err)
case got := <-gotCh:
if got != "ABCDEF" {
t.Error("Unexpected response from PerlDoUpper: ", got)
}
remaining--
t.Logf("%d response remaining", remaining)
}
}
}
2013-01-14 17:59:48 +08:00
func TestClientStatus(t *testing.T) {
if !runIntegrationTests {
t.Skip("To run this test, use: go test -integration")
}
2013-08-30 11:20:51 +08:00
status, err := client.Status("handle not exists")
2013-08-29 16:51:23 +08:00
if err != nil {
t.Error(err)
return
}
2013-08-30 11:20:51 +08:00
if status.Known {
t.Errorf("The job (%s) shouldn't be known.", status.Handle)
return
}
if status.Running {
t.Errorf("The job (%s) shouldn't be running.", status.Handle)
return
}
2013-01-14 17:59:48 +08:00
handle, err := client.Do("Delay5sec", []byte("abcdef"), JobLow, nil)
2013-08-30 11:41:18 +08:00
if err != nil {
t.Error(err)
return
}
2013-08-30 11:20:51 +08:00
status, err = client.Status(handle)
if err != nil {
t.Error(err)
return
}
if !status.Known {
t.Errorf("The job (%s) should be known.", status.Handle)
return
}
if status.Running {
t.Errorf("The job (%s) shouldn't be running.", status.Handle)
return
}
2013-01-14 17:59:48 +08:00
}
func TestClientClose(t *testing.T) {
if !runIntegrationTests {
t.Skip("To run this test, use: go test -integration")
}
2013-08-29 16:51:23 +08:00
if err := client.Close(); err != nil {
t.Error(err)
}
}