mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-10-26 16:22:45 -04:00 
			
		
		
		
	I am not a lawyer, but according to the appendix of the license, these boilerplate notices should be included with every source file.
		
			
				
	
	
		
			110 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			110 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2015 Light Code Labs, LLC
 | |
| //
 | |
| // Licensed under the Apache License, Version 2.0 (the "License");
 | |
| // you may not use this file except in compliance with the License.
 | |
| // You may obtain a copy of the License at
 | |
| //
 | |
| //     http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing, software
 | |
| // distributed under the License is distributed on an "AS IS" BASIS,
 | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| // See the License for the specific language governing permissions and
 | |
| // limitations under the License.
 | |
| 
 | |
| package redirect
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/mholt/caddy"
 | |
| 	"github.com/mholt/caddy/caddyhttp/httpserver"
 | |
| )
 | |
| 
 | |
| func TestSetup(t *testing.T) {
 | |
| 
 | |
| 	for j, test := range []struct {
 | |
| 		input         string
 | |
| 		shouldErr     bool
 | |
| 		expectedRules []Rule
 | |
| 	}{
 | |
| 		// test case #0 tests the recognition of a valid HTTP status code defined outside of block statement
 | |
| 		{"redir 300 {\n/ /foo\n}", false, []Rule{{FromPath: "/", To: "/foo", Code: 300, RequestMatcher: httpserver.IfMatcher{}}}},
 | |
| 
 | |
| 		// test case #1 tests the recognition of an invalid HTTP status code defined outside of block statement
 | |
| 		{"redir 9000 {\n/ /foo\n}", true, []Rule{{}}},
 | |
| 
 | |
| 		// test case #2 tests the detection of a valid HTTP status code outside of a block statement being overridden by an invalid HTTP status code inside statement of a block statement
 | |
| 		{"redir 300 {\n/ /foo 9000\n}", true, []Rule{{}}},
 | |
| 
 | |
| 		// test case #3 tests the detection of an invalid HTTP status code outside of a block statement being overridden by a valid HTTP status code inside statement of a block statement
 | |
| 		{"redir 9000 {\n/ /foo 300\n}", true, []Rule{{}}},
 | |
| 
 | |
| 		// test case #4 tests the recognition of a TO redirection in a block statement.The HTTP status code is set to the default of 301 - MovedPermanently
 | |
| 		{"redir 302 {\n/foo\n}", false, []Rule{{FromPath: "/", To: "/foo", Code: 302, RequestMatcher: httpserver.IfMatcher{}}}},
 | |
| 
 | |
| 		// test case #5 tests the recognition of a TO and From redirection in a block statement
 | |
| 		{"redir {\n/bar /foo 303\n}", false, []Rule{{FromPath: "/bar", To: "/foo", Code: 303, RequestMatcher: httpserver.IfMatcher{}}}},
 | |
| 
 | |
| 		// test case #6 tests the recognition of a TO redirection in a non-block statement. The HTTP status code is set to the default of 301 - MovedPermanently
 | |
| 		{"redir /foo", false, []Rule{{FromPath: "/", To: "/foo", Code: 301, RequestMatcher: httpserver.IfMatcher{}}}},
 | |
| 
 | |
| 		// test case #7 tests the recognition of a TO and From redirection in a non-block statement
 | |
| 		{"redir /bar /foo 303", false, []Rule{{FromPath: "/bar", To: "/foo", Code: 303, RequestMatcher: httpserver.IfMatcher{}}}},
 | |
| 
 | |
| 		// test case #8 tests the recognition of multiple redirections
 | |
| 		{"redir {\n / /foo 304 \n} \n redir {\n /bar /foobar 305 \n}", false,
 | |
| 			[]Rule{{FromPath: "/", To: "/foo", Code: 304, RequestMatcher: httpserver.IfMatcher{}},
 | |
| 				{FromPath: "/bar", To: "/foobar", Code: 305, RequestMatcher: httpserver.IfMatcher{}}}},
 | |
| 
 | |
| 		// test case #9 tests the detection of duplicate redirections
 | |
| 		{"redir {\n /bar /foo 304 \n} redir {\n /bar /foo 304 \n}", true, []Rule{{}}},
 | |
| 
 | |
| 		// test case #10 tests the detection of a valid HTTP status code outside of a block statement being overridden by an valid HTTP status code inside statement of a block statement
 | |
| 		{"redir 300 {\n/ /foo 301\n}", false, []Rule{{FromPath: "/", To: "/foo", Code: 301, RequestMatcher: httpserver.IfMatcher{}}}},
 | |
| 
 | |
| 		// test case #11 tests the recognition of a matcher
 | |
| 		{"redir {\n if {port} is 80\n/ /foo\n}", false, []Rule{{FromPath: "/", To: "/foo", Code: 301,
 | |
| 			RequestMatcher: func() httpserver.IfMatcher {
 | |
| 				c := caddy.NewTestController("http", "{\n if {port} is 80\n}")
 | |
| 				matcher, _ := httpserver.SetupIfMatcher(c)
 | |
| 				return matcher.(httpserver.IfMatcher)
 | |
| 			}()}}},
 | |
| 
 | |
| 		// test case #12 tests the detection of a valid HTTP status code outside of a block statement with a matcher
 | |
| 		{"redir 300 {\n if {port} is 80\n/ /foo\n}", false, []Rule{{FromPath: "/", To: "/foo", Code: 300,
 | |
| 			RequestMatcher: func() httpserver.IfMatcher {
 | |
| 				c := caddy.NewTestController("http", "{\n if {port} is 80\n}")
 | |
| 				matcher, _ := httpserver.SetupIfMatcher(c)
 | |
| 				return matcher.(httpserver.IfMatcher)
 | |
| 			}()}}},
 | |
| 	} {
 | |
| 		c := caddy.NewTestController("http", test.input)
 | |
| 		err := setup(c)
 | |
| 		if err != nil && !test.shouldErr {
 | |
| 			t.Errorf("Test case #%d received an error of %v", j, err)
 | |
| 		} else if test.shouldErr {
 | |
| 			continue
 | |
| 		}
 | |
| 		mids := httpserver.GetConfig(c).Middleware()
 | |
| 		receivedRules := mids[len(mids)-1](nil).(Redirect).Rules
 | |
| 
 | |
| 		for i, receivedRule := range receivedRules {
 | |
| 			if receivedRule.FromPath != test.expectedRules[i].FromPath {
 | |
| 				t.Errorf("Test case #%d.%d expected a from path of %s, but received a from path of %s", j, i, test.expectedRules[i].FromPath, receivedRule.FromPath)
 | |
| 			}
 | |
| 			if receivedRule.To != test.expectedRules[i].To {
 | |
| 				t.Errorf("Test case #%d.%d expected a TO path of %s, but received a TO path of %s", j, i, test.expectedRules[i].To, receivedRule.To)
 | |
| 			}
 | |
| 			if receivedRule.Code != test.expectedRules[i].Code {
 | |
| 				t.Errorf("Test case #%d.%d expected a HTTP status code of %d, but received a code of %d", j, i, test.expectedRules[i].Code, receivedRule.Code)
 | |
| 			}
 | |
| 			if gotMatcher, expectMatcher := fmt.Sprint(receivedRule.RequestMatcher), fmt.Sprint(test.expectedRules[i].RequestMatcher); gotMatcher != expectMatcher {
 | |
| 				t.Errorf("Test case #%d.%d expected a Matcher %s, but received a Matcher %s", j, i, expectMatcher, gotMatcher)
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| }
 |