2020-01-03 10:13:16 +08:00
|
|
|
// Copyright 2020 Kentaro Hibino. All rights reserved.
|
|
|
|
// Use of this source code is governed by a MIT license
|
|
|
|
// that can be found in the LICENSE file.
|
|
|
|
|
2019-12-19 23:13:43 +08:00
|
|
|
package asynq
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/google/go-cmp/cmp"
|
2020-06-12 11:58:27 +08:00
|
|
|
"github.com/google/go-cmp/cmp/cmpopts"
|
2020-01-05 05:13:46 +08:00
|
|
|
h "github.com/hibiken/asynq/internal/asynqtest"
|
|
|
|
"github.com/hibiken/asynq/internal/base"
|
2019-12-19 23:13:43 +08:00
|
|
|
)
|
|
|
|
|
2020-03-15 03:20:23 +08:00
|
|
|
type payloadTest struct {
|
|
|
|
data map[string]interface{}
|
|
|
|
key string
|
|
|
|
nonkey string
|
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
|
2020-03-15 03:20:23 +08:00
|
|
|
func TestPayloadString(t *testing.T) {
|
|
|
|
tests := []payloadTest{
|
|
|
|
{
|
|
|
|
data: map[string]interface{}{"name": "gopher"},
|
|
|
|
key: "name",
|
|
|
|
nonkey: "unknown",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
|
|
|
payload := Payload{tc.data}
|
|
|
|
|
|
|
|
got, err := payload.GetString(tc.key)
|
|
|
|
if err != nil || got != tc.data[tc.key] {
|
|
|
|
t.Errorf("Payload.GetString(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// encode and then decode task messsage.
|
|
|
|
in := h.NewTaskMessage("testing", tc.data)
|
2020-06-12 11:58:27 +08:00
|
|
|
encoded, err := base.EncodeMessage(in)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-06-12 11:58:27 +08:00
|
|
|
out, err := base.DecodeMessage(encoded)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
payload = Payload{out.Payload}
|
|
|
|
got, err = payload.GetString(tc.key)
|
|
|
|
if err != nil || got != tc.data[tc.key] {
|
|
|
|
t.Errorf("With Marshaling: Payload.GetString(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// access non-existent key.
|
|
|
|
got, err = payload.GetString(tc.nonkey)
|
|
|
|
if err == nil || got != "" {
|
|
|
|
t.Errorf("Payload.GetString(%q) = %v, %v; want '', error",
|
|
|
|
tc.key, got, err)
|
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
}
|
2020-03-15 03:20:23 +08:00
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
|
2020-03-15 03:20:23 +08:00
|
|
|
func TestPayloadInt(t *testing.T) {
|
|
|
|
tests := []payloadTest{
|
|
|
|
{
|
|
|
|
data: map[string]interface{}{"user_id": 42},
|
|
|
|
key: "user_id",
|
|
|
|
nonkey: "unknown",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
|
|
|
payload := Payload{tc.data}
|
|
|
|
|
|
|
|
got, err := payload.GetInt(tc.key)
|
|
|
|
if err != nil || got != tc.data[tc.key] {
|
|
|
|
t.Errorf("Payload.GetInt(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// encode and then decode task messsage.
|
|
|
|
in := h.NewTaskMessage("testing", tc.data)
|
2020-06-12 11:58:27 +08:00
|
|
|
encoded, err := base.EncodeMessage(in)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-06-12 11:58:27 +08:00
|
|
|
out, err := base.DecodeMessage(encoded)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
payload = Payload{out.Payload}
|
|
|
|
got, err = payload.GetInt(tc.key)
|
|
|
|
if err != nil || got != tc.data[tc.key] {
|
|
|
|
t.Errorf("With Marshaling: Payload.GetInt(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// access non-existent key.
|
|
|
|
got, err = payload.GetInt(tc.nonkey)
|
|
|
|
if err == nil || got != 0 {
|
|
|
|
t.Errorf("Payload.GetInt(%q) = %v, %v; want 0, error",
|
|
|
|
tc.key, got, err)
|
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
}
|
2020-03-15 03:20:23 +08:00
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
|
2020-03-15 03:20:23 +08:00
|
|
|
func TestPayloadFloat64(t *testing.T) {
|
|
|
|
tests := []payloadTest{
|
|
|
|
{
|
|
|
|
data: map[string]interface{}{"pi": 3.14},
|
|
|
|
key: "pi",
|
|
|
|
nonkey: "unknown",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
|
|
|
payload := Payload{tc.data}
|
|
|
|
|
|
|
|
got, err := payload.GetFloat64(tc.key)
|
|
|
|
if err != nil || got != tc.data[tc.key] {
|
|
|
|
t.Errorf("Payload.GetFloat64(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// encode and then decode task messsage.
|
|
|
|
in := h.NewTaskMessage("testing", tc.data)
|
2020-06-12 11:58:27 +08:00
|
|
|
encoded, err := base.EncodeMessage(in)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-06-12 11:58:27 +08:00
|
|
|
out, err := base.DecodeMessage(encoded)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
payload = Payload{out.Payload}
|
|
|
|
got, err = payload.GetFloat64(tc.key)
|
|
|
|
if err != nil || got != tc.data[tc.key] {
|
|
|
|
t.Errorf("With Marshaling: Payload.GetFloat64(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// access non-existent key.
|
|
|
|
got, err = payload.GetFloat64(tc.nonkey)
|
|
|
|
if err == nil || got != 0 {
|
|
|
|
t.Errorf("Payload.GetFloat64(%q) = %v, %v; want 0, error",
|
|
|
|
tc.key, got, err)
|
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
}
|
2020-03-15 03:20:23 +08:00
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
|
2020-03-15 03:20:23 +08:00
|
|
|
func TestPayloadBool(t *testing.T) {
|
|
|
|
tests := []payloadTest{
|
|
|
|
{
|
|
|
|
data: map[string]interface{}{"enabled": true},
|
|
|
|
key: "enabled",
|
|
|
|
nonkey: "unknown",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
|
|
|
payload := Payload{tc.data}
|
|
|
|
|
|
|
|
got, err := payload.GetBool(tc.key)
|
|
|
|
if err != nil || got != tc.data[tc.key] {
|
|
|
|
t.Errorf("Payload.GetBool(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// encode and then decode task messsage.
|
|
|
|
in := h.NewTaskMessage("testing", tc.data)
|
2020-06-12 11:58:27 +08:00
|
|
|
encoded, err := base.EncodeMessage(in)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-06-12 11:58:27 +08:00
|
|
|
out, err := base.DecodeMessage(encoded)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
payload = Payload{out.Payload}
|
|
|
|
got, err = payload.GetBool(tc.key)
|
|
|
|
if err != nil || got != tc.data[tc.key] {
|
|
|
|
t.Errorf("With Marshaling: Payload.GetBool(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// access non-existent key.
|
|
|
|
got, err = payload.GetBool(tc.nonkey)
|
|
|
|
if err == nil || got != false {
|
|
|
|
t.Errorf("Payload.GetBool(%q) = %v, %v; want false, error",
|
|
|
|
tc.key, got, err)
|
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
}
|
2020-03-15 03:20:23 +08:00
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
|
2020-03-15 03:20:23 +08:00
|
|
|
func TestPayloadStringSlice(t *testing.T) {
|
|
|
|
tests := []payloadTest{
|
|
|
|
{
|
|
|
|
data: map[string]interface{}{"names": []string{"luke", "rey", "anakin"}},
|
|
|
|
key: "names",
|
|
|
|
nonkey: "unknown",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
|
|
|
payload := Payload{tc.data}
|
|
|
|
|
|
|
|
got, err := payload.GetStringSlice(tc.key)
|
|
|
|
diff := cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("Payload.GetStringSlice(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// encode and then decode task messsage.
|
|
|
|
in := h.NewTaskMessage("testing", tc.data)
|
2020-06-12 11:58:27 +08:00
|
|
|
encoded, err := base.EncodeMessage(in)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-06-12 11:58:27 +08:00
|
|
|
out, err := base.DecodeMessage(encoded)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
payload = Payload{out.Payload}
|
|
|
|
got, err = payload.GetStringSlice(tc.key)
|
|
|
|
diff = cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("With Marshaling: Payload.GetStringSlice(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// access non-existent key.
|
|
|
|
got, err = payload.GetStringSlice(tc.nonkey)
|
|
|
|
if err == nil || got != nil {
|
|
|
|
t.Errorf("Payload.GetStringSlice(%q) = %v, %v; want nil, error",
|
|
|
|
tc.key, got, err)
|
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
}
|
2020-03-15 03:20:23 +08:00
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
|
2020-03-15 03:20:23 +08:00
|
|
|
func TestPayloadIntSlice(t *testing.T) {
|
|
|
|
tests := []payloadTest{
|
|
|
|
{
|
|
|
|
data: map[string]interface{}{"nums": []int{9, 8, 7}},
|
|
|
|
key: "nums",
|
|
|
|
nonkey: "unknown",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
|
|
|
payload := Payload{tc.data}
|
|
|
|
|
|
|
|
got, err := payload.GetIntSlice(tc.key)
|
|
|
|
diff := cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("Payload.GetIntSlice(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// encode and then decode task messsage.
|
|
|
|
in := h.NewTaskMessage("testing", tc.data)
|
2020-06-12 11:58:27 +08:00
|
|
|
encoded, err := base.EncodeMessage(in)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-06-12 11:58:27 +08:00
|
|
|
out, err := base.DecodeMessage(encoded)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
payload = Payload{out.Payload}
|
|
|
|
got, err = payload.GetIntSlice(tc.key)
|
|
|
|
diff = cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("With Marshaling: Payload.GetIntSlice(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// access non-existent key.
|
|
|
|
got, err = payload.GetIntSlice(tc.nonkey)
|
|
|
|
if err == nil || got != nil {
|
|
|
|
t.Errorf("Payload.GetIntSlice(%q) = %v, %v; want nil, error",
|
|
|
|
tc.key, got, err)
|
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
}
|
2020-03-15 03:20:23 +08:00
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
|
2020-03-15 03:20:23 +08:00
|
|
|
func TestPayloadStringMap(t *testing.T) {
|
|
|
|
tests := []payloadTest{
|
|
|
|
{
|
|
|
|
data: map[string]interface{}{"user": map[string]interface{}{"name": "Jon Doe", "score": 2.2}},
|
|
|
|
key: "user",
|
|
|
|
nonkey: "unknown",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
|
|
|
payload := Payload{tc.data}
|
|
|
|
|
|
|
|
got, err := payload.GetStringMap(tc.key)
|
|
|
|
diff := cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("Payload.GetStringMap(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// encode and then decode task messsage.
|
|
|
|
in := h.NewTaskMessage("testing", tc.data)
|
2020-06-12 11:58:27 +08:00
|
|
|
encoded, err := base.EncodeMessage(in)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-06-12 11:58:27 +08:00
|
|
|
out, err := base.DecodeMessage(encoded)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
payload = Payload{out.Payload}
|
|
|
|
got, err = payload.GetStringMap(tc.key)
|
2020-06-12 11:58:27 +08:00
|
|
|
ignoreOpt := cmpopts.IgnoreMapEntries(func(key string, val interface{}) bool {
|
|
|
|
switch val.(type) {
|
|
|
|
case json.Number:
|
|
|
|
return true
|
|
|
|
default:
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
})
|
|
|
|
diff = cmp.Diff(got, tc.data[tc.key], ignoreOpt)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil || diff != "" {
|
2020-06-12 11:58:27 +08:00
|
|
|
t.Errorf("With Marshaling: Payload.GetStringMap(%q) = %v, %v, want %v, nil;(-want,+got)\n%s",
|
|
|
|
tc.key, got, err, tc.data[tc.key], diff)
|
2020-03-15 03:20:23 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// access non-existent key.
|
|
|
|
got, err = payload.GetStringMap(tc.nonkey)
|
|
|
|
if err == nil || got != nil {
|
|
|
|
t.Errorf("Payload.GetStringMap(%q) = %v, %v; want nil, error",
|
|
|
|
tc.key, got, err)
|
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
}
|
2020-03-15 03:20:23 +08:00
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
|
2020-03-15 03:20:23 +08:00
|
|
|
func TestPayloadStringMapString(t *testing.T) {
|
|
|
|
tests := []payloadTest{
|
|
|
|
{
|
|
|
|
data: map[string]interface{}{"address": map[string]string{"line": "123 Main St", "city": "San Francisco", "state": "CA"}},
|
|
|
|
key: "address",
|
|
|
|
nonkey: "unknown",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
|
|
|
payload := Payload{tc.data}
|
|
|
|
|
|
|
|
got, err := payload.GetStringMapString(tc.key)
|
|
|
|
diff := cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("Payload.GetStringMapString(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// encode and then decode task messsage.
|
|
|
|
in := h.NewTaskMessage("testing", tc.data)
|
2020-06-12 11:58:27 +08:00
|
|
|
encoded, err := base.EncodeMessage(in)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-06-12 11:58:27 +08:00
|
|
|
out, err := base.DecodeMessage(encoded)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
payload = Payload{out.Payload}
|
|
|
|
got, err = payload.GetStringMapString(tc.key)
|
|
|
|
diff = cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("With Marshaling: Payload.GetStringMapString(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// access non-existent key.
|
|
|
|
got, err = payload.GetStringMapString(tc.nonkey)
|
|
|
|
if err == nil || got != nil {
|
|
|
|
t.Errorf("Payload.GetStringMapString(%q) = %v, %v; want nil, error",
|
|
|
|
tc.key, got, err)
|
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-15 03:20:23 +08:00
|
|
|
func TestPayloadStringMapStringSlice(t *testing.T) {
|
2019-12-19 23:13:43 +08:00
|
|
|
favs := map[string][]string{
|
2020-03-14 05:18:18 +08:00
|
|
|
"movies": {"forrest gump", "star wars"},
|
2020-03-15 03:20:23 +08:00
|
|
|
"tv_shows": {"game of thrones", "HIMYM", "breaking bad"},
|
|
|
|
}
|
|
|
|
tests := []payloadTest{
|
|
|
|
{
|
|
|
|
data: map[string]interface{}{"favorites": favs},
|
|
|
|
key: "favorites",
|
|
|
|
nonkey: "unknown",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
|
|
|
payload := Payload{tc.data}
|
|
|
|
|
|
|
|
got, err := payload.GetStringMapStringSlice(tc.key)
|
|
|
|
diff := cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("Payload.GetStringMapStringSlice(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// encode and then decode task messsage.
|
|
|
|
in := h.NewTaskMessage("testing", tc.data)
|
2020-06-12 11:58:27 +08:00
|
|
|
encoded, err := base.EncodeMessage(in)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-06-12 11:58:27 +08:00
|
|
|
out, err := base.DecodeMessage(encoded)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
payload = Payload{out.Payload}
|
|
|
|
got, err = payload.GetStringMapStringSlice(tc.key)
|
|
|
|
diff = cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("With Marshaling: Payload.GetStringMapStringSlice(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// access non-existent key.
|
|
|
|
got, err = payload.GetStringMapStringSlice(tc.nonkey)
|
|
|
|
if err == nil || got != nil {
|
|
|
|
t.Errorf("Payload.GetStringMapStringSlice(%q) = %v, %v; want nil, error",
|
|
|
|
tc.key, got, err)
|
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
}
|
2020-03-15 03:20:23 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestPayloadStringMapInt(t *testing.T) {
|
2019-12-19 23:13:43 +08:00
|
|
|
counter := map[string]int{
|
|
|
|
"a": 1,
|
|
|
|
"b": 101,
|
|
|
|
"c": 42,
|
|
|
|
}
|
2020-03-15 03:20:23 +08:00
|
|
|
tests := []payloadTest{
|
|
|
|
{
|
|
|
|
data: map[string]interface{}{"counts": counter},
|
|
|
|
key: "counts",
|
|
|
|
nonkey: "unknown",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
|
|
|
payload := Payload{tc.data}
|
|
|
|
|
|
|
|
got, err := payload.GetStringMapInt(tc.key)
|
|
|
|
diff := cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("Payload.GetStringMapInt(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// encode and then decode task messsage.
|
|
|
|
in := h.NewTaskMessage("testing", tc.data)
|
2020-06-12 11:58:27 +08:00
|
|
|
encoded, err := base.EncodeMessage(in)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-06-12 11:58:27 +08:00
|
|
|
out, err := base.DecodeMessage(encoded)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
payload = Payload{out.Payload}
|
|
|
|
got, err = payload.GetStringMapInt(tc.key)
|
|
|
|
diff = cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("With Marshaling: Payload.GetStringMapInt(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// access non-existent key.
|
|
|
|
got, err = payload.GetStringMapInt(tc.nonkey)
|
|
|
|
if err == nil || got != nil {
|
|
|
|
t.Errorf("Payload.GetStringMapInt(%q) = %v, %v; want nil, error",
|
|
|
|
tc.key, got, err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPayloadStringMapBool(t *testing.T) {
|
2019-12-19 23:13:43 +08:00
|
|
|
features := map[string]bool{
|
|
|
|
"A": false,
|
|
|
|
"B": true,
|
|
|
|
"C": true,
|
|
|
|
}
|
2020-03-15 03:20:23 +08:00
|
|
|
tests := []payloadTest{
|
|
|
|
{
|
|
|
|
data: map[string]interface{}{"features": features},
|
|
|
|
key: "features",
|
|
|
|
nonkey: "unknown",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
|
|
|
payload := Payload{tc.data}
|
|
|
|
|
|
|
|
got, err := payload.GetStringMapBool(tc.key)
|
|
|
|
diff := cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("Payload.GetStringMapBool(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// encode and then decode task messsage.
|
|
|
|
in := h.NewTaskMessage("testing", tc.data)
|
2020-06-12 11:58:27 +08:00
|
|
|
encoded, err := base.EncodeMessage(in)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-06-12 11:58:27 +08:00
|
|
|
out, err := base.DecodeMessage(encoded)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
payload = Payload{out.Payload}
|
|
|
|
got, err = payload.GetStringMapBool(tc.key)
|
|
|
|
diff = cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("With Marshaling: Payload.GetStringMapBool(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// access non-existent key.
|
|
|
|
got, err = payload.GetStringMapBool(tc.nonkey)
|
|
|
|
if err == nil || got != nil {
|
|
|
|
t.Errorf("Payload.GetStringMapBool(%q) = %v, %v; want nil, error",
|
|
|
|
tc.key, got, err)
|
|
|
|
}
|
2019-12-19 23:13:43 +08:00
|
|
|
}
|
|
|
|
}
|
2019-12-21 12:14:40 +08:00
|
|
|
|
2020-03-15 03:20:23 +08:00
|
|
|
func TestPayloadTime(t *testing.T) {
|
|
|
|
tests := []payloadTest{
|
|
|
|
{
|
|
|
|
data: map[string]interface{}{"current": time.Now()},
|
|
|
|
key: "current",
|
|
|
|
nonkey: "unknown",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
|
|
|
payload := Payload{tc.data}
|
|
|
|
|
|
|
|
got, err := payload.GetTime(tc.key)
|
|
|
|
diff := cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("Payload.GetTime(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// encode and then decode task messsage.
|
|
|
|
in := h.NewTaskMessage("testing", tc.data)
|
2020-06-12 11:58:27 +08:00
|
|
|
encoded, err := base.EncodeMessage(in)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-06-12 11:58:27 +08:00
|
|
|
out, err := base.DecodeMessage(encoded)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
payload = Payload{out.Payload}
|
|
|
|
got, err = payload.GetTime(tc.key)
|
|
|
|
diff = cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("With Marshaling: Payload.GetTime(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// access non-existent key.
|
|
|
|
got, err = payload.GetTime(tc.nonkey)
|
|
|
|
if err == nil || !got.IsZero() {
|
|
|
|
t.Errorf("Payload.GetTime(%q) = %v, %v; want %v, error",
|
|
|
|
tc.key, got, err, time.Time{})
|
|
|
|
}
|
2020-01-06 00:50:43 +08:00
|
|
|
}
|
2020-03-15 03:20:23 +08:00
|
|
|
}
|
2020-01-06 00:50:43 +08:00
|
|
|
|
2020-03-15 03:20:23 +08:00
|
|
|
func TestPayloadDuration(t *testing.T) {
|
|
|
|
tests := []payloadTest{
|
|
|
|
{
|
|
|
|
data: map[string]interface{}{"duration": 15 * time.Minute},
|
|
|
|
key: "duration",
|
|
|
|
nonkey: "unknown",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tests {
|
|
|
|
payload := Payload{tc.data}
|
|
|
|
|
|
|
|
got, err := payload.GetDuration(tc.key)
|
|
|
|
diff := cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("Payload.GetDuration(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// encode and then decode task messsage.
|
|
|
|
in := h.NewTaskMessage("testing", tc.data)
|
2020-06-12 11:58:27 +08:00
|
|
|
encoded, err := base.EncodeMessage(in)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-06-12 11:58:27 +08:00
|
|
|
out, err := base.DecodeMessage(encoded)
|
2020-03-15 03:20:23 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
payload = Payload{out.Payload}
|
|
|
|
got, err = payload.GetDuration(tc.key)
|
|
|
|
diff = cmp.Diff(got, tc.data[tc.key])
|
|
|
|
if err != nil || diff != "" {
|
|
|
|
t.Errorf("With Marshaling: Payload.GetDuration(%q) = %v, %v, want %v, nil",
|
|
|
|
tc.key, got, err, tc.data[tc.key])
|
|
|
|
}
|
|
|
|
|
|
|
|
// access non-existent key.
|
|
|
|
got, err = payload.GetDuration(tc.nonkey)
|
|
|
|
if err == nil || got != 0 {
|
|
|
|
t.Errorf("Payload.GetDuration(%q) = %v, %v; want %v, error",
|
|
|
|
tc.key, got, err, time.Duration(0))
|
|
|
|
}
|
2020-01-06 00:50:43 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-12-21 12:14:40 +08:00
|
|
|
func TestPayloadHas(t *testing.T) {
|
2020-01-05 05:13:46 +08:00
|
|
|
payload := Payload{map[string]interface{}{
|
2019-12-21 12:14:40 +08:00
|
|
|
"user_id": 123,
|
2020-01-05 05:13:46 +08:00
|
|
|
}}
|
2019-12-21 12:14:40 +08:00
|
|
|
|
|
|
|
if !payload.Has("user_id") {
|
|
|
|
t.Errorf("Payload.Has(%q) = false, want true", "user_id")
|
|
|
|
}
|
|
|
|
if payload.Has("name") {
|
|
|
|
t.Errorf("Payload.Has(%q) = true, want false", "name")
|
|
|
|
}
|
|
|
|
}
|