|
1 | 1 | package mux
|
2 | 2 |
|
3 | 3 | import (
|
| 4 | + "errors" |
4 | 5 | "net/http"
|
| 6 | + "reflect" |
5 | 7 | "regexp"
|
6 | 8 | "sync"
|
7 | 9 | "testing"
|
@@ -64,3 +66,89 @@ func testNewRouter(_ testing.TB, handler http.Handler) {
|
64 | 66 | r.Queries("orgID", "{orgID:[0-9]*?}")
|
65 | 67 | r.Host("{subdomain}.domain.com")
|
66 | 68 | }
|
| 69 | + |
| 70 | +func TestRouteMetadata(t *testing.T) { |
| 71 | + router := NewRouter() |
| 72 | + rw := NewRecorder() |
| 73 | + |
| 74 | + expectedMap := make(map[any]any) |
| 75 | + expectedMap["key"] = "value" |
| 76 | + |
| 77 | + router.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { |
| 78 | + route := CurrentRoute(r) |
| 79 | + metadata := route.GetMetadata() |
| 80 | + |
| 81 | + if !reflect.DeepEqual(metadata, expectedMap) { |
| 82 | + println(metadata) |
| 83 | + t.Fatalf("Expected map does not equal the metadata map") |
| 84 | + } |
| 85 | + |
| 86 | + }).Metadata("key", "value") |
| 87 | + |
| 88 | + router.HandleFunc("/single-value", func(w http.ResponseWriter, r *http.Request) { |
| 89 | + route := CurrentRoute(r) |
| 90 | + value, err := route.GetMetadataValue("key") |
| 91 | + if err != nil { |
| 92 | + t.Fatalf("Expected metadata value to be present, but gave error: %s", err) |
| 93 | + } |
| 94 | + |
| 95 | + stringValue, ok := value.(string) |
| 96 | + if !ok { |
| 97 | + t.Fatalf("Expected metadata value to be string, but was: %s", reflect.TypeOf(value)) |
| 98 | + } |
| 99 | + |
| 100 | + if stringValue != "value" { |
| 101 | + t.Fatalf("Expected metadata value to be '%s', but got '%s'", "value", stringValue) |
| 102 | + } |
| 103 | + |
| 104 | + _, err = route.GetMetadataValue("key2") |
| 105 | + if err == nil { |
| 106 | + t.Fatalf("Expected metadata key not to be present and error, but error was nil") |
| 107 | + } |
| 108 | + |
| 109 | + if !errors.Is(err, ErrMetadataKeyNotFound) { |
| 110 | + t.Fatalf("Expected error to be ErrMetadataKeyNotFound but got: %s", err) |
| 111 | + } |
| 112 | + |
| 113 | + }).Metadata("key", "value") |
| 114 | + |
| 115 | + router.HandleFunc("/single-value-fallback", func(w http.ResponseWriter, r *http.Request) { |
| 116 | + route := CurrentRoute(r) |
| 117 | + value := route.GetMetadataValueOr("key", "value-fallback") |
| 118 | + |
| 119 | + stringValue, ok := value.(string) |
| 120 | + if !ok { |
| 121 | + t.Fatalf("Expected metadata value to be string, but was: %s", reflect.TypeOf(value)) |
| 122 | + } |
| 123 | + |
| 124 | + if stringValue != "value" { |
| 125 | + t.Fatalf("Expected metadata value to be '%s', but got '%s'", "value", stringValue) |
| 126 | + } |
| 127 | + |
| 128 | + fallbackValue := route.GetMetadataValueOr("key2", "value2") |
| 129 | + fallbackStringValue, ok := fallbackValue.(string) |
| 130 | + if !ok { |
| 131 | + t.Fatalf("Expected metadata value to be string, but was: %s", reflect.TypeOf(value)) |
| 132 | + } |
| 133 | + |
| 134 | + if fallbackStringValue != "value2" { |
| 135 | + t.Fatalf("Expected metadata value to be '%s', but got '%s'", "value2", fallbackStringValue) |
| 136 | + } |
| 137 | + |
| 138 | + }).Metadata("key", "value") |
| 139 | + |
| 140 | + t.Run("get metadata map", func(t *testing.T) { |
| 141 | + req := newRequest("GET", "/") |
| 142 | + router.ServeHTTP(rw, req) |
| 143 | + }) |
| 144 | + |
| 145 | + t.Run("get metadata value", func(t *testing.T) { |
| 146 | + req := newRequest("GET", "/single-value") |
| 147 | + router.ServeHTTP(rw, req) |
| 148 | + }) |
| 149 | + |
| 150 | + t.Run("get metadata value or fallback", func(t *testing.T) { |
| 151 | + req := newRequest("GET", "/single-value-fallback") |
| 152 | + router.ServeHTTP(rw, req) |
| 153 | + }) |
| 154 | +} |
0 commit comments