Skip to content

Commit

Permalink
feat: add tests for BuildSearchQuery
Browse files Browse the repository at this point in the history
  • Loading branch information
elraphty committed Dec 3, 2024
1 parent 3b261f4 commit 1058241
Show file tree
Hide file tree
Showing 2 changed files with 149 additions and 0 deletions.
4 changes: 4 additions & 0 deletions utils/utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,10 @@ func GetPaginationParams(r *http.Request) (int, int, string, string, string) {
}

func BuildSearchQuery(key string, term string) (string, string) {
// trim spaces
key = strings.TrimSpace(key)
term = strings.TrimSpace(term)

arg1 := key + " LIKE ?"
arg2 := "%" + term + "%"
return arg1, arg2
Expand Down
145 changes: 145 additions & 0 deletions utils/utils_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -99,3 +99,148 @@ func TestBuildV2KeysendBodyData(t *testing.T) {
})
}
}

func TestBuildSearchQuery(t *testing.T) {
tests := []struct {
name string
key string
term string
expectedQuery string
expectedArg string
}{
{
name: "Standard Input",
key: "name",
term: "John",
expectedQuery: "name LIKE ?",
expectedArg: "%John%",
},
{
name: "Empty Term",
key: "name",
term: "",
expectedQuery: "name LIKE ?",
expectedArg: "%%",
},
{
name: "Empty Key",
key: "",
term: "John",
expectedQuery: " LIKE ?",
expectedArg: "%John%",
},
{
name: "Both Key and Term Empty",
key: "",
term: "",
expectedQuery: " LIKE ?",
expectedArg: "%%",
},
{
name: "Special Characters in Key",
key: "user@name",
term: "John",
expectedQuery: "user@name LIKE ?",
expectedArg: "%John%",
},
{
name: "Special Characters in Term",
key: "name",
term: "J@hn",
expectedQuery: "name LIKE ?",
expectedArg: "%J@hn%",
},
{
name: "SQL Keywords in Key",
key: "SELECT",
term: "John",
expectedQuery: "SELECT LIKE ?",
expectedArg: "%John%",
},
{
name: "SQL Keywords in Term",
key: "name",
term: "SELECT",
expectedQuery: "name LIKE ?",
expectedArg: "%SELECT%",
},
{
name: "Null Key",
key: "",
term: "John",
expectedQuery: " LIKE ?",
expectedArg: "%John%",
},
{
name: "Null Term",
key: "name",
term: "",
expectedQuery: "name LIKE ?",
expectedArg: "%%",
},
{
name: "Non-String Key",
key: "123",
term: "John",
expectedQuery: "123 LIKE ?",
expectedArg: "%John%",
},
{
name: "Non-String Term",
key: "name",
term: "456",
expectedQuery: "name LIKE ?",
expectedArg: "%456%",
},
{
name: "Very Long Key",
key: string(make([]byte, 1000)),
term: "John",
expectedQuery: string(make([]byte, 1000)) + " LIKE ?",
expectedArg: "%John%",
},
{
name: "Very Long Term",
key: "name",
term: string(make([]byte, 1000)),
expectedQuery: "name LIKE ?",
expectedArg: "%" + string(make([]byte, 1000)) + "%",
},
{
name: "Unicode Characters in Key",
key: "名前",
term: "John",
expectedQuery: "名前 LIKE ?",
expectedArg: "%John%",
},
{
name: "Unicode Characters in Term",
key: "name",
term: "ジョン",
expectedQuery: "name LIKE ?",
expectedArg: "%ジョン%",
},
{
name: "Whitespace in Key",
key: " name ",
term: "John",
expectedQuery: "name LIKE ?",
expectedArg: "%John%",
},
{
name: "Whitespace in Term",
key: "name",
term: " John ",
expectedQuery: "name LIKE ?",
expectedArg: "%John%",
},
}

for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
query, arg := BuildSearchQuery(tt.key, tt.term)
assert.Equal(t, tt.expectedQuery, query)
assert.Equal(t, tt.expectedArg, arg)
})
}
}

0 comments on commit 1058241

Please sign in to comment.