-
Notifications
You must be signed in to change notification settings - Fork 158
/
Copy pathunsafe_test.go
123 lines (112 loc) · 2.98 KB
/
unsafe_test.go
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
// MIT License
// Copyright (c) 2020 Qi Yin <[email protected]>
package exstrings
import (
"fmt"
"strings"
"testing"
)
func TestUnsafeRepeat(t *testing.T) {
for _, tt := range RepeatTests {
a := UnsafeRepeat(tt.in, tt.count)
if !equal("Repeat(s)", a, tt.out, t) {
t.Errorf("Repeat(%v, %d) = %v; want %v", tt.in, tt.count, a, tt.out)
continue
}
}
}
func unsafeRepeatPanicRecover(s string, count int) (err error) {
defer func() {
if r := recover(); r != nil {
switch v := r.(type) {
case error:
err = v
default:
err = fmt.Errorf("%s", v)
}
}
}()
UnsafeRepeat(s, count)
return
}
// See Issue golang.org/issue/16237
func TestUnsafeRepeatCatchesOverflow(t *testing.T) {
tests := [...]struct {
s string
count int
errStr string
}{
0: {"--", -2147483647, "negative"},
1: {"", int(^uint(0) >> 1), ""},
2: {"-", 10, ""},
3: {"gopher", 0, ""},
4: {"-", -1, "negative"},
5: {"--", -102, "negative"},
6: {string(make([]byte, 255)), int((^uint(0))/255 + 1), "overflow"},
}
for i, tt := range tests {
err := unsafeRepeatPanicRecover(tt.s, tt.count)
if tt.errStr == "" {
if err != nil {
t.Errorf("#%d panicked %v", i, err)
}
continue
}
if err == nil || !strings.Contains(err.Error(), tt.errStr) {
t.Errorf("#%d expected %q got %q", i, tt.errStr, err)
}
}
}
func TestUnsafeJoin(t *testing.T) {
for _, v := range []struct {
in []string
out, sep string
}{
{[]string{}, "", "-"},
{[]string{"a"}, "a", "-"},
{[]string{"a", "b"}, "a-b", "-"},
{[]string{"a", "b", "c"}, "a-b-c", "-"},
{[]string{"a", "b", "c", "d"}, "a-b-c-d", "-"},
{[]string{"a", "b", "c", "d", "e"}, "a-b-c-d-e", "-"},
{[]string{"a", "b", "c", "d", "e", "f"}, "a-b-c-d-e-f", "-"},
} {
a := UnsafeJoin(v.in, v.sep)
if a != v.out {
t.Errorf("UnsafeJoin(%v, %s) = %v; want %v", v.in, v.sep, v.out, a)
continue
}
}
}
func TestUnsafeReplace(t *testing.T) {
var ReplaceTests = []struct {
in string
old, new string
n int
out string
}{
{"hello", "l", "L", 0, "hello"},
{"hello", "l", "L", -1, "heLLo"},
{"hello", "x", "X", -1, "hello"},
{"", "x", "X", -1, ""},
{"radar", "r", "<r>", -1, "<r>ada<r>"},
{"", "", "<>", -1, "<>"},
{"banana", "a", "<>", -1, "b<>n<>n<>"},
{"banana", "a", "<>", 1, "b<>nana"},
{"banana", "a", "<>", 1000, "b<>n<>n<>"},
{"banana", "an", "<>", -1, "b<><>a"},
{"banana", "ana", "<>", -1, "b<>na"},
{"banana", "", "<>", -1, "<>b<>a<>n<>a<>n<>a<>"},
{"banana", "", "<>", 10, "<>b<>a<>n<>a<>n<>a<>"},
{"banana", "", "<>", 6, "<>b<>a<>n<>a<>n<>a"},
{"banana", "", "<>", 5, "<>b<>a<>n<>a<>na"},
{"banana", "", "<>", 1, "<>banana"},
{"banana", "a", "a", -1, "banana"},
{"banana", "a", "a", 1, "banana"},
{"☺☻☹", "", "<>", -1, "<>☺<>☻<>☹<>"},
}
for _, tt := range ReplaceTests {
if s := UnsafeReplace(tt.in, tt.old, tt.new, tt.n); s != tt.out {
t.Errorf("UnsafeReplace(%q, %q, %q, %d) = %q, want %q", tt.in, tt.old, tt.new, tt.n, s, tt.out)
}
}
}