page_test.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. package qs
  2. import "testing"
  3. func TestReadPage(t *testing.T) {
  4. type TestCase struct {
  5. Input string
  6. Opt *ReadPageOptions
  7. Output *Page
  8. Err error
  9. }
  10. testCases := []TestCase{
  11. {
  12. Input: "",
  13. Output: &Page{
  14. Pagination: &Pagination{},
  15. },
  16. },
  17. {
  18. Input: "limit=10&page=2",
  19. Output: &Page{
  20. Pagination: &Pagination{Limit: 10, Offset: 10, Page: 2},
  21. },
  22. },
  23. {
  24. Input: "limit=10&page=2&filter=title eq Spaghetti",
  25. Output: &Page{
  26. Pagination: &Pagination{Limit: 10, Offset: 10, Page: 2},
  27. Filters: []Filter{
  28. {Field: "title", Operator: "eq", Value: "Spaghetti"},
  29. },
  30. },
  31. },
  32. {
  33. Input: "limit=10&page=2&filter=title eq Spaghetti&sort=serves desc",
  34. Output: &Page{
  35. Pagination: &Pagination{Limit: 10, Offset: 10, Page: 2},
  36. Filters: []Filter{
  37. {Field: "title", Operator: "eq", Value: "Spaghetti"},
  38. },
  39. Sorts: []Sort{
  40. {Field: "serves", Direction: "desc"},
  41. },
  42. },
  43. },
  44. }
  45. for n, tc := range testCases {
  46. t.Logf("(%d) Testing %q with options %+v", n, tc.Input, tc.Opt)
  47. page, err := ReadStringPage(tc.Input, tc.Opt)
  48. if err != tc.Err {
  49. t.Errorf("Expected error %v, got %v", tc.Err, err)
  50. }
  51. if tc.Err != nil {
  52. continue
  53. }
  54. if tc.Output == nil && page != nil {
  55. t.Error("Expected nil")
  56. continue
  57. }
  58. // Compare pagination (see pagination_test.go)
  59. if *page.Pagination != *tc.Output.Pagination {
  60. t.Errorf("Expected %+v for pagination, got %+v", tc.Output, page.Pagination)
  61. }
  62. // Compare filters (see filter_test.go)
  63. if tc.Output.Filters == nil && page.Filters != nil {
  64. t.Error("Expected nil filters")
  65. }
  66. if len(page.Filters) != len(tc.Output.Filters) {
  67. t.Errorf("Expected %d filters, got %d", len(tc.Output.Filters), len(page.Filters))
  68. }
  69. for i, filter := range tc.Output.Filters {
  70. if i == len(page.Filters) {
  71. break
  72. }
  73. if filter != page.Filters[i] {
  74. t.Errorf("Expected %+v for filter %d, got %+v", filter, i, page.Filters[i])
  75. }
  76. }
  77. // Compare sorts (see sort_test.go)
  78. if tc.Output.Sorts == nil && page.Sorts != nil {
  79. t.Error("Expected nil sorts")
  80. }
  81. if len(page.Sorts) != len(tc.Output.Sorts) {
  82. t.Errorf("Expected %d sorts, got %d", len(tc.Output.Sorts), len(page.Sorts))
  83. }
  84. for i, sort := range tc.Output.Sorts {
  85. if i == len(page.Sorts) {
  86. break
  87. }
  88. if sort != page.Sorts[i] {
  89. t.Errorf("Expected %+v for sort %d, got %+v", sort, i, page.Sorts[i])
  90. }
  91. }
  92. }
  93. }