-
Notifications
You must be signed in to change notification settings - Fork 0
/
joinType_test.go
113 lines (103 loc) · 3.02 KB
/
joinType_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
package squl
import (
"fmt"
"testing"
"github.com/stretchr/testify/assert"
)
func TestNewJoinType(t *testing.T) {
testCases := []struct {
shouldFail bool
enumTypeStr string
enumType JoinType
}{
{true, unknownStr, JoinType(Unknown)},
{false, "default", JoinTypeDefault},
{false, "inner", JoinTypeInner},
{false, "left", JoinTypeLeft},
{false, "outerLeft", JoinTypeOuterLeft},
{false, "right", JoinTypeRight},
{false, "outerRight", JoinTypeOuterRight},
{false, "full", JoinTypeFull},
{false, "outerFull", JoinTypeOuterFull},
{false, "cross", JoinTypeCross},
}
for i, testCase := range testCases {
actual, err := NewJoinType(testCase.enumTypeStr)
failMsg := fmt.Sprintf("testCase: %d %v", i, testCase)
if (err != nil) != testCase.shouldFail {
assert.Fail(t, failMsg, err)
}
assert.Equal(t, testCase.enumType, actual, failMsg)
}
}
func TestJoinType_String(t *testing.T) {
testCases := []struct {
enumType JoinType
enumTypeStr string
}{
{JoinType(Unknown), unknownStr},
{JoinTypeDefault, "default"},
{JoinTypeInner, "inner"},
{JoinTypeLeft, "left"},
{JoinTypeOuterLeft, "outerLeft"},
{JoinTypeRight, "right"},
{JoinTypeOuterRight, "outerRight"},
{JoinTypeFull, "full"},
{JoinTypeOuterFull, "outerFull"},
{JoinTypeCross, "cross"},
}
for i, testCase := range testCases {
failMsg := fmt.Sprintf("testCase: %d %v", i, testCase)
assert.Equal(t, testCase.enumTypeStr, testCase.enumType.String(), failMsg)
}
}
func TestJoinType_UnmarshalJSON(t *testing.T) {
testCases := []struct {
shouldFail bool
enumTypeJSONStr string
enumType JoinType
}{
{true, unknownJSONStr, JoinType(Unknown)},
{false, `"default"`, JoinTypeDefault},
{false, `"inner"`, JoinTypeInner},
{false, `"left"`, JoinTypeLeft},
{false, `"outerLeft"`, JoinTypeOuterLeft},
{false, `"right"`, JoinTypeRight},
{false, `"outerRight"`, JoinTypeOuterRight},
{false, `"full"`, JoinTypeFull},
{false, `"outerFull"`, JoinTypeOuterFull},
{false, `"cross"`, JoinTypeCross},
}
for i, testCase := range testCases {
actual := JoinType(Unknown)
err := actual.UnmarshalJSON([]byte(testCase.enumTypeJSONStr))
failMsg := fmt.Sprintf("testCase: %d %v", i, testCase)
if (err != nil) != testCase.shouldFail {
assert.Fail(t, failMsg, err)
}
assert.Equal(t, testCase.enumType, actual, failMsg)
}
}
func TestJoinType_MarshalJSON(t *testing.T) {
testCases := []struct {
enumType JoinType
enumTypeJSONStr string
}{
{JoinType(Unknown), unknownJSONStr},
{JoinTypeDefault, `"default"`},
{JoinTypeInner, `"inner"`},
{JoinTypeLeft, `"left"`},
{JoinTypeOuterLeft, `"outerLeft"`},
{JoinTypeRight, `"right"`},
{JoinTypeOuterRight, `"outerRight"`},
{JoinTypeFull, `"full"`},
{JoinTypeOuterFull, `"outerFull"`},
{JoinTypeCross, `"cross"`},
}
for i, testCase := range testCases {
failMsg := fmt.Sprintf("testCase: %d %v", i, testCase)
actual, err := testCase.enumType.MarshalJSON()
assert.Nil(t, err, failMsg)
assert.Equal(t, testCase.enumTypeJSONStr, string(actual), failMsg)
}
}