2017-09-23 08:56:58 +03:00
|
|
|
// 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.
|
|
|
|
|
2016-06-06 07:39:23 +03:00
|
|
|
package templates
|
|
|
|
|
|
|
|
import (
|
2017-04-22 04:54:25 +03:00
|
|
|
"bytes"
|
2017-08-24 16:13:53 +03:00
|
|
|
"context"
|
fix lint warnings (issue 2541) (#2551)
* Lint: fix some errcheck #2541
* Lint: fix passing structcheck #2541
* Lint: update fix structcheck #2541
* Lint: fix errcheck for basicauth, browse, fastcgi_test #2541
* Lint: fix errcheck for browse, fastcgi_test, fcgiclient, fcgiclient_test #2541
* Lint: fix errcheck for responsefilter_test, fcgilient_test #2541
* Lint: fix errcheck for header_test #2541
* Lint: update errcheck for fcgiclient_test #2541
* Lint: fix errcheck for server, header_test, fastcgi_test, https_test, recorder_test #2541
* Lint: fix errcheck for tplcontext, vhosttrie_test, internal_test, handler_test #2541
* Lint: fix errcheck for log_test, markdown mholt#2541
* Lint: fix errcheck for policy, body_test, proxy_test #2541
* Lint: fix errcheck for on multiple packages #2541
- reverseproxy
- reverseproxy_test
- upstream
- upstream_test
- body_test
* Lint: fix errcheck in multiple packages mholt#2541
- handler_test
- redirect_test
- requestid_test
- rewrite_test
- fileserver_test
* Lint: fix errcheck in multiple packages mholt#2541
- websocket
- setup
- collection
- redirect_test
- templates_test
* Lint: fix errcheck in logger test #2541
run goimports against #2551
- lexer_test
- log_test
- markdown
* Update caddyhttp/httpserver/logger_test.go
Co-Authored-By: Inconnu08 <taufiqrx8@gmail.com>
* Update log_test.go
* Lint: fix scope in logger_test #2541
* remove redundant err check in logger_test #2541
* fix alias in logger_test #2541
* fix import for format #2541
* refactor variable names and error check #2541
2019-04-22 19:20:37 +03:00
|
|
|
"log"
|
2016-06-06 07:39:23 +03:00
|
|
|
"net/http"
|
|
|
|
"net/http/httptest"
|
2017-04-22 04:54:25 +03:00
|
|
|
"sync"
|
2016-06-06 07:39:23 +03:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/mholt/caddy/caddyhttp/httpserver"
|
2017-08-24 16:13:53 +03:00
|
|
|
"github.com/mholt/caddy/caddyhttp/staticfiles"
|
2016-06-06 07:39:23 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestTemplates(t *testing.T) {
|
2017-08-24 16:13:53 +03:00
|
|
|
siteRoot := "./testdata"
|
2016-06-06 07:39:23 +03:00
|
|
|
tmpl := Templates{
|
2017-08-24 16:13:53 +03:00
|
|
|
Next: staticfiles.FileServer{Root: http.Dir(siteRoot)},
|
2016-06-06 07:39:23 +03:00
|
|
|
Rules: []Rule{
|
|
|
|
{
|
|
|
|
Extensions: []string{".html"},
|
|
|
|
IndexFiles: []string{"index.html"},
|
|
|
|
Path: "/photos",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Extensions: []string{".html", ".htm"},
|
|
|
|
IndexFiles: []string{"index.html", "index.htm"},
|
|
|
|
Path: "/images",
|
|
|
|
Delims: [2]string{"{%", "%}"},
|
|
|
|
},
|
|
|
|
},
|
2017-08-24 16:13:53 +03:00
|
|
|
Root: siteRoot,
|
|
|
|
FileSys: http.Dir(siteRoot),
|
2017-04-22 04:54:25 +03:00
|
|
|
BufPool: &sync.Pool{New: func() interface{} { return new(bytes.Buffer) }},
|
2016-06-06 07:39:23 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
tmplroot := Templates{
|
2017-08-24 16:13:53 +03:00
|
|
|
Next: staticfiles.FileServer{Root: http.Dir(siteRoot)},
|
2016-06-06 07:39:23 +03:00
|
|
|
Rules: []Rule{
|
|
|
|
{
|
|
|
|
Extensions: []string{".html"},
|
|
|
|
IndexFiles: []string{"index.html"},
|
|
|
|
Path: "/",
|
|
|
|
},
|
|
|
|
},
|
2017-08-24 16:13:53 +03:00
|
|
|
Root: siteRoot,
|
|
|
|
FileSys: http.Dir(siteRoot),
|
2017-04-22 04:54:25 +03:00
|
|
|
BufPool: &sync.Pool{New: func() interface{} { return new(bytes.Buffer) }},
|
2016-06-06 07:39:23 +03:00
|
|
|
}
|
|
|
|
|
2018-01-16 04:27:55 +03:00
|
|
|
// register custom function which is used in template
|
|
|
|
httpserver.TemplateFuncs["root"] = func() string { return "root" }
|
2016-06-06 07:39:23 +03:00
|
|
|
|
2018-01-16 04:27:55 +03:00
|
|
|
for _, c := range []struct {
|
|
|
|
tpl Templates
|
|
|
|
req string
|
|
|
|
respCode int
|
|
|
|
res string
|
2018-11-19 00:06:54 +03:00
|
|
|
bypass bool
|
2018-01-16 04:27:55 +03:00
|
|
|
}{
|
|
|
|
{
|
|
|
|
tpl: tmpl,
|
|
|
|
req: "/photos/test.html",
|
|
|
|
respCode: http.StatusOK,
|
|
|
|
res: `<!DOCTYPE html><html><head><title>test page</title></head><body><h1>Header title</h1>
|
2016-06-06 07:39:23 +03:00
|
|
|
</body></html>
|
2018-01-16 04:27:55 +03:00
|
|
|
`,
|
|
|
|
},
|
2016-06-06 07:39:23 +03:00
|
|
|
|
2018-01-16 04:27:55 +03:00
|
|
|
{
|
|
|
|
tpl: tmpl,
|
|
|
|
req: "/images/img.htm",
|
|
|
|
respCode: http.StatusOK,
|
|
|
|
res: `<!DOCTYPE html><html><head><title>img</title></head><body><h1>Header title</h1>
|
2016-06-06 07:39:23 +03:00
|
|
|
</body></html>
|
2018-01-16 04:27:55 +03:00
|
|
|
`,
|
|
|
|
},
|
2016-06-06 07:39:23 +03:00
|
|
|
|
2018-01-16 04:27:55 +03:00
|
|
|
{
|
|
|
|
tpl: tmpl,
|
|
|
|
req: "/images/img2.htm",
|
|
|
|
respCode: http.StatusOK,
|
|
|
|
res: `<!DOCTYPE html><html><head><title>img</title></head><body>{{.Include "header.html"}}</body></html>
|
|
|
|
`,
|
|
|
|
},
|
2016-06-06 07:39:23 +03:00
|
|
|
|
2018-01-16 04:27:55 +03:00
|
|
|
{
|
|
|
|
tpl: tmplroot,
|
|
|
|
req: "/root.html",
|
|
|
|
respCode: http.StatusOK,
|
|
|
|
res: `<!DOCTYPE html><html><head><title>root</title></head><body><h1>Header title</h1>
|
2016-06-06 07:39:23 +03:00
|
|
|
</body></html>
|
2018-01-16 04:27:55 +03:00
|
|
|
`,
|
|
|
|
},
|
2016-06-06 07:39:23 +03:00
|
|
|
|
2018-01-16 04:27:55 +03:00
|
|
|
// test extension filter
|
|
|
|
{
|
|
|
|
tpl: tmplroot,
|
|
|
|
req: "/as_it_is.txt",
|
|
|
|
respCode: http.StatusOK,
|
|
|
|
res: `<!DOCTYPE html><html><head><title>as it is</title></head><body>{{.Include "header.html"}}</body></html>
|
|
|
|
`,
|
2018-11-19 00:06:54 +03:00
|
|
|
bypass: true,
|
2018-01-16 04:27:55 +03:00
|
|
|
},
|
|
|
|
} {
|
|
|
|
c := c
|
|
|
|
t.Run("", func(t *testing.T) {
|
|
|
|
req, err := http.NewRequest("GET", c.req, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Test: Could not create HTTP request: %v", err)
|
|
|
|
}
|
|
|
|
req = req.WithContext(context.WithValue(req.Context(), httpserver.OriginalURLCtxKey, *req.URL))
|
|
|
|
|
|
|
|
rec := httptest.NewRecorder()
|
|
|
|
|
fix lint warnings (issue 2541) (#2551)
* Lint: fix some errcheck #2541
* Lint: fix passing structcheck #2541
* Lint: update fix structcheck #2541
* Lint: fix errcheck for basicauth, browse, fastcgi_test #2541
* Lint: fix errcheck for browse, fastcgi_test, fcgiclient, fcgiclient_test #2541
* Lint: fix errcheck for responsefilter_test, fcgilient_test #2541
* Lint: fix errcheck for header_test #2541
* Lint: update errcheck for fcgiclient_test #2541
* Lint: fix errcheck for server, header_test, fastcgi_test, https_test, recorder_test #2541
* Lint: fix errcheck for tplcontext, vhosttrie_test, internal_test, handler_test #2541
* Lint: fix errcheck for log_test, markdown mholt#2541
* Lint: fix errcheck for policy, body_test, proxy_test #2541
* Lint: fix errcheck for on multiple packages #2541
- reverseproxy
- reverseproxy_test
- upstream
- upstream_test
- body_test
* Lint: fix errcheck in multiple packages mholt#2541
- handler_test
- redirect_test
- requestid_test
- rewrite_test
- fileserver_test
* Lint: fix errcheck in multiple packages mholt#2541
- websocket
- setup
- collection
- redirect_test
- templates_test
* Lint: fix errcheck in logger test #2541
run goimports against #2551
- lexer_test
- log_test
- markdown
* Update caddyhttp/httpserver/logger_test.go
Co-Authored-By: Inconnu08 <taufiqrx8@gmail.com>
* Update log_test.go
* Lint: fix scope in logger_test #2541
* remove redundant err check in logger_test #2541
* fix alias in logger_test #2541
* fix import for format #2541
* refactor variable names and error check #2541
2019-04-22 19:20:37 +03:00
|
|
|
if _, err := c.tpl.ServeHTTP(rec, req); err != nil {
|
|
|
|
log.Println("[ERROR] failed to serve HTTP: ", err)
|
|
|
|
}
|
2018-01-16 04:27:55 +03:00
|
|
|
|
|
|
|
if rec.Code != c.respCode {
|
|
|
|
t.Fatalf("Test: Wrong response code: %d, should be %d", rec.Code, c.respCode)
|
|
|
|
}
|
|
|
|
|
|
|
|
respBody := rec.Body.String()
|
|
|
|
if respBody != c.res {
|
|
|
|
t.Fatalf("Test: the expected body %v is different from the response one: %v", c.res, respBody)
|
|
|
|
}
|
2018-11-19 00:06:54 +03:00
|
|
|
|
|
|
|
if !c.bypass {
|
|
|
|
eTag := rec.Header().Get("ETag")
|
|
|
|
lastModified := rec.Header().Get("Last-Modified")
|
|
|
|
if eTag != "" || lastModified != "" {
|
|
|
|
t.Fatalf("Test: expect a response without ETag or Last-Modified, got %v %v", eTag, lastModified)
|
|
|
|
}
|
|
|
|
}
|
2018-01-16 04:27:55 +03:00
|
|
|
})
|
2016-06-06 07:39:23 +03:00
|
|
|
}
|
|
|
|
}
|