shithub: hugo

Download patch

ref: 93d02aabe6e611d65c428a9c5669b422e1bcf5e8
parent: 508db1906beb84058e6d4394c8805532035e7bd2
author: Bjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
date: Sat Jul 27 14:16:13 EDT 2019

resources: Fix image Width/Height regression

Fixes #6120

--- /dev/null
+++ b/hugolib/image_test.go
@@ -1,0 +1,114 @@
+// 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 (
+	"io"
+	"os"
+	"path/filepath"
+	"testing"
+
+	"github.com/gohugoio/hugo/htesting"
+
+	"github.com/gohugoio/hugo/hugofs"
+	"github.com/spf13/viper"
+	"github.com/stretchr/testify/require"
+)
+
+// We have many tests for the different resize operations etc. in the resource package,
+// this is an integration test.
+func TestImageResize(t *testing.T) {
+	assert := require.New(t)
+	// Make this a real as possible.
+	workDir, clean, err := htesting.CreateTempDir(hugofs.Os, "image-resize")
+	assert.NoError(err)
+	defer clean()
+
+	newBuilder := func() *sitesBuilder {
+
+		v := viper.New()
+		v.Set("workingDir", workDir)
+		v.Set("baseURL", "https://example.org")
+
+		b := newTestSitesBuilder(t).WithWorkingDir(workDir)
+		b.Fs = hugofs.NewDefault(v)
+		b.WithViper(v)
+		b.WithContent("mybundle/index.md", `
+---
+title: "My bundle"
+---
+
+`)
+
+		b.WithTemplatesAdded("index.html", `
+{{ $p := .Site.GetPage "mybundle" }}
+{{ $img1 := resources.Get "images/sunset.jpg" }}
+{{ $img2 := $p.Resources.GetMatch "sunset.jpg" }}
+{{ $r := $img1.Resize "123x234" }}
+{{ $r2 := $r.Resize "12x23" }}
+{{ $b := $img2.Resize "345x678" }}
+{{ $b2 := $b.Resize "34x67" }}
+
+{{ $images := slice $r $r2 $b $b2 }}
+
+{{ range $i, $r := $images }}
+{{ printf "Resized%d:" (add $i  1) }} {{ $r.Name }}|{{ $r.Width }}|{{ $r.Height }}|{{ $r.MediaType }}|{{ $r.RelPermalink }}|
+{{ end }}
+
+`)
+
+		return b
+	}
+
+	imageDir := filepath.Join(workDir, "assets", "images")
+	bundleDir := filepath.Join(workDir, "content", "mybundle")
+
+	assert.NoError(os.MkdirAll(imageDir, 0777))
+	assert.NoError(os.MkdirAll(bundleDir, 0777))
+	src, err := os.Open("testdata/sunset.jpg")
+	assert.NoError(err)
+	out, err := os.Create(filepath.Join(imageDir, "sunset.jpg"))
+	assert.NoError(err)
+	_, err = io.Copy(out, src)
+	assert.NoError(err)
+	out.Close()
+
+	src.Seek(0, 0)
+
+	out, err = os.Create(filepath.Join(bundleDir, "sunset.jpg"))
+	assert.NoError(err)
+	_, err = io.Copy(out, src)
+	assert.NoError(err)
+	out.Close()
+	src.Close()
+
+	b := newBuilder()
+	b.Build(BuildCfg{})
+
+	imgExpect := []string{
+		"Resized1: images/sunset.jpg|123|234|image/jpg|/images/sunset_hu59e56ffff1bc1d8d122b1403d34e039f_90587_123x234_resize_q75_box.jpg|",
+		"Resized2: images/sunset.jpg|12|23|image/jpg|/images/sunset_hu59e56ffff1bc1d8d122b1403d34e039f_90587_ada4bb1a57f77a63306e3bd67286248e.jpg|",
+		"Resized3: sunset.jpg|345|678|image/jpg|/mybundle/sunset_hu59e56ffff1bc1d8d122b1403d34e039f_90587_345x678_resize_q75_box.jpg|",
+		"Resized4: sunset.jpg|34|67|image/jpg|/mybundle/sunset_hu59e56ffff1bc1d8d122b1403d34e039f_90587_44d8c928664d7c5a67377c6ec58425ce.jpg|",
+	}
+
+	b.AssertFileContent(filepath.Join(workDir, "public/index.html"), imgExpect...)
+
+	// Build it again to make sure we read images from file cache.
+	b = newBuilder()
+	b.Build(BuildCfg{})
+
+	b.AssertFileContent(filepath.Join(workDir, "public/index.html"), imgExpect...)
+
+}
--- a/resources/image_cache.go
+++ b/resources/image_cache.go
@@ -91,6 +91,8 @@
 		img = parent.clone()
 		img.relTargetDirFile.file = relTarget.file
 		img.sourceFilename = info.Name
+		// Make sure it's always loaded by sourceFilename.
+		img.openReadSeekerCloser = nil
 
 		w, err := img.openDestinationsForWriting()
 		if err != nil {