Skip to content

Commit

Permalink
Merge pull request caddyserver#1747 from twdkeule/fix-index-push
Browse files Browse the repository at this point in the history
Pushes for /index.html work when surfing to /
  • Loading branch information
mholt authored Jul 24, 2017
2 parents 40b52fb + 20f76a2 commit 6e0317a
Show file tree
Hide file tree
Showing 4 changed files with 72 additions and 3 deletions.
9 changes: 8 additions & 1 deletion caddyhttp/push/handler.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import (
"strings"

"github.com/mholt/caddy/caddyhttp/httpserver"
"github.com/mholt/caddy/caddyhttp/staticfiles"
)

func (h Middleware) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error) {
Expand All @@ -25,7 +26,13 @@ func (h Middleware) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, erro
// push first
outer:
for _, rule := range h.Rules {
if httpserver.Path(r.URL.Path).Matches(rule.Path) {
urlPath := r.URL.Path
matches := httpserver.Path(urlPath).Matches(rule.Path)
// Also check IndexPages when requesting a directory
if !matches {
_, matches = httpserver.IndexFile(h.Root, urlPath, staticfiles.IndexPages)
}
if matches {
for _, resource := range rule.Resources {
pushErr := pusher.Push(resource.Path, &http.PushOptions{
Method: resource.Method,
Expand Down
60 changes: 60 additions & 0 deletions caddyhttp/push/handler_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,11 @@ package push

import (
"errors"
"io/ioutil"
"net/http"
"net/http/httptest"
"os"
"path/filepath"
"reflect"
"testing"

Expand Down Expand Up @@ -307,6 +310,63 @@ func TestMiddlewareShouldInterceptLinkHeaderPusherError(t *testing.T) {
comparePushedResources(t, expectedPushedResources, pushingWriter.pushed)
}

func TestMiddlewareShouldPushIndexFile(t *testing.T) {
// given
indexFile := "/index.html"
request, err := http.NewRequest(http.MethodGet, "/", nil) // Request root directory, not indexfile itself
if err != nil {
t.Fatalf("Could not create HTTP request: %v", err)
}

root, err := ioutil.TempDir("", "caddy")
if err != nil {
t.Fatalf("Could not create temporary directory: %v", err)
}
defer os.Remove(root)

middleware := Middleware{
Next: httpserver.HandlerFunc(func(w http.ResponseWriter, r *http.Request) (int, error) {
return 0, nil
}),
Rules: []Rule{
{Path: indexFile, Resources: []Resource{
{Path: "/index.css", Method: http.MethodGet},
}},
},
Root: http.Dir(root),
}

indexFilePath := filepath.Join(root, indexFile)
_, err = os.Create(indexFilePath)
if err != nil {
t.Fatalf("Could not create index file: %s: %v", indexFile, err)
}
defer os.Remove(indexFilePath)

pushingWriter := &MockedPusher{
ResponseWriter: httptest.NewRecorder(),
returnedError: errors.New("Cannot push right now"),
}

// when
_, err2 := middleware.ServeHTTP(pushingWriter, request)

// then
if err2 != nil {
t.Error("Should not return error")
}

expectedPushedResources := map[string]*http.PushOptions{
"/index.css": {
Method: http.MethodGet,
Header: http.Header{},
},
}

comparePushedResources(t, expectedPushedResources, pushingWriter.pushed)

}

func comparePushedResources(t *testing.T, expected, actual map[string]*http.PushOptions) {
if len(expected) != len(actual) {
t.Errorf("Expected %d pushed resources, actual: %d", len(expected), len(actual))
Expand Down
1 change: 1 addition & 0 deletions caddyhttp/push/push.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ type (
Middleware struct {
Next httpserver.Handler
Rules []Rule
Root http.FileSystem
}

ruleOp func([]Resource)
Expand Down
5 changes: 3 additions & 2 deletions caddyhttp/push/setup.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,8 +34,9 @@ func setup(c *caddy.Controller) error {
return err
}

httpserver.GetConfig(c).AddMiddleware(func(next httpserver.Handler) httpserver.Handler {
return Middleware{Next: next, Rules: rules}
cfg := httpserver.GetConfig(c)
cfg.AddMiddleware(func(next httpserver.Handler) httpserver.Handler {
return Middleware{Next: next, Rules: rules, Root: http.Dir(cfg.Root)}
})

return nil
Expand Down

0 comments on commit 6e0317a

Please sign in to comment.