|
|
|
|
@ -101,11 +101,11 @@ func TestGetFilterFields(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
t.Run("Skip nil fields", func(t *testing.T) {
|
|
|
|
|
type TestFilter struct {
|
|
|
|
|
Alive *bool `filterfield:"alive,EQ"`
|
|
|
|
|
Id *int64 `filterfield:"id,EQ"`
|
|
|
|
|
Ids *[]uint `filterfield:"id,IN"`
|
|
|
|
|
IdsNot *[]uint `filterfield:"id,NOT_IN"`
|
|
|
|
|
FirstName *string `filterfield:"first_name,EQ"`
|
|
|
|
|
Alive *bool `filterfield:"alive;EQ"`
|
|
|
|
|
Id *int64 `filterfield:"id;EQ"`
|
|
|
|
|
Ids *[]uint `filterfield:"id;IN"`
|
|
|
|
|
IdsNot *[]uint `filterfield:"id;NOT_IN"`
|
|
|
|
|
FirstName *string `filterfield:"first_name;EQ"`
|
|
|
|
|
}
|
|
|
|
|
filter := TestFilter{}
|
|
|
|
|
result := getFilterFields(filter)
|
|
|
|
|
@ -119,7 +119,7 @@ func TestGetFilterFields(t *testing.T) {
|
|
|
|
|
)
|
|
|
|
|
type TestFilter struct {
|
|
|
|
|
Alive *bool
|
|
|
|
|
Id *int64 `funnytag:"created_at,LT"`
|
|
|
|
|
Id *int64 `funnytag:"created_at;LT"`
|
|
|
|
|
}
|
|
|
|
|
filter := TestFilter{
|
|
|
|
|
Alive: &alive,
|
|
|
|
|
@ -140,7 +140,7 @@ func TestFilterField(t *testing.T) {
|
|
|
|
|
testCases := []TagParseTestCase{
|
|
|
|
|
{
|
|
|
|
|
name: "Parse without spaces",
|
|
|
|
|
tagValue: "field=field_1,operator=EQ",
|
|
|
|
|
tagValue: "field=field_1;operator=EQ",
|
|
|
|
|
expected: FilterField{
|
|
|
|
|
Name: "field_1",
|
|
|
|
|
Operator: OperatorEQ,
|
|
|
|
|
@ -148,7 +148,7 @@ func TestFilterField(t *testing.T) {
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Parse spaces between pairs",
|
|
|
|
|
tagValue: " field=field_2 , operator=LT ",
|
|
|
|
|
tagValue: " field=field_2 ; operator=LT ",
|
|
|
|
|
expected: FilterField{
|
|
|
|
|
Name: "field_2",
|
|
|
|
|
Operator: OperatorLT,
|
|
|
|
|
@ -156,7 +156,7 @@ func TestFilterField(t *testing.T) {
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Parse spaces between around keys and values",
|
|
|
|
|
tagValue: "operator = LIKE , field = field_3",
|
|
|
|
|
tagValue: "operator = LIKE ; field = field_3",
|
|
|
|
|
expected: FilterField{
|
|
|
|
|
Name: "field_3",
|
|
|
|
|
Operator: OperatorLIKE,
|
|
|
|
|
@ -174,19 +174,19 @@ func TestFilterField(t *testing.T) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
t.Run("Fail on invalid tag value", func(t *testing.T) {
|
|
|
|
|
filterField, err := newFilterField("field=field_1=fail, operator=EQ")
|
|
|
|
|
filterField, err := newFilterField("field=field_1=fail; operator=EQ")
|
|
|
|
|
assert.Nil(t, filterField)
|
|
|
|
|
assert.EqualError(t, err, "invalid tag value: field=field_1=fail")
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("Fail on invalid operator", func(t *testing.T) {
|
|
|
|
|
filterField, err := newFilterField("field=field_1, operator=FAIL")
|
|
|
|
|
filterField, err := newFilterField("field=field_1; operator=FAIL")
|
|
|
|
|
assert.Nil(t, filterField)
|
|
|
|
|
assert.EqualError(t, err, "unknown operator: FAIL")
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("Fail on invalid value key", func(t *testing.T) {
|
|
|
|
|
filterField, err := newFilterField("failkey=field_1, operator=FAIL")
|
|
|
|
|
filterField, err := newFilterField("failkey=field_1; operator=FAIL")
|
|
|
|
|
assert.Nil(t, filterField)
|
|
|
|
|
assert.EqualError(t, err, "invalid value key: failkey")
|
|
|
|
|
})
|
|
|
|
|
|