tpl/os: Revert readDir in theme behaviour
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Fri, 4 Mar 2022 06:07:11 +0000 (07:07 +0100)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Fri, 4 Mar 2022 07:43:47 +0000 (08:43 +0100)
Fixes #9599

hugofs/fs.go
hugolib/filesystems/basefs.go
tpl/os/integration_test.go [new file with mode: 0644]
tpl/os/os.go

index 2c57fe8b5a8c926ebedddc47437e9021ab45d59f..54d962553e70ae6ba2f8a5e7babc40fb72fca01c 100644 (file)
@@ -41,6 +41,7 @@ type Fs struct {
 
        // WorkingDir is a read-only file system
        // restricted to the project working dir.
+       // TODO(bep) get rid of this (se BaseFs)
        WorkingDir *afero.BasePathFs
 }
 
index aae3613f247639c6fe07240fcb60bb4c7b6395df..04648c25f0749bde2f39b21adbb09e753b3b5d69 100644 (file)
@@ -68,6 +68,9 @@ type BaseFs struct {
        // This usually maps to /my-project/public.
        PublishFs afero.Fs
 
+       // A read-only filesystem from the project workDir (no theme here).
+       WorkDir afero.Fs
+
        theBigFs *filesystemsCollector
 
        // Locks.
@@ -202,7 +205,7 @@ type SourceFilesystems struct {
        // with any sub module's resource fs layered below.
        ResourcesCache afero.Fs
 
-       // The project folder.
+       // The work folder (may be a composite of project and theme components).
        Work afero.Fs
 
        // When in multihost we have one static filesystem per language. The sync
@@ -435,9 +438,11 @@ func NewBase(p *paths.Paths, logger loggers.Logger, options ...func(*BaseFs) err
 
        publishFs := hugofs.NewBaseFileDecorator(afero.NewBasePathFs(fs.Destination, p.AbsPublishDir))
        sourceFs := hugofs.NewBaseFileDecorator(afero.NewBasePathFs(fs.Source, p.WorkingDir))
+       workDir := hugofs.NewBaseFileDecorator(afero.NewBasePathFs(afero.NewReadOnlyFs(fs.Source), p.WorkingDir))
 
        b := &BaseFs{
                SourceFs:  sourceFs,
+               WorkDir:   workDir,
                PublishFs: publishFs,
                buildMu:   lockedfile.MutexAt(filepath.Join(p.WorkingDir, lockFileBuild)),
        }
diff --git a/tpl/os/integration_test.go b/tpl/os/integration_test.go
new file mode 100644 (file)
index 0000000..fe1bb3d
--- /dev/null
@@ -0,0 +1,51 @@
+// Copyright 2022 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 os_test
+
+import (
+       "testing"
+
+       "github.com/gohugoio/hugo/hugolib"
+)
+
+// Issue 9599
+func TestReadDirWorkDir(t *testing.T) {
+       t.Parallel()
+
+       files := `
+-- config.toml --
+theme = "mytheme"
+-- myproject.txt --
+Hello project!
+-- themes/mytheme/mytheme.txt --
+Hello theme!
+-- layouts/index.html --
+{{ $entries := (readDir ".") }}
+START:|{{ range $entry := $entries }}{{ if not $entry.IsDir }}{{ $entry.Name }}|{{ end }}{{ end }}:END:
+
+
+  `
+
+       b := hugolib.NewIntegrationTestBuilder(
+               hugolib.IntegrationTestConfig{
+                       T:           t,
+                       TxtarString: files,
+                       NeedsOsFS:   true,
+               },
+       ).Build()
+
+       b.AssertFileContent("public/index.html", `
+START:|config.toml|myproject.txt|:END:
+`)
+}
index 2da792ac1966f325c0edbf3aa3cd3c13bac11419..5abc03c68dc43f5eb7fa8df851e3e6fd5cff03b9 100644 (file)
@@ -33,7 +33,8 @@ func New(d *deps.Deps) *Namespace {
        // The docshelper script does not have or need all the dependencies set up.
        if d.PathSpec != nil {
                readFileFs = afero.NewReadOnlyFs(afero.NewCopyOnWriteFs(d.PathSpec.BaseFs.Content.Fs, d.PathSpec.BaseFs.Work))
-               workFs = d.PathSpec.BaseFs.Work
+               // See #9599
+               workFs = d.PathSpec.BaseFs.WorkDir
        }
 
        return &Namespace{