2016-06-06 06:51:56 +03:00
|
|
|
package rewrite
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"regexp"
|
2017-07-30 18:33:59 +03:00
|
|
|
"strings"
|
2016-06-06 06:51:56 +03:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/mholt/caddy"
|
|
|
|
"github.com/mholt/caddy/caddyhttp/httpserver"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestSetup(t *testing.T) {
|
2016-06-20 20:44:20 +03:00
|
|
|
c := caddy.NewTestController("http", `rewrite /from /to`)
|
|
|
|
err := setup(c)
|
2016-06-06 06:51:56 +03:00
|
|
|
if err != nil {
|
|
|
|
t.Errorf("Expected no errors, but got: %v", err)
|
|
|
|
}
|
2016-06-20 20:44:20 +03:00
|
|
|
mids := httpserver.GetConfig(c).Middleware()
|
2016-06-06 06:51:56 +03:00
|
|
|
if len(mids) == 0 {
|
|
|
|
t.Fatal("Expected middleware, had 0 instead")
|
|
|
|
}
|
|
|
|
|
|
|
|
handler := mids[0](httpserver.EmptyNext)
|
|
|
|
myHandler, ok := handler.(Rewrite)
|
|
|
|
if !ok {
|
|
|
|
t.Fatalf("Expected handler to be type Rewrite, got: %#v", handler)
|
|
|
|
}
|
|
|
|
|
|
|
|
if !httpserver.SameNext(myHandler.Next, httpserver.EmptyNext) {
|
|
|
|
t.Error("'Next' field of handler was not set properly")
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(myHandler.Rules) != 1 {
|
|
|
|
t.Errorf("Expected handler to have %d rule, has %d instead", 1, len(myHandler.Rules))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRewriteParse(t *testing.T) {
|
|
|
|
simpleTests := []struct {
|
|
|
|
input string
|
|
|
|
shouldErr bool
|
|
|
|
expected []Rule
|
|
|
|
}{
|
|
|
|
{`rewrite /from /to`, false, []Rule{
|
|
|
|
SimpleRule{From: "/from", To: "/to"},
|
|
|
|
}},
|
|
|
|
{`rewrite /from /to
|
2017-05-02 18:30:18 +03:00
|
|
|
rewrite a b`, false, []Rule{
|
2016-06-06 06:51:56 +03:00
|
|
|
SimpleRule{From: "/from", To: "/to"},
|
2017-05-02 18:30:18 +03:00
|
|
|
SimpleRule{From: "a", To: "b"},
|
2016-06-06 06:51:56 +03:00
|
|
|
}},
|
|
|
|
{`rewrite a`, true, []Rule{}},
|
|
|
|
{`rewrite`, true, []Rule{}},
|
2017-05-02 18:30:18 +03:00
|
|
|
{`rewrite a b c`, false, []Rule{
|
2016-06-06 06:51:56 +03:00
|
|
|
SimpleRule{From: "a", To: "b c"},
|
|
|
|
}},
|
|
|
|
}
|
|
|
|
|
|
|
|
for i, test := range simpleTests {
|
2016-06-20 20:44:20 +03:00
|
|
|
actual, err := rewriteParse(caddy.NewTestController("http", test.input))
|
2016-06-06 06:51:56 +03:00
|
|
|
|
|
|
|
if err == nil && test.shouldErr {
|
|
|
|
t.Errorf("Test %d didn't error, but it should have", i)
|
|
|
|
} else if err != nil && !test.shouldErr {
|
|
|
|
t.Errorf("Test %d errored, but it shouldn't have; got '%v'", i, err)
|
|
|
|
} else if err != nil && test.shouldErr {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(actual) != len(test.expected) {
|
|
|
|
t.Fatalf("Test %d expected %d rules, but got %d",
|
|
|
|
i, len(test.expected), len(actual))
|
|
|
|
}
|
|
|
|
|
|
|
|
for j, e := range test.expected {
|
|
|
|
actualRule := actual[j].(SimpleRule)
|
|
|
|
expectedRule := e.(SimpleRule)
|
|
|
|
|
|
|
|
if actualRule.From != expectedRule.From {
|
|
|
|
t.Errorf("Test %d, rule %d: Expected From=%s, got %s",
|
|
|
|
i, j, expectedRule.From, actualRule.From)
|
|
|
|
}
|
|
|
|
|
|
|
|
if actualRule.To != expectedRule.To {
|
|
|
|
t.Errorf("Test %d, rule %d: Expected To=%s, got %s",
|
|
|
|
i, j, expectedRule.To, actualRule.To)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
regexpTests := []struct {
|
|
|
|
input string
|
|
|
|
shouldErr bool
|
|
|
|
expected []Rule
|
|
|
|
}{
|
|
|
|
{`rewrite {
|
|
|
|
r .*
|
|
|
|
to /to /index.php?
|
|
|
|
}`, false, []Rule{
|
2017-07-30 18:33:59 +03:00
|
|
|
ComplexRule{Base: "/", To: "/to /index.php?", Regexp: regexp.MustCompile(".*")},
|
2016-06-06 06:51:56 +03:00
|
|
|
}},
|
|
|
|
{`rewrite {
|
|
|
|
regexp .*
|
|
|
|
to /to
|
|
|
|
ext / html txt
|
|
|
|
}`, false, []Rule{
|
2017-07-30 18:33:59 +03:00
|
|
|
ComplexRule{Base: "/", To: "/to", Exts: []string{"/", "html", "txt"}, Regexp: regexp.MustCompile(".*")},
|
2016-06-06 06:51:56 +03:00
|
|
|
}},
|
|
|
|
{`rewrite /path {
|
|
|
|
r rr
|
|
|
|
to /dest
|
|
|
|
}
|
|
|
|
rewrite / {
|
|
|
|
regexp [a-z]+
|
|
|
|
to /to /to2
|
|
|
|
}
|
|
|
|
`, false, []Rule{
|
2017-07-30 18:33:59 +03:00
|
|
|
ComplexRule{Base: "/path", To: "/dest", Regexp: regexp.MustCompile("rr")},
|
|
|
|
ComplexRule{Base: "/", To: "/to /to2", Regexp: regexp.MustCompile("[a-z]+")},
|
2016-06-06 06:51:56 +03:00
|
|
|
}},
|
|
|
|
{`rewrite {
|
|
|
|
r .*
|
|
|
|
}`, true, []Rule{
|
2017-07-30 18:33:59 +03:00
|
|
|
ComplexRule{},
|
2016-06-06 06:51:56 +03:00
|
|
|
}},
|
|
|
|
{`rewrite {
|
|
|
|
|
|
|
|
}`, true, []Rule{
|
2017-07-30 18:33:59 +03:00
|
|
|
ComplexRule{},
|
2016-06-06 06:51:56 +03:00
|
|
|
}},
|
|
|
|
{`rewrite /`, true, []Rule{
|
2017-07-30 18:33:59 +03:00
|
|
|
ComplexRule{},
|
2016-06-06 06:51:56 +03:00
|
|
|
}},
|
2016-07-08 20:11:15 +03:00
|
|
|
{`rewrite {
|
|
|
|
if {path} match /
|
|
|
|
to /to
|
|
|
|
}`, false, []Rule{
|
2017-07-30 18:33:59 +03:00
|
|
|
ComplexRule{Base: "/", To: "/to"},
|
2016-07-08 20:11:15 +03:00
|
|
|
}},
|
2016-06-06 06:51:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
for i, test := range regexpTests {
|
2016-06-20 20:44:20 +03:00
|
|
|
actual, err := rewriteParse(caddy.NewTestController("http", test.input))
|
2016-06-06 06:51:56 +03:00
|
|
|
|
|
|
|
if err == nil && test.shouldErr {
|
|
|
|
t.Errorf("Test %d didn't error, but it should have", i)
|
|
|
|
} else if err != nil && !test.shouldErr {
|
|
|
|
t.Errorf("Test %d errored, but it shouldn't have; got '%v'", i, err)
|
|
|
|
} else if err != nil && test.shouldErr {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(actual) != len(test.expected) {
|
|
|
|
t.Fatalf("Test %d expected %d rules, but got %d",
|
|
|
|
i, len(test.expected), len(actual))
|
|
|
|
}
|
|
|
|
|
|
|
|
for j, e := range test.expected {
|
2017-07-30 18:33:59 +03:00
|
|
|
actualRule := actual[j].(ComplexRule)
|
|
|
|
expectedRule := e.(ComplexRule)
|
2016-06-06 06:51:56 +03:00
|
|
|
|
|
|
|
if actualRule.Base != expectedRule.Base {
|
|
|
|
t.Errorf("Test %d, rule %d: Expected Base=%s, got %s",
|
|
|
|
i, j, expectedRule.Base, actualRule.Base)
|
|
|
|
}
|
|
|
|
|
|
|
|
if actualRule.To != expectedRule.To {
|
|
|
|
t.Errorf("Test %d, rule %d: Expected To=%s, got %s",
|
|
|
|
i, j, expectedRule.To, actualRule.To)
|
|
|
|
}
|
|
|
|
|
|
|
|
if fmt.Sprint(actualRule.Exts) != fmt.Sprint(expectedRule.Exts) {
|
|
|
|
t.Errorf("Test %d, rule %d: Expected Ext=%v, got %v",
|
|
|
|
i, j, expectedRule.To, actualRule.To)
|
|
|
|
}
|
|
|
|
|
|
|
|
if actualRule.Regexp != nil {
|
2017-07-30 18:33:59 +03:00
|
|
|
if actualRule.Regexp.String() != expectedRule.Regexp.String() {
|
2016-06-06 06:51:56 +03:00
|
|
|
t.Errorf("Test %d, rule %d: Expected Pattern=%s, got %s",
|
2017-07-30 18:33:59 +03:00
|
|
|
i, j, actualRule.Regexp.String(), expectedRule.Regexp.String())
|
2016-06-06 06:51:56 +03:00
|
|
|
}
|
|
|
|
}
|
2017-07-30 18:33:59 +03:00
|
|
|
}
|
2016-06-06 06:51:56 +03:00
|
|
|
|
2017-07-30 18:33:59 +03:00
|
|
|
if rules_fmt := fmt.Sprintf("%v", actual); strings.HasPrefix(rules_fmt, "%!") {
|
|
|
|
t.Errorf("Test %d: Failed to string encode: %#v", i, rules_fmt)
|
2016-06-06 06:51:56 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|