-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathfuzz_queue_test.go
More file actions
68 lines (60 loc) · 1.46 KB
/
fuzz_queue_test.go
File metadata and controls
68 lines (60 loc) · 1.46 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
package queue
import (
"encoding/json"
"reflect"
"testing"
)
func FuzzJobBindMatchesJSONUnmarshal(f *testing.F) {
seeds := [][]byte{
nil,
[]byte(""),
[]byte("null"),
[]byte("{}"),
[]byte(`{"id":1,"name":"ok"}`),
[]byte(`{"nested":{"ids":[1,2,3]}}`),
[]byte(`[]`),
[]byte(`{"id":`),
[]byte(`not-json`),
}
for _, seed := range seeds {
f.Add(seed)
}
f.Fuzz(func(t *testing.T, payload []byte) {
job := NewJob("job:fuzz:bind").Payload(payload)
var got map[string]any
err := job.Bind(&got)
var want map[string]any
wantErr := json.Unmarshal(payload, &want)
if (err == nil) != (wantErr == nil) {
t.Fatalf("Bind/json.Unmarshal success mismatch: bind=%v json=%v payload=%q", err, wantErr, payload)
}
if err == nil && !reflect.DeepEqual(got, want) {
t.Fatalf("Bind/json.Unmarshal result mismatch: got=%v want=%v payload=%q", got, want, payload)
}
})
}
func FuzzNormalizeQueueName(f *testing.F) {
for _, seed := range []string{
"",
"default",
"emails",
"jobs:critical",
" with-spaces ",
"UPPER",
"日本語",
} {
f.Add(seed)
}
f.Fuzz(func(t *testing.T, name string) {
got := normalizeQueueName(name)
if got == "" {
t.Fatal("normalizeQueueName returned empty string")
}
if name == "" && got != "default" {
t.Fatalf("expected empty name to normalize to default, got %q", got)
}
if name != "" && got != name {
t.Fatalf("expected non-empty name to remain unchanged, got %q want %q", got, name)
}
})
}