mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-13 22:51:08 -05:00
69 lines
2 KiB
Go
69 lines
2 KiB
Go
package browse
|
|
|
|
import (
|
|
"io/ioutil"
|
|
"os"
|
|
"path/filepath"
|
|
"strconv"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/mholt/caddy"
|
|
"github.com/mholt/caddy/caddyhttp/httpserver"
|
|
)
|
|
|
|
func TestSetup(t *testing.T) {
|
|
tempDirPath := os.TempDir()
|
|
_, err := os.Stat(tempDirPath)
|
|
if err != nil {
|
|
t.Fatalf("BeforeTest: Failed to find an existing directory for testing! Error was: %v", err)
|
|
}
|
|
nonExistantDirPath := filepath.Join(tempDirPath, strconv.Itoa(int(time.Now().UnixNano())))
|
|
|
|
tempTemplate, err := ioutil.TempFile(".", "tempTemplate")
|
|
if err != nil {
|
|
t.Fatalf("BeforeTest: Failed to create a temporary file in the working directory! Error was: %v", err)
|
|
}
|
|
defer os.Remove(tempTemplate.Name())
|
|
|
|
tempTemplatePath := filepath.Join(".", tempTemplate.Name())
|
|
|
|
for i, test := range []struct {
|
|
input string
|
|
expectedPathScope []string
|
|
shouldErr bool
|
|
}{
|
|
// test case #0 tests handling of multiple pathscopes
|
|
{"browse " + tempDirPath + "\n browse .", []string{tempDirPath, "."}, false},
|
|
|
|
// test case #1 tests instantiation of Config with default values
|
|
{"browse /", []string{"/"}, false},
|
|
|
|
// test case #2 tests detectaction of custom template
|
|
{"browse . " + tempTemplatePath, []string{"."}, false},
|
|
|
|
// test case #3 tests detection of non-existent template
|
|
{"browse . " + nonExistantDirPath, nil, true},
|
|
|
|
// test case #4 tests detection of duplicate pathscopes
|
|
{"browse " + tempDirPath + "\n browse " + tempDirPath, nil, true},
|
|
} {
|
|
|
|
c := caddy.NewTestController("http", test.input)
|
|
err := setup(c)
|
|
if err != nil && !test.shouldErr {
|
|
t.Errorf("Test case #%d received an error of %v", i, err)
|
|
}
|
|
if test.expectedPathScope == nil {
|
|
continue
|
|
}
|
|
mids := httpserver.GetConfig(c).Middleware()
|
|
mid := mids[len(mids)-1]
|
|
receivedConfigs := mid(nil).(Browse).Configs
|
|
for j, config := range receivedConfigs {
|
|
if config.PathScope != test.expectedPathScope[j] {
|
|
t.Errorf("Test case #%d expected a pathscope of %v, but got %v", i, test.expectedPathScope, config.PathScope)
|
|
}
|
|
}
|
|
}
|
|
}
|