2016-06-07 03:18:24 +03:00
|
|
|
package request
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
"net/url"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
var extractorTestTokenA = "A"
|
|
|
|
var extractorTestTokenB = "B"
|
|
|
|
|
|
|
|
var extractorTestData = []struct {
|
|
|
|
name string
|
|
|
|
extractor Extractor
|
|
|
|
headers map[string]string
|
|
|
|
query url.Values
|
|
|
|
token string
|
|
|
|
err error
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "simple header",
|
|
|
|
extractor: HeaderExtractor{"Foo"},
|
|
|
|
headers: map[string]string{"Foo": extractorTestTokenA},
|
|
|
|
query: nil,
|
|
|
|
token: extractorTestTokenA,
|
|
|
|
err: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "simple argument",
|
|
|
|
extractor: ArgumentExtractor{"token"},
|
|
|
|
headers: map[string]string{},
|
|
|
|
query: url.Values{"token": {extractorTestTokenA}},
|
|
|
|
token: extractorTestTokenA,
|
|
|
|
err: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "multiple extractors",
|
|
|
|
extractor: MultiExtractor{
|
|
|
|
HeaderExtractor{"Foo"},
|
|
|
|
ArgumentExtractor{"token"},
|
|
|
|
},
|
|
|
|
headers: map[string]string{"Foo": extractorTestTokenA},
|
|
|
|
query: url.Values{"token": {extractorTestTokenB}},
|
|
|
|
token: extractorTestTokenA,
|
|
|
|
err: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "simple miss",
|
|
|
|
extractor: HeaderExtractor{"This-Header-Is-Not-Set"},
|
|
|
|
headers: map[string]string{"Foo": extractorTestTokenA},
|
|
|
|
query: nil,
|
|
|
|
token: "",
|
|
|
|
err: ErrNoTokenInRequest,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "filter",
|
|
|
|
extractor: AuthorizationHeaderExtractor,
|
|
|
|
headers: map[string]string{"Authorization": "Bearer " + extractorTestTokenA},
|
|
|
|
query: nil,
|
|
|
|
token: extractorTestTokenA,
|
|
|
|
err: nil,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestExtractor(t *testing.T) {
|
|
|
|
// Bearer token request
|
|
|
|
for _, data := range extractorTestData {
|
|
|
|
// Make request from test struct
|
2016-06-07 03:45:30 +03:00
|
|
|
r := makeExampleRequest("GET", "/", data.headers, data.query)
|
2016-06-07 03:18:24 +03:00
|
|
|
|
|
|
|
// Test extractor
|
|
|
|
token, err := data.extractor.ExtractToken(r)
|
|
|
|
if token != data.token {
|
|
|
|
t.Errorf("[%v] Expected token '%v'. Got '%v'", data.name, data.token, token)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if err != data.err {
|
|
|
|
t.Errorf("[%v] Expected error '%v'. Got '%v'", data.name, data.err, err)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-06-07 03:45:30 +03:00
|
|
|
|
|
|
|
func makeExampleRequest(method, path string, headers map[string]string, urlArgs url.Values) *http.Request {
|
|
|
|
r, _ := http.NewRequest(method, fmt.Sprintf("%v?%v", path, urlArgs.Encode()), nil)
|
|
|
|
for k, v := range headers {
|
|
|
|
r.Header.Set(k, v)
|
|
|
|
}
|
|
|
|
return r
|
|
|
|
}
|
2022-08-19 14:59:36 +03:00
|
|
|
|
|
|
|
func TestBearerExtractor(t *testing.T) {
|
|
|
|
request := makeExampleRequest("POST", "https://example.com/", map[string]string{"Authorization": "Bearer ToKen"}, nil)
|
|
|
|
token, err := BearerExtractor{}.ExtractToken(request)
|
|
|
|
if err != nil || token != "ToKen" {
|
|
|
|
t.Errorf("ExtractToken did not return token, returned: %v, %v", token, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
request = makeExampleRequest("POST", "https://example.com/", map[string]string{"Authorization": "Bearo ToKen"}, nil)
|
|
|
|
token, err = BearerExtractor{}.ExtractToken(request)
|
|
|
|
if err == nil || token != "" {
|
|
|
|
t.Errorf("ExtractToken did not return error, returned: %v, %v", token, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
request = makeExampleRequest("POST", "https://example.com/", map[string]string{"Authorization": "BeArEr HeLO"}, nil)
|
|
|
|
token, err = BearerExtractor{}.ExtractToken(request)
|
|
|
|
if err != nil || token != "HeLO" {
|
|
|
|
t.Errorf("ExtractToken did not return token, returned: %v, %v", token, err)
|
|
|
|
}
|
|
|
|
}
|