package templates import ( "os" "strings" "testing" ) func TestParseTemplate(t *testing.T) { input := `--- title: my new post subtitle: a blog post tags: ["software", "web"] ---

Hello World!

` file := newFile("test*.html", input) defer os.Remove(file.Name()) templ, err := Parse(NewEngine("https://olano.dev", "includes"), file.Name()) assertEqual(t, err, nil) assertEqual(t, templ.Metadata["title"], "my new post") assertEqual(t, templ.Metadata["subtitle"], "a blog post") assertEqual(t, templ.Metadata["tags"].([]interface{})[0], "software") assertEqual(t, templ.Metadata["tags"].([]interface{})[1], "web") content, err := templ.Render(nil) assertEqual(t, err, nil) assertEqual(t, string(content), "

Hello World!

") } func TestNonTemplate(t *testing.T) { // not identified as front matter, leaving file as is input := `+++ title: my new post subtitle: a blog post +++

Hello World!

` file := newFile("test*.html", input) defer os.Remove(file.Name()) _, err := Parse(NewEngine("https://olano.dev", "includes"), file.Name()) assertEqual(t, err, nil) // not first thing in file, leaving as is input = `#+OPTIONS: toc:nil num:nil --- title: my new post subtitle: a blog post tags: ["software", "web"] ---

Hello World!

` file = newFile("test*.html", input) defer os.Remove(file.Name()) _, err = Parse(NewEngine("https://olano.dev", "includes"), file.Name()) assertEqual(t, err, nil) } func TestInvalidFrontMatter(t *testing.T) { input := `--- title: my new post subtitle: a blog post tags: ["software", "web"] ` file := newFile("test*.html", input) defer os.Remove(file.Name()) _, err := Parse(NewEngine("https://olano.dev", "includes"), file.Name()) assertEqual(t, err.Error(), "front matter not closed") input = `--- title tags: ["software", "web"] ---

Hello World!

` file = newFile("test*.html", input) defer os.Remove(file.Name()) _, err = Parse(NewEngine("https://olano.dev", "includes"), file.Name()) assert(t, strings.Contains(err.Error(), "invalid yaml")) } func TestRenderLiquid(t *testing.T) { input := `--- title: my new post subtitle: a blog post tags: ["software", "web"] ---

{{ page.title }}

{{ page.subtitle }}

` file := newFile("test*.html", input) defer os.Remove(file.Name()) templ, err := Parse(NewEngine("https://olano.dev", "includes"), file.Name()) assertEqual(t, err, nil) ctx := map[string]interface{}{"page": templ.Metadata} content, err := templ.Render(ctx) assertEqual(t, err, nil) expected := `

my new post

a blog post

` assertEqual(t, string(content), expected) } func TestRenderOrg(t *testing.T) { input := `--- title: my new post subtitle: a blog post tags: ["software", "web"] --- #+OPTIONS: toc:nil num:nil * My title ** my Subtitle - list 1 - list 2 ` file := newFile("test*.org", input) defer os.Remove(file.Name()) templ, err := Parse(NewEngine("https://olano.dev", "includes"), file.Name()) assertEqual(t, err, nil) content, err := templ.Render(nil) assertEqual(t, err, nil) expected := `

My title

my Subtitle

  • list 1
  • list 2
` assertEqual(t, string(content), expected) } func TestRenderMarkdown(t *testing.T) { input := `--- title: my new post subtitle: a blog post tags: ["software", "web"] --- # My title ## my Subtitle - list 1 - list 2 ` file := newFile("test*.md", input) defer os.Remove(file.Name()) templ, err := Parse(NewEngine("https://olano.dev", "includes"), file.Name()) assertEqual(t, err, nil) content, err := templ.Render(nil) assertEqual(t, err, nil) expected := `

My title

my Subtitle

` assertEqual(t, string(content), expected) } // ------ HELPERS -------- func newFile(path string, contents string) *os.File { file, _ := os.CreateTemp("", path) file.WriteString(contents) return file } // TODO move to assert package func assert(t *testing.T, cond bool) { t.Helper() if !cond { t.Fatalf("%v is false", cond) } } func assertEqual(t *testing.T, a interface{}, b interface{}) { t.Helper() if a != b { t.Fatalf("%v != %v", a, b) } }