mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-11-03 19:17:29 -05:00 
			
		
		
		
	This is a breaking change for those who expect catch-all redirects to preserve path; use {uri} variable explicitly now
		
	
			
		
			
				
	
	
		
			124 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package redirect
 | 
						|
 | 
						|
import (
 | 
						|
	"bytes"
 | 
						|
	"io/ioutil"
 | 
						|
	"net/http"
 | 
						|
	"net/http/httptest"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/mholt/caddy/middleware"
 | 
						|
)
 | 
						|
 | 
						|
func TestRedirect(t *testing.T) {
 | 
						|
	for i, test := range []struct {
 | 
						|
		from             string
 | 
						|
		expectedLocation string
 | 
						|
	}{
 | 
						|
		{"/from", "/to"},
 | 
						|
		{"/a", "/b"},
 | 
						|
		{"/aa", ""},
 | 
						|
		{"/", ""},
 | 
						|
		{"/a?foo=bar", "/b"},
 | 
						|
		{"/asdf?foo=bar", ""},
 | 
						|
		{"/foo#bar", ""},
 | 
						|
		{"/a#foo", "/b"},
 | 
						|
	} {
 | 
						|
		var nextCalled bool
 | 
						|
 | 
						|
		re := Redirect{
 | 
						|
			Next: middleware.HandlerFunc(func(w http.ResponseWriter, r *http.Request) (int, error) {
 | 
						|
				nextCalled = true
 | 
						|
				return 0, nil
 | 
						|
			}),
 | 
						|
			Rules: []Rule{
 | 
						|
				{From: "/from", To: "/to"},
 | 
						|
				{From: "/a", To: "/b"},
 | 
						|
			},
 | 
						|
		}
 | 
						|
 | 
						|
		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()
 | 
						|
		re.ServeHTTP(rec, req)
 | 
						|
 | 
						|
		if rec.Header().Get("Location") != test.expectedLocation {
 | 
						|
			t.Errorf("Test %d: Expected Location header to be %q but was %q",
 | 
						|
				i, test.expectedLocation, rec.Header().Get("Location"))
 | 
						|
		}
 | 
						|
 | 
						|
		if nextCalled && test.expectedLocation != "" {
 | 
						|
			t.Errorf("Test %d: Next handler was unexpectedly called", i)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestParametersRedirect(t *testing.T) {
 | 
						|
	re := Redirect{
 | 
						|
		Rules: []Rule{
 | 
						|
			{From: "/", Meta: false, To: "http://example.com{uri}"},
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	req, err := http.NewRequest("GET", "/a?b=c", nil)
 | 
						|
	if err != nil {
 | 
						|
		t.Fatalf("Test: Could not create HTTP request: %v", err)
 | 
						|
	}
 | 
						|
 | 
						|
	rec := httptest.NewRecorder()
 | 
						|
	re.ServeHTTP(rec, req)
 | 
						|
 | 
						|
	if rec.Header().Get("Location") != "http://example.com/a?b=c" {
 | 
						|
		t.Fatalf("Test: expected location header %q but was %q", "http://example.com/a?b=c", rec.Header().Get("Location"))
 | 
						|
	}
 | 
						|
 | 
						|
	re = Redirect{
 | 
						|
		Rules: []Rule{
 | 
						|
			{From: "/", Meta: false, To: "http://example.com/a{path}?b=c&{query}"},
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	req, err = http.NewRequest("GET", "/d?e=f", nil)
 | 
						|
	if err != nil {
 | 
						|
		t.Fatalf("Test: Could not create HTTP request: %v", err)
 | 
						|
	}
 | 
						|
 | 
						|
	re.ServeHTTP(rec, req)
 | 
						|
 | 
						|
	if "http://example.com/a/d?b=c&e=f" != rec.Header().Get("Location") {
 | 
						|
		t.Fatalf("Test: expected location header %q but was %q", "http://example.com/a/d?b=c&e=f", rec.Header().Get("Location"))
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestMetaRedirect(t *testing.T) {
 | 
						|
	re := Redirect{
 | 
						|
		Rules: []Rule{
 | 
						|
			{From: "/whatever", Meta: true, To: "/something"},
 | 
						|
			{From: "/", Meta: true, To: "https://example.com/"},
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	for i, test := range re.Rules {
 | 
						|
		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()
 | 
						|
		re.ServeHTTP(rec, req)
 | 
						|
 | 
						|
		body, err := ioutil.ReadAll(rec.Body)
 | 
						|
		if err != nil {
 | 
						|
			t.Fatalf("Test %d: Could not read HTTP response body: %v", i, err)
 | 
						|
		}
 | 
						|
		expectedSnippet := `<meta http-equiv="refresh" content="0; URL='` + test.To + `'">`
 | 
						|
		if !bytes.Contains(body, []byte(expectedSnippet)) {
 | 
						|
			t.Errorf("Test %d: Expected Response Body to contain %q but was %q",
 | 
						|
				i, expectedSnippet, body)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 |