hugolib: Add some baseof test variants
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Mon, 6 Feb 2017 16:07:48 +0000 (23:07 +0700)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Mon, 6 Feb 2017 17:01:28 +0000 (00:01 +0700)
See #2995

hugolib/template_test.go

index 2690b172aabde8c4e4269e826cafaf6a1d255c97..fa27dfc6640d118aa4168987d5ae834d87d26b55 100644 (file)
@@ -42,9 +42,16 @@ func TestBaseGoTemplate(t *testing.T) {
                                writeSource(t, fs, filepath.Join("layouts", "section", "sect-baseof.html"), `Base: {{block "main" .}}block{{end}}`)
                                writeSource(t, fs, filepath.Join("layouts", "section", "sect.html"), `{{define "main"}}sect{{ end }}`)
 
+                               // See #2995
+                               writeSource(t, fs, filepath.Join("layouts", "sect", "single.html"), `{{define "main"}}single sect{{ end }}`)
+
+                               // Should not be picked.
+                               writeSource(t, fs, filepath.Join("layouts", "_default", "baseof.html"), `Base: {{block "main" .}}NO{{end}}`)
+
                        },
                        func(t *testing.T) {
                                assertFileContent(t, fs, filepath.Join("public", "sect", "index.html"), false, "Base: sect")
+                               assertFileContent(t, fs, filepath.Join("public", "sect", "page", "index.html"), false, "Base: single sect")
                        },
                },
                {
@@ -52,7 +59,6 @@ func TestBaseGoTemplate(t *testing.T) {
                        func(t *testing.T) {
                                writeSource(t, fs, filepath.Join("layouts", "baseof.html"), `Base: {{block "main" .}}block{{end}}`)
                                writeSource(t, fs, filepath.Join("layouts", "index.html"), `{{define "main"}}index{{ end }}`)
-
                        },
                        func(t *testing.T) {
                                assertFileContent(t, fs, filepath.Join("public", "index.html"), false, "Base: index")
@@ -88,9 +94,16 @@ func TestBaseGoTemplate(t *testing.T) {
                                writeSource(t, fs, filepath.Join("themes", "mytheme", "layouts", "section", "sect-baseof.html"), `Base Theme: {{block "main" .}}block{{end}}`)
                                writeSource(t, fs, filepath.Join("layouts", "section", "sect.html"), `{{define "main"}}sect{{ end }}`)
 
+                               // See #2995
+                               writeSource(t, fs, filepath.Join("themes", "mytheme", "layouts", "sect", "single.html"), `{{define "main"}}single sect{{ end }}`)
+
+                               // Should not be picked.
+                               writeSource(t, fs, filepath.Join("themes", "mytheme", "layouts", "_default", "baseof.html"), `Base: {{block "main" .}}NO{{end}}`)
+
                        },
                        func(t *testing.T) {
                                assertFileContent(t, fs, filepath.Join("public", "sect", "index.html"), false, "Base: sect")
+                               assertFileContent(t, fs, filepath.Join("public", "sect", "page", "index.html"), false, "Base: single sect")
                        },
                },
                {
@@ -100,9 +113,16 @@ func TestBaseGoTemplate(t *testing.T) {
                                writeSource(t, fs, filepath.Join("themes", "mytheme", "layouts", "section", "sect-baseof.html"), `Base Theme: {{block "main" .}}block{{end}}`)
                                writeSource(t, fs, filepath.Join("layouts", "section", "sect.html"), `{{define "main"}}sect{{ end }}`)
 
+                               // See #2995
+                               writeSource(t, fs, filepath.Join("themes", "mytheme", "layouts", "sect", "single.html"), `{{define "main"}}single sect{{ end }}`)
+
+                               // Should not be picked.
+                               writeSource(t, fs, filepath.Join("themes", "mytheme", "layouts", "_default", "baseof.html"), `Base: {{block "main" .}}NO{{end}}`)
+
                        },
                        func(t *testing.T) {
                                assertFileContent(t, fs, filepath.Join("public", "sect", "index.html"), false, "Base Theme: sect")
+                               assertFileContent(t, fs, filepath.Join("public", "sect", "page", "index.html"), false, "Base: single sect")
                        },
                },
                {