mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-10-25 07:49:19 -04:00 
			
		
		
		
	Added test on markdown static files generation
This commit is contained in:
		
							parent
							
								
									d1eb2ea9e2
								
							
						
					
					
						commit
						0168a627a4
					
				| @ -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…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user