ref: 439ab0339d9ac6972caabaa55fa41887ace839cb
parent: b6a60f718e376066456da37e7bb997a7697edc31
author: Bjørn Erik Pedersen <[email protected]>
date: Sat Mar 30 05:12:49 EDT 2019
resources: Fix image publish ordering issue Fixes #5730
--- a/resources/image.go
+++ b/resources/image.go
@@ -510,6 +510,9 @@
func (i *Image) clone() *Image {
g := *i.genericResource
g.resourceContent = &resourceContent{}
+ if g.publishOnce != nil {
+ g.publishOnce = &publishOnce{logger: g.publishOnce.logger}
+ }
return &Image{
imaging: i.imaging,
--- a/resources/image_test.go
+++ b/resources/image_test.go
@@ -152,6 +152,50 @@
assert.Equal("/a/_hu59e56ffff1bc1d8d122b1403d34e039f_90587_c876768085288f41211f768147ba2647.jpg", resized.RelPermalink())
}
+// https://github.com/gohugoio/hugo/issues/5730
+func TestImagePermalinkPublishOrder(t *testing.T) {
+ for _, checkOriginalFirst := range []bool{true, false} {
+ name := "OriginalFirst"
+ if !checkOriginalFirst {
+ name = "ResizedFirst"
+ }
+
+ t.Run(name, func(t *testing.T) {
+
+ assert := require.New(t)
+ spec := newTestResourceOsFs(assert)
+
+ check1 := func(img *Image) {
+ resizedLink := "/a/sunset_hu59e56ffff1bc1d8d122b1403d34e039f_90587_100x50_resize_q75_box.jpg"
+ assert.Equal(resizedLink, img.RelPermalink())
+ assertImageFile(assert, spec.PublishFs, resizedLink, 100, 50)
+ }
+
+ check2 := func(img *Image) {
+ assert.Equal("/a/sunset.jpg", img.RelPermalink())
+ assertImageFile(assert, spec.PublishFs, "a/sunset.jpg", 900, 562)
+ }
+
+ orignal := fetchImageForSpec(spec, assert, "sunset.jpg")
+ assert.NotNil(orignal)
+
+ if checkOriginalFirst {
+ check2(orignal)
+ }
+
+ resized, err := orignal.Resize("100x50")
+ assert.NoError(err)
+
+ check1(resized)
+
+ if !checkOriginalFirst {
+ check2(orignal)
+ }
+ })
+ }
+
+}
+
func TestImageTransformConcurrent(t *testing.T) {
var wg sync.WaitGroup
--- a/resources/testhelpers_test.go
+++ b/resources/testhelpers_test.go
@@ -135,7 +135,7 @@
factory := newTargetPaths("/a")
- r, err := spec.New(ResourceSourceDescriptor{TargetPaths: factory, SourceFilename: name})
+ r, err := spec.New(ResourceSourceDescriptor{TargetPaths: factory, LazyPublish: true, SourceFilename: name})
assert.NoError(err)
return r.(resource.ContentResource)
@@ -142,6 +142,7 @@
}
func assertImageFile(assert *require.Assertions, fs afero.Fs, filename string, width, height int) {
+ filename = filepath.Clean(filename)
f, err := fs.Open(filename)
if err != nil {
printFs(fs, "", os.Stdout)