forked from yuxh/gearman-go
63 lines
1.4 KiB
Go
63 lines
1.4 KiB
Go
|
package worker
|
||
|
|
||
|
import (
|
||
|
"bytes"
|
||
|
"testing"
|
||
|
)
|
||
|
|
||
|
var (
|
||
|
inpackcases = map[uint32]map[string]string{
|
||
|
NOOP: map[string]string{
|
||
|
"src": "\x00RES\x00\x00\x00\x06\x00\x00\x00\x00",
|
||
|
},
|
||
|
NO_JOB: map[string]string{
|
||
|
"src": "\x00RES\x00\x00\x00\x0a\x00\x00\x00\x00",
|
||
|
},
|
||
|
JOB_ASSIGN: map[string]string{
|
||
|
"src": "\x00RES\x00\x00\x00\x0b\x00\x00\x00\x07a\x00b\x00xyz",
|
||
|
"handle": "a",
|
||
|
"fn": "b",
|
||
|
"data": "xyz",
|
||
|
},
|
||
|
JOB_ASSIGN_UNIQ: map[string]string{
|
||
|
"src": "\x00RES\x00\x00\x00\x1F\x00\x00\x00\x09a\x00b\x00c\x00xyz",
|
||
|
"handle": "a",
|
||
|
"fn": "b",
|
||
|
"uid": "c",
|
||
|
"data": "xyz",
|
||
|
},
|
||
|
}
|
||
|
)
|
||
|
|
||
|
func TestInPack(t *testing.T) {
|
||
|
for k, v := range inpackcases {
|
||
|
inpack, _, err := decodeInPack([]byte(v["src"]))
|
||
|
if err != nil {
|
||
|
t.Error(err)
|
||
|
}
|
||
|
if inpack.dataType != k {
|
||
|
t.Errorf("DataType: %d expected, %d got.", k, inpack.dataType)
|
||
|
}
|
||
|
if handle, ok := v["handle"]; ok {
|
||
|
if inpack.handle != handle {
|
||
|
t.Errorf("Handle: %s expected, %s got.", handle, inpack.handle)
|
||
|
}
|
||
|
}
|
||
|
if fn, ok := v["fn"]; ok {
|
||
|
if inpack.fn != fn {
|
||
|
t.Errorf("FuncName: %s expected, %s got.", fn, inpack.fn)
|
||
|
}
|
||
|
}
|
||
|
if uid, ok := v["uid"]; ok {
|
||
|
if inpack.uniqueId != uid {
|
||
|
t.Errorf("UID: %s expected, %s got.", uid, inpack.uniqueId)
|
||
|
}
|
||
|
}
|
||
|
if data, ok := v["data"]; ok {
|
||
|
if bytes.Compare([]byte(data), inpack.data) != 0 {
|
||
|
t.Errorf("UID: %v expected, %v got.", data, inpack.data)
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|