filter_test.go 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. package qs
  2. import (
  3. "errors"
  4. "testing"
  5. )
  6. func TestReadFilters(t *testing.T) {
  7. type TestCase struct {
  8. Input string
  9. Opt *ReadFiltersOptions
  10. Output []Filter
  11. Err error
  12. }
  13. testCases := []TestCase{
  14. {Input: ""},
  15. {
  16. Input: "filter=title eq Spaghetti",
  17. Output: []Filter{
  18. {Field: "title", Operator: "eq", Value: "Spaghetti"},
  19. },
  20. },
  21. {
  22. Input: "filter=title eq Bolognese&filter=serves gte 4",
  23. Output: []Filter{
  24. {Field: "title", Operator: "eq", Value: "Bolognese"},
  25. {Field: "serves", Operator: "gte", Value: "4"},
  26. },
  27. },
  28. }
  29. for n, tc := range testCases {
  30. t.Logf("(%d) Testing %q with options %+v", n, tc.Input, tc.Opt)
  31. filters, err := ReadStringFilters(tc.Input, nil)
  32. if !errors.Is(err, tc.Err) {
  33. t.Errorf("Expected error %v, got %v", tc.Err, err)
  34. }
  35. if tc.Err != nil {
  36. continue
  37. }
  38. if tc.Output == nil && filters != nil {
  39. t.Error("Expected nil")
  40. continue
  41. }
  42. if len(filters) != len(tc.Output) {
  43. t.Errorf("Expected %d filters, got %d", len(tc.Output), len(filters))
  44. }
  45. for i, filter := range tc.Output {
  46. if i == len(filters) {
  47. break
  48. }
  49. if filter != filters[i] {
  50. t.Errorf("Expected %+v for filter %d, got %+v", filter, i, filters[i])
  51. }
  52. }
  53. }
  54. }