mirror of
https://github.com/gohugoio/hugo.git
synced 2024-11-21 20:46:30 -05:00
e5f2299741
This is in line with how it behaved before, but it was lifted a little for the project mount for Hugo Modules, but that could create hard-to-detect loops.
88 lines
2.4 KiB
Go
88 lines
2.4 KiB
Go
// 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, loggers.NewErrorLogger())
|
|
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 }
|