mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-05 18:44:58 +03:00
Added test on markdown static files generation
This commit is contained in:
parent
d1eb2ea9e2
commit
0168a627a4
7 changed files with 161 additions and 3 deletions
|
@ -2,8 +2,14 @@ package setup
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/mholt/caddy/middleware/markdown"
|
"io/ioutil"
|
||||||
|
"net/http"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/mholt/caddy/middleware"
|
||||||
|
"github.com/mholt/caddy/middleware/markdown"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestMarkdown(t *testing.T) {
|
func TestMarkdown(t *testing.T) {
|
||||||
|
@ -33,8 +39,82 @@ func TestMarkdown(t *testing.T) {
|
||||||
if fmt.Sprint(myHandler.Configs[0].Extensions) != fmt.Sprint([]string{".md"}) {
|
if fmt.Sprint(myHandler.Configs[0].Extensions) != fmt.Sprint([]string{".md"}) {
|
||||||
t.Errorf("Expected .md as the Default Extension")
|
t.Errorf("Expected .md as the Default Extension")
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestMarkdownStaticGen(t *testing.T) {
|
||||||
|
c := NewTestController(`markdown /blog {
|
||||||
|
ext .md
|
||||||
|
template tpl_with_include.html
|
||||||
|
sitegen
|
||||||
|
}`)
|
||||||
|
|
||||||
|
c.Root = "./testdata"
|
||||||
|
mid, err := Markdown(c)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Expected no errors, got: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if mid == nil {
|
||||||
|
t.Fatal("Expected middleware, was nil instead")
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, start := range c.Startup {
|
||||||
|
err := start()
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Startup error: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
next := middleware.HandlerFunc(func(w http.ResponseWriter, r *http.Request) (int, error) {
|
||||||
|
t.Fatalf("Next shouldn't be called")
|
||||||
|
return 0, nil
|
||||||
|
})
|
||||||
|
hndlr := mid(next)
|
||||||
|
mkdwn, ok := hndlr.(markdown.Markdown)
|
||||||
|
if !ok {
|
||||||
|
t.Fatalf("Was expecting a markdown.Markdown but got %T", hndlr)
|
||||||
|
}
|
||||||
|
|
||||||
|
expectedStaticFiles := map[string]string{"/blog/first_post.md": "testdata/generated_site/blog/first_post.md/index.html"}
|
||||||
|
if fmt.Sprint(expectedStaticFiles) != fmt.Sprint(mkdwn.Configs[0].StaticFiles) {
|
||||||
|
t.Fatalf("Test expected StaticFiles to be %s, but got %s",
|
||||||
|
fmt.Sprint(expectedStaticFiles), fmt.Sprint(mkdwn.Configs[0].StaticFiles))
|
||||||
|
}
|
||||||
|
|
||||||
|
filePath := "testdata/generated_site/blog/first_post.md/index.html"
|
||||||
|
if _, err := os.Stat(filePath); err != nil {
|
||||||
|
t.Fatalf("An error occured when getting the file information: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
html, err := ioutil.ReadFile(filePath)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("An error occured when getting the file content: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
expectedBody := `<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>first_post</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<h1>Header title</h1>
|
||||||
|
|
||||||
|
<h1>Test h1</h1>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
`
|
||||||
|
if string(html) != expectedBody {
|
||||||
|
t.Fatalf("Expected file content: %v got: %v", expectedBody, html)
|
||||||
|
}
|
||||||
|
|
||||||
|
fp := filepath.Join(c.Root, markdown.DefaultStaticDir)
|
||||||
|
if err = os.RemoveAll(fp); err != nil {
|
||||||
|
t.Errorf("Error while removing the generated static files: ", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func TestMarkdownParse(t *testing.T) {
|
func TestMarkdownParse(t *testing.T) {
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
inputMarkdownConfig string
|
inputMarkdownConfig string
|
||||||
|
@ -52,9 +132,20 @@ func TestMarkdownParse(t *testing.T) {
|
||||||
Styles: []string{"/resources/css/blog.css"},
|
Styles: []string{"/resources/css/blog.css"},
|
||||||
Scripts: []string{"/resources/js/blog.js"},
|
Scripts: []string{"/resources/js/blog.js"},
|
||||||
}}},
|
}}},
|
||||||
|
{`markdown /blog {
|
||||||
|
ext .md
|
||||||
|
template tpl_with_include.html
|
||||||
|
sitegen
|
||||||
|
}`, false, []markdown.Config{{
|
||||||
|
PathScope: "/blog",
|
||||||
|
Extensions: []string{".md"},
|
||||||
|
Templates: map[string]string{markdown.DefaultTemplate: "testdata/tpl_with_include.html"},
|
||||||
|
StaticDir: markdown.DefaultStaticDir,
|
||||||
|
}}},
|
||||||
}
|
}
|
||||||
for i, test := range tests {
|
for i, test := range tests {
|
||||||
c := NewTestController(test.inputMarkdownConfig)
|
c := NewTestController(test.inputMarkdownConfig)
|
||||||
|
c.Root = "./testdata"
|
||||||
actualMarkdownConfigs, err := markdownParse(c)
|
actualMarkdownConfigs, err := markdownParse(c)
|
||||||
|
|
||||||
if err == nil && test.shouldErr {
|
if err == nil && test.shouldErr {
|
||||||
|
@ -81,7 +172,10 @@ func TestMarkdownParse(t *testing.T) {
|
||||||
t.Errorf("Test %d expected %dth Markdown Config Scripts to be %s , but got %s",
|
t.Errorf("Test %d expected %dth Markdown Config Scripts to be %s , but got %s",
|
||||||
i, j, fmt.Sprint(test.expectedMarkdownConfig[j].Scripts), fmt.Sprint(actualMarkdownConfig.Scripts))
|
i, j, fmt.Sprint(test.expectedMarkdownConfig[j].Scripts), fmt.Sprint(actualMarkdownConfig.Scripts))
|
||||||
}
|
}
|
||||||
|
if fmt.Sprint(actualMarkdownConfig.Templates) != fmt.Sprint(test.expectedMarkdownConfig[j].Templates) {
|
||||||
|
t.Errorf("Test %d expected %dth Markdown Config Templates to be %s , but got %s",
|
||||||
|
i, j, fmt.Sprint(test.expectedMarkdownConfig[j].Templates), fmt.Sprint(actualMarkdownConfig.Templates))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
1
config/setup/testdata/blog/first_post.md
vendored
Normal file
1
config/setup/testdata/blog/first_post.md
vendored
Normal file
|
@ -0,0 +1 @@
|
||||||
|
# Test h1
|
1
config/setup/testdata/header.html
vendored
Normal file
1
config/setup/testdata/header.html
vendored
Normal file
|
@ -0,0 +1 @@
|
||||||
|
<h1>Header title</h1>
|
10
config/setup/testdata/tpl_with_include.html
vendored
Normal file
10
config/setup/testdata/tpl_with_include.html
vendored
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>{{.Doc.title}}</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
{{.Include "header.html"}}
|
||||||
|
{{.Doc.body}}
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -33,6 +33,16 @@ func TestMarkdown(t *testing.T) {
|
||||||
Scripts: []string{"/resources/js/log.js", "/resources/js/default.js"},
|
Scripts: []string{"/resources/js/log.js", "/resources/js/default.js"},
|
||||||
Templates: make(map[string]string),
|
Templates: make(map[string]string),
|
||||||
},
|
},
|
||||||
|
Config{
|
||||||
|
Renderer: blackfriday.HtmlRenderer(0, "", ""),
|
||||||
|
PathScope: "/og",
|
||||||
|
Extensions: []string{".md"},
|
||||||
|
Styles: []string{},
|
||||||
|
Scripts: []string{},
|
||||||
|
Templates: templates,
|
||||||
|
StaticDir: "/og_static",
|
||||||
|
StaticFiles: map[string]string{"/og/first.md": "testdata/og_static/og/first.md/index.html"},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
IndexFiles: []string{"index.html"},
|
IndexFiles: []string{"index.html"},
|
||||||
Next: middleware.HandlerFunc(func(w http.ResponseWriter, r *http.Request) (int, error) {
|
Next: middleware.HandlerFunc(func(w http.ResponseWriter, r *http.Request) (int, error) {
|
||||||
|
@ -123,4 +133,33 @@ func getTrue() bool {
|
||||||
if respBody != expectedBody {
|
if respBody != expectedBody {
|
||||||
t.Fatalf("Expected body: %v got: %v", expectedBody, respBody)
|
t.Fatalf("Expected body: %v got: %v", 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()
|
||||||
|
|
||||||
|
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()
|
||||||
|
expectedBody = `<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>first_post</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<h1>Header title</h1>
|
||||||
|
|
||||||
|
<h1>Test h1</h1>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>`
|
||||||
|
respBody = replacer.Replace(respBody)
|
||||||
|
expectedBody = replacer.Replace(expectedBody)
|
||||||
|
if respBody != expectedBody {
|
||||||
|
t.Fatalf("Expected body: %v got: %v", expectedBody, respBody)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
1
middleware/markdown/testdata/og/first.md
vendored
Normal file
1
middleware/markdown/testdata/og/first.md
vendored
Normal file
|
@ -0,0 +1 @@
|
||||||
|
# Test h1
|
12
middleware/markdown/testdata/og_static/og/first.md/index.html
vendored
Normal file
12
middleware/markdown/testdata/og_static/og/first.md/index.html
vendored
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>first_post</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<h1>Header title</h1>
|
||||||
|
|
||||||
|
<h1>Test h1</h1>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
Loading…
Reference in a new issue