From dc8248f8a49e4801e119008a32b28cd2ad6e1a57 Mon Sep 17 00:00:00 2001 From: Andrew Boyarshin Date: Tue, 14 Feb 2017 08:13:59 +0700 Subject: Markdown rendering overhaul (#186) * Markdown rendering overhaul Cleaned up and squashed commits into single one. Signed-off-by: Andrew Boyarshin * Fix markdown API, add markdown module and API tests, improve code coverage Signed-off-by: Andrew Boyarshin --- routers/api/v1/misc/markdown_test.go | 184 +++++++++++++++++++++++++++++++++++ 1 file changed, 184 insertions(+) create mode 100644 routers/api/v1/misc/markdown_test.go (limited to 'routers/api/v1/misc/markdown_test.go') diff --git a/routers/api/v1/misc/markdown_test.go b/routers/api/v1/misc/markdown_test.go new file mode 100644 index 0000000000..398e652d21 --- /dev/null +++ b/routers/api/v1/misc/markdown_test.go @@ -0,0 +1,184 @@ +package misc + +import ( + "net/http" + "net/http/httptest" + "testing" + + macaron "gopkg.in/macaron.v1" + + "net/url" + + "io/ioutil" + "strings" + + "code.gitea.io/gitea/modules/context" + "code.gitea.io/gitea/modules/markdown" + "code.gitea.io/gitea/modules/setting" + api "code.gitea.io/sdk/gitea" + "github.com/go-macaron/inject" + "github.com/stretchr/testify/assert" +) + +const AppURL = "http://localhost:3000/" +const Repo = "gogits/gogs" +const AppSubURL = AppURL + Repo + "/" + +func createContext(req *http.Request) (*macaron.Context, *httptest.ResponseRecorder) { + resp := httptest.NewRecorder() + c := &macaron.Context{ + Injector: inject.New(), + Req: macaron.Request{req}, + Resp: macaron.NewResponseWriter(resp), + Render: &macaron.DummyRender{resp}, + Data: make(map[string]interface{}), + } + c.Map(c) + c.Map(req) + return c, resp +} + +func wrap(ctx *macaron.Context) *context.APIContext { + return &context.APIContext{ + Context: &context.Context{ + Context: ctx, + }, + } +} + +func TestAPI_RenderGFM(t *testing.T) { + setting.AppURL = AppURL + + options := api.MarkdownOption{ + Mode: "gfm", + Text: "", + Context: Repo, + } + requrl, _ := url.Parse(markdown.URLJoin(AppURL, "api", "v1", "markdown")) + req := &http.Request{ + Method: "POST", + URL: requrl, + } + m, resp := createContext(req) + ctx := wrap(m) + + testCases := []string{ + // dear imgui wiki markdown extract: special wiki syntax + `Wiki! Enjoy :) +- [[Links, Language bindings, Engine bindings|Links]] +- [[Tips]] +- Bezier widget (by @r-lyeh) https://github.com/ocornut/imgui/issues/786`, + // rendered + `

Wiki! Enjoy :)

+ + +`, + // wine-staging wiki home extract: special wiki syntax, images + `## What is Wine Staging? +**Wine Staging** on website [wine-staging.com](http://wine-staging.com). + +## Quick Links +Here are some links to the most important topics. You can find the full list of pages at the sidebar. + +[[Configuration]] +[[images/icon-bug.png]] +`, + // rendered + `

What is Wine Staging?

+ +

Wine Staging on website wine-staging.com.

+ +

Quick Links

+ +

Here are some links to the most important topics. You can find the full list of pages at the sidebar.

+ +

Configuration +images/icon-bug.png

+`, + // Guard wiki sidebar: special syntax + `[[Guardfile-DSL / Configuring-Guard|Guardfile-DSL---Configuring-Guard]]`, + // rendered + `

Guardfile-DSL / Configuring-Guard

+`, + // special syntax + `[[Name|Link]]`, + // rendered + `

Name

+`, + // empty + ``, + // rendered + ``, + } + + for i := 0; i < len(testCases); i += 2 { + options.Text = testCases[i] + Markdown(ctx, options) + assert.Equal(t, testCases[i+1], resp.Body.String()) + resp.Body.Reset() + } +} + +var simpleCases = []string{ + // Guard wiki sidebar: special syntax + `[[Guardfile-DSL / Configuring-Guard|Guardfile-DSL---Configuring-Guard]]`, + // rendered + `

[[Guardfile-DSL / Configuring-Guard|Guardfile-DSL---Configuring-Guard]]

+`, + // special syntax + `[[Name|Link]]`, + // rendered + `

[[Name|Link]]

+`, + // empty + ``, + // rendered + ``, +} + +func TestAPI_RenderSimple(t *testing.T) { + setting.AppURL = AppURL + + options := api.MarkdownOption{ + Mode: "markdown", + Text: "", + Context: Repo, + } + requrl, _ := url.Parse(markdown.URLJoin(AppURL, "api", "v1", "markdown")) + req := &http.Request{ + Method: "POST", + URL: requrl, + } + m, resp := createContext(req) + ctx := wrap(m) + + for i := 0; i < len(simpleCases); i += 2 { + options.Text = simpleCases[i] + Markdown(ctx, options) + assert.Equal(t, simpleCases[i+1], resp.Body.String()) + resp.Body.Reset() + } +} + +func TestAPI_RenderRaw(t *testing.T) { + setting.AppURL = AppURL + + requrl, _ := url.Parse(markdown.URLJoin(AppURL, "api", "v1", "markdown")) + req := &http.Request{ + Method: "POST", + URL: requrl, + } + m, resp := createContext(req) + ctx := wrap(m) + + for i := 0; i < len(simpleCases); i += 2 { + ctx.Req.Request.Body = ioutil.NopCloser(strings.NewReader(simpleCases[i])) + MarkdownRaw(ctx) + assert.Equal(t, simpleCases[i+1], resp.Body.String()) + resp.Body.Reset() + } +} -- cgit v1.2.3