mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-23 00:56:45 +01:00
markdown: fix fake tests
Signed-off-by: Tw <tw19881113@gmail.com>
This commit is contained in:
parent
d3fc9f7a9b
commit
47fc35acc0
11 changed files with 98 additions and 90 deletions
|
@ -1,16 +1,12 @@
|
|||
package markdown
|
||||
|
||||
import (
|
||||
"bufio"
|
||||
"io/ioutil"
|
||||
"net/http"
|
||||
"net/http/httptest"
|
||||
"os"
|
||||
"path/filepath"
|
||||
"strings"
|
||||
"testing"
|
||||
"text/template"
|
||||
"time"
|
||||
|
||||
"github.com/mholt/caddy/caddyhttp/httpserver"
|
||||
"github.com/russross/blackfriday"
|
||||
|
@ -79,19 +75,23 @@ func TestMarkdown(t *testing.T) {
|
|||
}),
|
||||
}
|
||||
|
||||
req, err := http.NewRequest("GET", "/blog/test.md", nil)
|
||||
if err != nil {
|
||||
t.Fatalf("Could not create HTTP request: %v", err)
|
||||
get := func(url string) string {
|
||||
req, err := http.NewRequest("GET", url, nil)
|
||||
if err != nil {
|
||||
t.Fatalf("Could not create HTTP request: %v", err)
|
||||
}
|
||||
rec := httptest.NewRecorder()
|
||||
code, err := md.ServeHTTP(rec, req)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
if code != http.StatusOK {
|
||||
t.Fatalf("Wrong status, expected: %d and got %d", http.StatusOK, code)
|
||||
}
|
||||
return rec.Body.String()
|
||||
}
|
||||
|
||||
rec := httptest.NewRecorder()
|
||||
|
||||
md.ServeHTTP(rec, req)
|
||||
if rec.Code != http.StatusOK {
|
||||
t.Fatalf("Wrong status, expected: %d and got %d", http.StatusOK, rec.Code)
|
||||
}
|
||||
|
||||
respBody := rec.Body.String()
|
||||
respBody := get("/blog/test.md")
|
||||
expectedBody := `<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
|
@ -99,7 +99,6 @@ func TestMarkdown(t *testing.T) {
|
|||
</head>
|
||||
<body>
|
||||
<h1>Header for: Markdown test 1</h1>
|
||||
|
||||
Welcome to A Caddy website!
|
||||
<h2>Welcome on the blog</h2>
|
||||
|
||||
|
@ -113,46 +112,22 @@ Welcome to A Caddy website!
|
|||
</body>
|
||||
</html>
|
||||
`
|
||||
if !equalStrings(respBody, expectedBody) {
|
||||
t.Fatalf("Expected body: %v got: %v", expectedBody, respBody)
|
||||
}
|
||||
|
||||
req, err = http.NewRequest("GET", "/docflags/test.md", nil)
|
||||
if err != nil {
|
||||
t.Fatalf("Could not create HTTP request: %v", err)
|
||||
}
|
||||
rec = httptest.NewRecorder()
|
||||
|
||||
md.ServeHTTP(rec, req)
|
||||
if rec.Code != http.StatusOK {
|
||||
t.Fatalf("Wrong status, expected: %d and got %d", http.StatusOK, rec.Code)
|
||||
}
|
||||
respBody = rec.Body.String()
|
||||
respBody = get("/docflags/test.md")
|
||||
expectedBody = `Doc.var_string hello
|
||||
Doc.var_bool <no value>
|
||||
DocFlags.var_string <no value>
|
||||
DocFlags.var_bool true`
|
||||
Doc.var_bool true
|
||||
`
|
||||
|
||||
if !equalStrings(respBody, expectedBody) {
|
||||
t.Fatalf("Expected body: %v got: %v", expectedBody, respBody)
|
||||
if respBody != expectedBody {
|
||||
t.Fatalf("Expected body:\n%q\ngot:\n%q", expectedBody, respBody)
|
||||
}
|
||||
|
||||
req, err = http.NewRequest("GET", "/log/test.md", nil)
|
||||
if err != nil {
|
||||
t.Fatalf("Could not create HTTP request: %v", err)
|
||||
}
|
||||
rec = httptest.NewRecorder()
|
||||
|
||||
md.ServeHTTP(rec, req)
|
||||
if rec.Code != http.StatusOK {
|
||||
t.Fatalf("Wrong status, expected: %d and got %d", http.StatusOK, rec.Code)
|
||||
}
|
||||
respBody = rec.Body.String()
|
||||
respBody = get("/log/test.md")
|
||||
expectedBody = `<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>Markdown test 2</title>
|
||||
<meta charset="utf-8">
|
||||
|
||||
<link rel="stylesheet" href="/resources/css/log.css">
|
||||
<link rel="stylesheet" href="/resources/css/default.css">
|
||||
<script src="/resources/js/log.js"></script>
|
||||
|
@ -171,26 +146,11 @@ DocFlags.var_bool true`
|
|||
</body>
|
||||
</html>`
|
||||
|
||||
if !equalStrings(respBody, expectedBody) {
|
||||
t.Fatalf("Expected body: %v got: %v", expectedBody, respBody)
|
||||
if respBody != expectedBody {
|
||||
t.Fatalf("Expected body:\n%q\ngot:\n%q", expectedBody, respBody)
|
||||
}
|
||||
|
||||
req, err = http.NewRequest("GET", "/og/first.md", nil)
|
||||
if err != nil {
|
||||
t.Fatalf("Could not create HTTP request: %v", err)
|
||||
}
|
||||
rec = httptest.NewRecorder()
|
||||
currenttime := time.Now().Local().Add(-time.Second)
|
||||
_ = os.Chtimes("testdata/og/first.md", currenttime, currenttime)
|
||||
currenttime = time.Now().Local()
|
||||
_ = os.Chtimes("testdata/og_static/og/first.md/index.html", currenttime, currenttime)
|
||||
time.Sleep(time.Millisecond * 200)
|
||||
|
||||
md.ServeHTTP(rec, req)
|
||||
if rec.Code != http.StatusOK {
|
||||
t.Fatalf("Wrong status, expected: %d and got %d", http.StatusOK, rec.Code)
|
||||
}
|
||||
respBody = rec.Body.String()
|
||||
respBody = get("/og/first.md")
|
||||
expectedBody = `<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
|
@ -198,32 +158,18 @@ DocFlags.var_bool true`
|
|||
</head>
|
||||
<body>
|
||||
<h1>Header for: first_post</h1>
|
||||
|
||||
Welcome to title!
|
||||
<h1>Test h1</h1>
|
||||
|
||||
</body>
|
||||
</html>`
|
||||
</html>
|
||||
`
|
||||
|
||||
if !equalStrings(respBody, expectedBody) {
|
||||
t.Fatalf("Expected body: %v got: %v", expectedBody, respBody)
|
||||
if respBody != expectedBody {
|
||||
t.Fatalf("Expected body:\n%q\ngot:\n%q", expectedBody, respBody)
|
||||
}
|
||||
}
|
||||
|
||||
func equalStrings(s1, s2 string) bool {
|
||||
s1 = strings.TrimSpace(s1)
|
||||
s2 = strings.TrimSpace(s2)
|
||||
in := bufio.NewScanner(strings.NewReader(s1))
|
||||
for in.Scan() {
|
||||
txt := strings.TrimSpace(in.Text())
|
||||
if !strings.HasPrefix(strings.TrimSpace(s2), txt) {
|
||||
return false
|
||||
}
|
||||
s2 = strings.Replace(s2, txt, "", 1)
|
||||
}
|
||||
return true
|
||||
}
|
||||
|
||||
func setDefaultTemplate(filename string) *template.Template {
|
||||
buf, err := ioutil.ReadFile(filename)
|
||||
if err != nil {
|
||||
|
|
|
@ -115,15 +115,17 @@ func loadParams(c *caddy.Controller, mdc *Config) error {
|
|||
fpath := filepath.ToSlash(filepath.Clean(cfg.Root + string(filepath.Separator) + tArgs[0]))
|
||||
|
||||
if err := SetTemplate(mdc.Template, "", fpath); err != nil {
|
||||
c.Errf("default template parse error: %v", err)
|
||||
return c.Errf("default template parse error: %v", err)
|
||||
}
|
||||
|
||||
return nil
|
||||
case 2:
|
||||
fpath := filepath.ToSlash(filepath.Clean(cfg.Root + string(filepath.Separator) + tArgs[1]))
|
||||
|
||||
if err := SetTemplate(mdc.Template, tArgs[0], fpath); err != nil {
|
||||
c.Errf("template parse error: %v", err)
|
||||
return c.Errf("template parse error: %v", err)
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
case "templatedir":
|
||||
|
@ -132,11 +134,12 @@ func loadParams(c *caddy.Controller, mdc *Config) error {
|
|||
}
|
||||
_, err := mdc.Template.ParseGlob(c.Val())
|
||||
if err != nil {
|
||||
c.Errf("template load error: %v", err)
|
||||
return c.Errf("template load error: %v", err)
|
||||
}
|
||||
if c.NextArg() {
|
||||
return c.ArgErr()
|
||||
}
|
||||
|
||||
return nil
|
||||
default:
|
||||
return c.Err("Expected valid markdown configuration property")
|
||||
|
|
|
@ -71,12 +71,9 @@ func TestMarkdownParse(t *testing.T) {
|
|||
Extensions: map[string]struct{}{
|
||||
".md": {},
|
||||
},
|
||||
Template: GetDefaultTemplate(),
|
||||
Template: setDefaultTemplate("./testdata/tpl_with_include.html"),
|
||||
}}},
|
||||
}
|
||||
// Setup the extra template
|
||||
tmpl := tests[1].expectedMarkdownConfig[0].Template
|
||||
SetTemplate(tmpl, "", "./testdata/tpl_with_include.html")
|
||||
|
||||
for i, test := range tests {
|
||||
c := caddy.NewTestController("http", test.inputMarkdownConfig)
|
||||
|
|
14
caddyhttp/markdown/testdata/blog/test.md
vendored
Normal file
14
caddyhttp/markdown/testdata/blog/test.md
vendored
Normal file
|
@ -0,0 +1,14 @@
|
|||
---
|
||||
title: Markdown test 1
|
||||
sitename: A Caddy website
|
||||
---
|
||||
|
||||
## Welcome on the blog
|
||||
|
||||
Body
|
||||
|
||||
``` go
|
||||
func getTrue() bool {
|
||||
return true
|
||||
}
|
||||
```
|
2
caddyhttp/markdown/testdata/docflags/template.txt
vendored
Normal file
2
caddyhttp/markdown/testdata/docflags/template.txt
vendored
Normal file
|
@ -0,0 +1,2 @@
|
|||
Doc.var_string {{.Doc.var_string}}
|
||||
Doc.var_bool {{.Doc.var_bool}}
|
4
caddyhttp/markdown/testdata/docflags/test.md
vendored
Normal file
4
caddyhttp/markdown/testdata/docflags/test.md
vendored
Normal file
|
@ -0,0 +1,4 @@
|
|||
---
|
||||
var_string: hello
|
||||
var_bool: true
|
||||
---
|
1
caddyhttp/markdown/testdata/header.html
vendored
Normal file
1
caddyhttp/markdown/testdata/header.html
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
<h1>Header for: {{.Doc.title}}</h1>
|
14
caddyhttp/markdown/testdata/log/test.md
vendored
Normal file
14
caddyhttp/markdown/testdata/log/test.md
vendored
Normal file
|
@ -0,0 +1,14 @@
|
|||
---
|
||||
title: Markdown test 2
|
||||
sitename: A Caddy website
|
||||
---
|
||||
|
||||
## Welcome on the blog
|
||||
|
||||
Body
|
||||
|
||||
``` go
|
||||
func getTrue() bool {
|
||||
return true
|
||||
}
|
||||
```
|
11
caddyhttp/markdown/testdata/markdown_tpl.html
vendored
Normal file
11
caddyhttp/markdown/testdata/markdown_tpl.html
vendored
Normal file
|
@ -0,0 +1,11 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>{{.Doc.title}}</title>
|
||||
</head>
|
||||
<body>
|
||||
{{.Include "header.html"}}
|
||||
Welcome to {{.Doc.sitename}}!
|
||||
{{.Doc.body}}
|
||||
</body>
|
||||
</html>
|
5
caddyhttp/markdown/testdata/og/first.md
vendored
Normal file
5
caddyhttp/markdown/testdata/og/first.md
vendored
Normal file
|
@ -0,0 +1,5 @@
|
|||
---
|
||||
title: first_post
|
||||
sitename: title
|
||||
---
|
||||
# Test h1
|
11
caddyhttp/markdown/testdata/tpl_with_include.html
vendored
Normal file
11
caddyhttp/markdown/testdata/tpl_with_include.html
vendored
Normal file
|
@ -0,0 +1,11 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>{{.Doc.title}}</title>
|
||||
</head>
|
||||
<body>
|
||||
Welcome to {{.Doc.sitename}}!
|
||||
<br><br>
|
||||
{{.Doc.body}}
|
||||
</body>
|
||||
</html>
|
Loading…
Reference in a new issue