mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-11-03 19:17:29 -05:00 
			
		
		
		
	* Very simple fix for #1153 * Prevent Caddy-Rewrite-Original-URI being added as an HTTP ENV variable passed to FastCGI part of fix for #1153 * Changes to Markdown to fix travis CI build. #1955.2 * Revert "Changes to Markdown to fix travis CI build." This reverts commit 4a018888395b7a90c57faf9ebb8ef04c4e6fe702. * fail fast and fmt changes * Create test for existance of Caddy-Rewrite-Original-URI header value #1153 * updated test comment * const moved outside function so available to tests
		
			
				
	
	
		
			210 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			210 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package fastcgi
 | 
						|
 | 
						|
import (
 | 
						|
	"fmt"
 | 
						|
	"reflect"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/mholt/caddy"
 | 
						|
	"github.com/mholt/caddy/caddyhttp/httpserver"
 | 
						|
)
 | 
						|
 | 
						|
func TestSetup(t *testing.T) {
 | 
						|
	c := caddy.NewTestController("http", `fastcgi / 127.0.0.1:9000`)
 | 
						|
	err := setup(c)
 | 
						|
	if err != nil {
 | 
						|
		t.Errorf("Expected no errors, got: %v", err)
 | 
						|
	}
 | 
						|
	mids := httpserver.GetConfig(c).Middleware()
 | 
						|
	if len(mids) == 0 {
 | 
						|
		t.Fatal("Expected middleware, got 0 instead")
 | 
						|
	}
 | 
						|
 | 
						|
	handler := mids[0](httpserver.EmptyNext)
 | 
						|
	myHandler, ok := handler.(Handler)
 | 
						|
 | 
						|
	if !ok {
 | 
						|
		t.Fatalf("Expected handler to be type , got: %#v", handler)
 | 
						|
	}
 | 
						|
 | 
						|
	if myHandler.Rules[0].Path != "/" {
 | 
						|
		t.Errorf("Expected / as the Path")
 | 
						|
	}
 | 
						|
	if myHandler.Rules[0].Address != "127.0.0.1:9000" {
 | 
						|
		t.Errorf("Expected 127.0.0.1:9000 as the Address")
 | 
						|
	}
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
func (p *persistentDialer) Equals(q *persistentDialer) bool {
 | 
						|
	if p.size != q.size {
 | 
						|
		return false
 | 
						|
	}
 | 
						|
	if p.network != q.network {
 | 
						|
		return false
 | 
						|
	}
 | 
						|
	if p.address != q.address {
 | 
						|
		return false
 | 
						|
	}
 | 
						|
 | 
						|
	if len(p.pool) != len(q.pool) {
 | 
						|
		return false
 | 
						|
	}
 | 
						|
	for i, client := range p.pool {
 | 
						|
		if client != q.pool[i] {
 | 
						|
			return false
 | 
						|
		}
 | 
						|
	}
 | 
						|
	// ignore mutex state
 | 
						|
	return true
 | 
						|
}
 | 
						|
 | 
						|
func TestFastcgiParse(t *testing.T) {
 | 
						|
	defaultAddress := "127.0.0.1:9001"
 | 
						|
	network, address := parseAddress(defaultAddress)
 | 
						|
	t.Logf("Address '%v' was parsed to network '%v' and address '%v'", defaultAddress, network, address)
 | 
						|
 | 
						|
	tests := []struct {
 | 
						|
		inputFastcgiConfig    string
 | 
						|
		shouldErr             bool
 | 
						|
		expectedFastcgiConfig []Rule
 | 
						|
	}{
 | 
						|
 | 
						|
		{`fastcgi /blog 127.0.0.1:9000 php`,
 | 
						|
			false, []Rule{{
 | 
						|
				Path:       "/blog",
 | 
						|
				Address:    "127.0.0.1:9000",
 | 
						|
				Ext:        ".php",
 | 
						|
				SplitPath:  ".php",
 | 
						|
				dialer:     basicDialer{network: "tcp", address: "127.0.0.1:9000"},
 | 
						|
				IndexFiles: []string{"index.php"},
 | 
						|
			}}},
 | 
						|
		{`fastcgi / ` + defaultAddress + ` {
 | 
						|
	              split .html
 | 
						|
	              }`,
 | 
						|
			false, []Rule{{
 | 
						|
				Path:       "/",
 | 
						|
				Address:    defaultAddress,
 | 
						|
				Ext:        "",
 | 
						|
				SplitPath:  ".html",
 | 
						|
				dialer:     basicDialer{network: network, address: address},
 | 
						|
				IndexFiles: []string{},
 | 
						|
			}}},
 | 
						|
		{`fastcgi / ` + defaultAddress + ` {
 | 
						|
	              split .html
 | 
						|
	              except /admin /user
 | 
						|
	              }`,
 | 
						|
			false, []Rule{{
 | 
						|
				Path:            "/",
 | 
						|
				Address:         "127.0.0.1:9001",
 | 
						|
				Ext:             "",
 | 
						|
				SplitPath:       ".html",
 | 
						|
				dialer:          basicDialer{network: network, address: address},
 | 
						|
				IndexFiles:      []string{},
 | 
						|
				IgnoredSubPaths: []string{"/admin", "/user"},
 | 
						|
			}}},
 | 
						|
		{`fastcgi / ` + defaultAddress + ` {
 | 
						|
	              pool 0
 | 
						|
	              }`,
 | 
						|
			false, []Rule{{
 | 
						|
				Path:       "/",
 | 
						|
				Address:    defaultAddress,
 | 
						|
				Ext:        "",
 | 
						|
				SplitPath:  "",
 | 
						|
				dialer:     &persistentDialer{size: 0, network: network, address: address},
 | 
						|
				IndexFiles: []string{},
 | 
						|
			}}},
 | 
						|
		{`fastcgi / ` + defaultAddress + ` {
 | 
						|
	              pool 5
 | 
						|
	              }`,
 | 
						|
			false, []Rule{{
 | 
						|
				Path:       "/",
 | 
						|
				Address:    defaultAddress,
 | 
						|
				Ext:        "",
 | 
						|
				SplitPath:  "",
 | 
						|
				dialer:     &persistentDialer{size: 5, network: network, address: address},
 | 
						|
				IndexFiles: []string{},
 | 
						|
			}}},
 | 
						|
		{`fastcgi / ` + defaultAddress + ` {
 | 
						|
	              split .php
 | 
						|
	              }`,
 | 
						|
			false, []Rule{{
 | 
						|
				Path:       "/",
 | 
						|
				Address:    defaultAddress,
 | 
						|
				Ext:        "",
 | 
						|
				SplitPath:  ".php",
 | 
						|
				dialer:     basicDialer{network: network, address: address},
 | 
						|
				IndexFiles: []string{},
 | 
						|
			}}},
 | 
						|
	}
 | 
						|
	for i, test := range tests {
 | 
						|
		actualFastcgiConfigs, err := fastcgiParse(caddy.NewTestController("http", test.inputFastcgiConfig))
 | 
						|
 | 
						|
		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)
 | 
						|
		}
 | 
						|
		if len(actualFastcgiConfigs) != len(test.expectedFastcgiConfig) {
 | 
						|
			t.Fatalf("Test %d expected %d no of FastCGI configs, but got %d ",
 | 
						|
				i, len(test.expectedFastcgiConfig), len(actualFastcgiConfigs))
 | 
						|
		}
 | 
						|
		for j, actualFastcgiConfig := range actualFastcgiConfigs {
 | 
						|
 | 
						|
			if actualFastcgiConfig.Path != test.expectedFastcgiConfig[j].Path {
 | 
						|
				t.Errorf("Test %d expected %dth FastCGI Path to be  %s  , but got %s",
 | 
						|
					i, j, test.expectedFastcgiConfig[j].Path, actualFastcgiConfig.Path)
 | 
						|
			}
 | 
						|
 | 
						|
			if actualFastcgiConfig.Address != test.expectedFastcgiConfig[j].Address {
 | 
						|
				t.Errorf("Test %d expected %dth FastCGI Address to be  %s  , but got %s",
 | 
						|
					i, j, test.expectedFastcgiConfig[j].Address, actualFastcgiConfig.Address)
 | 
						|
			}
 | 
						|
 | 
						|
			if actualFastcgiConfig.Ext != test.expectedFastcgiConfig[j].Ext {
 | 
						|
				t.Errorf("Test %d expected %dth FastCGI Ext to be  %s  , but got %s",
 | 
						|
					i, j, test.expectedFastcgiConfig[j].Ext, actualFastcgiConfig.Ext)
 | 
						|
			}
 | 
						|
 | 
						|
			if actualFastcgiConfig.SplitPath != test.expectedFastcgiConfig[j].SplitPath {
 | 
						|
				t.Errorf("Test %d expected %dth FastCGI SplitPath to be  %s  , but got %s",
 | 
						|
					i, j, test.expectedFastcgiConfig[j].SplitPath, actualFastcgiConfig.SplitPath)
 | 
						|
			}
 | 
						|
 | 
						|
			if reflect.TypeOf(actualFastcgiConfig.dialer) != reflect.TypeOf(test.expectedFastcgiConfig[j].dialer) {
 | 
						|
				t.Errorf("Test %d expected %dth FastCGI dialer to be of type %T, but got %T",
 | 
						|
					i, j, test.expectedFastcgiConfig[j].dialer, actualFastcgiConfig.dialer)
 | 
						|
			} else {
 | 
						|
				equal := true
 | 
						|
				switch actual := actualFastcgiConfig.dialer.(type) {
 | 
						|
				case basicDialer:
 | 
						|
					equal = actualFastcgiConfig.dialer == test.expectedFastcgiConfig[j].dialer
 | 
						|
				case *persistentDialer:
 | 
						|
					if expected, ok := test.expectedFastcgiConfig[j].dialer.(*persistentDialer); ok {
 | 
						|
						equal = actual.Equals(expected)
 | 
						|
					} else {
 | 
						|
						equal = false
 | 
						|
					}
 | 
						|
				default:
 | 
						|
					t.Errorf("Unkonw dialer type %T", actualFastcgiConfig.dialer)
 | 
						|
				}
 | 
						|
				if !equal {
 | 
						|
					t.Errorf("Test %d expected %dth FastCGI dialer to be %v, but got %v",
 | 
						|
						i, j, test.expectedFastcgiConfig[j].dialer, actualFastcgiConfig.dialer)
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			if fmt.Sprint(actualFastcgiConfig.IndexFiles) != fmt.Sprint(test.expectedFastcgiConfig[j].IndexFiles) {
 | 
						|
				t.Errorf("Test %d expected %dth FastCGI IndexFiles to be  %s  , but got %s",
 | 
						|
					i, j, test.expectedFastcgiConfig[j].IndexFiles, actualFastcgiConfig.IndexFiles)
 | 
						|
			}
 | 
						|
 | 
						|
			if fmt.Sprint(actualFastcgiConfig.IgnoredSubPaths) != fmt.Sprint(test.expectedFastcgiConfig[j].IgnoredSubPaths) {
 | 
						|
				t.Errorf("Test %d expected %dth FastCGI IgnoredSubPaths to be  %s  , but got %s",
 | 
						|
					i, j, test.expectedFastcgiConfig[j].IgnoredSubPaths, actualFastcgiConfig.IgnoredSubPaths)
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
}
 |