2016-06-05 22:51:56 -05:00
|
|
|
package header
|
|
|
|
|
|
|
|
import (
|
2016-09-27 02:35:13 -05:00
|
|
|
"fmt"
|
2016-06-05 22:51:56 -05:00
|
|
|
"net/http"
|
|
|
|
"net/http/httptest"
|
|
|
|
"os"
|
2016-07-20 16:23:55 -05:00
|
|
|
"reflect"
|
|
|
|
"sort"
|
2016-06-05 22:51:56 -05:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/mholt/caddy/caddyhttp/httpserver"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestHeader(t *testing.T) {
|
|
|
|
hostname, err := os.Hostname()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Could not determine hostname: %v", err)
|
|
|
|
}
|
|
|
|
for i, test := range []struct {
|
|
|
|
from string
|
|
|
|
name string
|
|
|
|
value string
|
|
|
|
}{
|
|
|
|
{"/a", "Foo", "Bar"},
|
|
|
|
{"/a", "Bar", ""},
|
|
|
|
{"/a", "Baz", ""},
|
2016-11-01 23:08:02 -05:00
|
|
|
{"/a", "Server", ""},
|
2016-06-05 22:51:56 -05:00
|
|
|
{"/a", "ServerName", hostname},
|
|
|
|
{"/b", "Foo", ""},
|
|
|
|
{"/b", "Bar", "Removed in /a"},
|
|
|
|
} {
|
|
|
|
he := Headers{
|
|
|
|
Next: httpserver.HandlerFunc(func(w http.ResponseWriter, r *http.Request) (int, error) {
|
2016-09-27 02:35:13 -05:00
|
|
|
w.Header().Set("Bar", "Removed in /a")
|
2016-11-01 23:08:02 -05:00
|
|
|
w.WriteHeader(http.StatusOK)
|
2016-06-05 22:51:56 -05:00
|
|
|
return 0, nil
|
|
|
|
}),
|
|
|
|
Rules: []Rule{
|
2016-11-03 13:24:26 -05:00
|
|
|
{Path: "/a", Headers: http.Header{
|
|
|
|
"Foo": []string{"Bar"},
|
|
|
|
"ServerName": []string{"{hostname}"},
|
|
|
|
"-Bar": []string{""},
|
|
|
|
"-Server": []string{},
|
2016-06-05 22:51:56 -05:00
|
|
|
}},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
req, err := http.NewRequest("GET", test.from, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Test %d: Could not create HTTP request: %v", i, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
rec := httptest.NewRecorder()
|
2016-11-01 23:08:02 -05:00
|
|
|
// preset header
|
|
|
|
rec.Header().Set("Server", "Caddy")
|
2016-06-05 22:51:56 -05:00
|
|
|
|
|
|
|
he.ServeHTTP(rec, req)
|
|
|
|
|
|
|
|
if got := rec.Header().Get(test.name); got != test.value {
|
|
|
|
t.Errorf("Test %d: Expected %s header to be %q but was %q",
|
|
|
|
i, test.name, test.value, got)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-07-20 16:23:55 -05:00
|
|
|
|
|
|
|
func TestMultipleHeaders(t *testing.T) {
|
|
|
|
he := Headers{
|
|
|
|
Next: httpserver.HandlerFunc(func(w http.ResponseWriter, r *http.Request) (int, error) {
|
2016-09-27 02:35:13 -05:00
|
|
|
fmt.Fprint(w, "This is a test")
|
2016-07-20 16:23:55 -05:00
|
|
|
return 0, nil
|
|
|
|
}),
|
|
|
|
Rules: []Rule{
|
2016-11-03 13:24:26 -05:00
|
|
|
{Path: "/a", Headers: http.Header{
|
|
|
|
"+Link": []string{"</images/image.png>; rel=preload", "</css/main.css>; rel=preload"},
|
2016-07-20 16:23:55 -05:00
|
|
|
}},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
req, err := http.NewRequest("GET", "/a", nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Could not create HTTP request: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
rec := httptest.NewRecorder()
|
|
|
|
he.ServeHTTP(rec, req)
|
|
|
|
|
|
|
|
desiredHeaders := []string{"</css/main.css>; rel=preload", "</images/image.png>; rel=preload"}
|
|
|
|
actualHeaders := rec.HeaderMap[http.CanonicalHeaderKey("Link")]
|
|
|
|
sort.Strings(actualHeaders)
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(desiredHeaders, actualHeaders) {
|
|
|
|
t.Errorf("Expected header to contain: %v but got: %v", desiredHeaders, actualHeaders)
|
|
|
|
}
|
|
|
|
}
|