summaryrefslogtreecommitdiffstats
path: root/hugolib/pages_capture_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'hugolib/pages_capture_test.go')
-rw-r--r--hugolib/pages_capture_test.go88
1 files changed, 88 insertions, 0 deletions
diff --git a/hugolib/pages_capture_test.go b/hugolib/pages_capture_test.go
new file mode 100644
index 000000000..f8a7833be
--- /dev/null
+++ b/hugolib/pages_capture_test.go
@@ -0,0 +1,88 @@
+// Copyright 2019 The Hugo Authors. All rights reserved.
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+package hugolib
+
+import (
+ "context"
+ "fmt"
+ "path/filepath"
+ "testing"
+
+ "github.com/pkg/errors"
+
+ "github.com/gohugoio/hugo/helpers"
+ "github.com/gohugoio/hugo/source"
+
+ "github.com/gohugoio/hugo/common/loggers"
+
+ "github.com/gohugoio/hugo/hugofs"
+ "github.com/spf13/afero"
+ "github.com/stretchr/testify/require"
+)
+
+func TestPagesCapture(t *testing.T) {
+
+ cfg, hfs := newTestCfg()
+ fs := hfs.Source
+
+ assert := require.New(t)
+
+ var writeFile = func(filename string) {
+ assert.NoError(afero.WriteFile(fs, filepath.FromSlash(filename), []byte(fmt.Sprintf("content-%s", filename)), 0755))
+ }
+
+ writeFile("_index.md")
+ writeFile("logo.png")
+ writeFile("root.md")
+ writeFile("blog/index.md")
+ writeFile("blog/hello.md")
+ writeFile("blog/images/sunset.png")
+ writeFile("pages/page1.md")
+ writeFile("pages/page2.md")
+ writeFile("pages/page.png")
+
+ ps, err := helpers.NewPathSpec(hugofs.NewFrom(fs, cfg), cfg)
+ assert.NoError(err)
+ sourceSpec := source.NewSourceSpec(ps, fs)
+
+ t.Run("Collect", func(t *testing.T) {
+ assert := require.New(t)
+ proc := &testPagesCollectorProcessor{}
+ c := newPagesCollector(sourceSpec, loggers.NewErrorLogger(), nil, proc)
+ assert.NoError(c.Collect())
+ assert.Equal(4, len(proc.items))
+ })
+
+ t.Run("error in Wait", func(t *testing.T) {
+ assert := require.New(t)
+ c := newPagesCollector(sourceSpec, loggers.NewErrorLogger(), nil,
+ &testPagesCollectorProcessor{waitErr: errors.New("failed")})
+ assert.Error(c.Collect())
+ })
+}
+
+type testPagesCollectorProcessor struct {
+ items []interface{}
+ waitErr error
+}
+
+func (proc *testPagesCollectorProcessor) Process(item interface{}) error {
+ proc.items = append(proc.items, item)
+ return nil
+}
+func (proc *testPagesCollectorProcessor) Start(ctx context.Context) context.Context {
+ return ctx
+}
+
+func (proc *testPagesCollectorProcessor) Wait() error { return proc.waitErr }