Skip to content

Commit 1f5a15a

Browse files
committed
resources: Fix 2 image file cache key issues
* Always include the content hash in the cache key for unprocessed images. * Always include the image config hash in the cache key. This is also a major cleanup/simplification of the implementation in this area. Note that this, unfortunately, forces new hashes/filenames for generated images. Fixes #13273 Fixes #13272
1 parent 8897113 commit 1f5a15a

38 files changed

+341
-232
lines changed

‎config/namespace.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,7 @@ import (
2222
func DecodeNamespace[S, C any](configSource any, buildConfig func(any) (C, any, error)) (*ConfigNamespace[S, C], error) {
2323
// Calculate the hash of the input (not including any defaults applied later).
2424
// This allows us to introduce new config options without breaking the hash.
25-
h := hashing.HashString(configSource)
25+
h := hashing.HashStringHex(configSource)
2626

2727
// Build the config
2828
c, ext, err := buildConfig(configSource)

‎config/namespace_test.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -43,7 +43,7 @@ func TestNamespace(t *testing.T) {
4343
c.Assert(err, qt.IsNil)
4444
c.Assert(ns, qt.Not(qt.IsNil))
4545
c.Assert(ns.SourceStructure, qt.DeepEquals, map[string]interface{}{"foo": "bar"})
46-
c.Assert(ns.SourceHash, qt.Equals, "1450430416588600409")
46+
c.Assert(ns.SourceHash, qt.Equals, "1420f6c7782f7459")
4747
c.Assert(ns.Config, qt.DeepEquals, &tstNsExt{Foo: "bar"})
4848
c.Assert(ns.Signature(), qt.DeepEquals, []*tstNsExt(nil))
4949
}

‎hugolib/hugo_sites_multihost_test.go

+2-2
Original file line numberDiff line numberDiff line change
@@ -205,9 +205,9 @@ title: mybundle-en
205205
b.AssertFileExists("public/de/mybundle/pixel.png", true)
206206
b.AssertFileExists("public/en/mybundle/pixel.png", true)
207207

208-
b.AssertFileExists("public/de/mybundle/pixel_hu8581513846771248023.png", true)
208+
b.AssertFileExists("public/de/mybundle/pixel_hu_58204cbc58507d74.png", true)
209209
// failing test below
210-
b.AssertFileExists("public/en/mybundle/pixel_hu8581513846771248023.png", true)
210+
b.AssertFileExists("public/en/mybundle/pixel_hu_58204cbc58507d74.png", true)
211211
}
212212

213213
func TestMultihostResourceOneBaseURLWithSuPath(t *testing.T) {

‎hugolib/image_test.go

+8-8
Original file line numberDiff line numberDiff line change
@@ -72,20 +72,20 @@ SUNSET2: {{ $resized2.RelPermalink }}/{{ $resized2.Width }}/Lat: {{ $resized2.Ex
7272

7373
b.Build(BuildCfg{})
7474

75-
b.AssertFileContent("public/index.html", "SUNSET FOR: en: /bundle/sunset_hu13235715490294913361.jpg/200/Lat: 36.59744166666667")
76-
b.AssertFileContent("public/fr/index.html", "SUNSET FOR: fr: /bundle/sunset_hu13235715490294913361.jpg/200/Lat: 36.59744166666667")
77-
b.AssertFileContent("public/index.html", " SUNSET2: /images/sunset_hu1573057890424052540.jpg/123/Lat: 36.59744166666667")
78-
b.AssertFileContent("public/nn/index.html", " SUNSET2: /images/sunset_hu1573057890424052540.jpg/123/Lat: 36.59744166666667")
75+
b.AssertFileContent("public/index.html", "SUNSET FOR: en: /bundle/sunset_hu_77061c65c31d2244.jpg/200/Lat: 36.59744166666667")
76+
b.AssertFileContent("public/fr/index.html", "SUNSET FOR: fr: /bundle/sunset_hu_77061c65c31d2244.jpg/200/Lat: 36.59744166666667")
77+
b.AssertFileContent("public/index.html", " SUNSET2: /images/sunset_hu_b52e3343ea6a8764.jpg/123/Lat: 36.59744166666667")
78+
b.AssertFileContent("public/nn/index.html", " SUNSET2: /images/sunset_hu_b52e3343ea6a8764.jpg/123/Lat: 36.59744166666667")
7979

80-
b.AssertImage(200, 200, "public/bundle/sunset_hu13235715490294913361.jpg")
80+
b.AssertImage(200, 200, "public/bundle/sunset_hu_77061c65c31d2244.jpg")
8181

8282
// Check the file cache
83-
b.AssertImage(200, 200, "resources/_gen/images/bundle/sunset_hu13235715490294913361.jpg")
83+
b.AssertImage(200, 200, "resources/_gen/images/bundle/sunset_hu_77061c65c31d2244.jpg")
8484

85-
b.AssertFileContent("resources/_gen/images/bundle/sunset_17710516992648092201.json",
85+
b.AssertFileContent("resources/_gen/images/bundle/sunset_d209dcdc6b875e26.json",
8686
"FocalLengthIn35mmFormat|uint16", "PENTAX")
8787

88-
b.AssertFileContent("resources/_gen/images/images/sunset_17710516992648092201.json",
88+
b.AssertFileContent("resources/_gen/images/images/sunset_d209dcdc6b875e26.json",
8989
"FocalLengthIn35mmFormat|uint16", "PENTAX")
9090

9191
b.AssertNoDuplicateWrites()

‎hugolib/pagesfromdata/pagesfromgotmpl_integration_test.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -119,7 +119,7 @@ docs/p1/sub/mymixcasetext2.txt
119119
"RelPermalink: /docs/p1/sub/mymixcasetext2.txt|Name: sub/mymixcasetext2.txt|",
120120
"RelPermalink: /mydata.yaml|Name: sub/data1.yaml|Title: Sub data|Params: map[]|",
121121
"Featured Image: /a/pixel.png|featured.png|",
122-
"Resized Featured Image: /a/pixel_hu16809842526914527184.png|10|",
122+
"Resized Featured Image: /a/pixel_hu_a32b3e361d55df1.png|10|",
123123
// Resource from string
124124
"RelPermalink: /docs/p1/mytext.txt|Name: textresource|Title: My Text Resource|Params: map[param1:param1v]|",
125125
// Dates

‎hugolib/resource_chain_test.go

+2-2
Original file line numberDiff line numberDiff line change
@@ -106,12 +106,12 @@ FAILED REMOTE ERROR DETAILS CONTENT: {{ with $failedImg }}{{ with .Err }}{{ with
106106
b.AssertFileContent("public/index.html",
107107
fmt.Sprintf(`
108108
SUNSET: /images/sunset.jpg|/images/sunset.a9bf1d944e19c0f382e0d8f51de690f7d0bc8fa97390c4242a86c3e5c0737e71.jpg|900|90587
109-
FIT: /images/sunset.jpg|/images/sunset_hu15210517121918042184.jpg|200
109+
FIT: /images/sunset.jpg|/images/sunset_hu_f2aae87288f3c13b.jpg|200
110110
CSS integrity Data first: sha256-od9YaHw8nMOL8mUy97Sy8sKwMV3N4hI3aVmZXATxH+8= /styles.min.a1df58687c3c9cc38bf26532f7b4b2f2c2b0315dcde212376959995c04f11fef.css
111111
CSS integrity Data last: /styles2.min.1cfc52986836405d37f9998a63fd6dd8608e8c410e5e3db1daaa30f78bc273ba.css sha256-HPxSmGg2QF03+ZmKY/1t2GCOjEEOXj2x2qow94vCc7o=
112112
113113
SUNSET REMOTE: /sunset_%[1]s.jpg|/sunset_%[1]s.a9bf1d944e19c0f382e0d8f51de690f7d0bc8fa97390c4242a86c3e5c0737e71.jpg|900|90587
114-
FIT REMOTE: /sunset_%[1]s.jpg|/sunset_%[1]s_hu15210517121918042184.jpg|200
114+
FIT REMOTE: /sunset_%[1]s.jpg|/sunset_%[1]s_hu_f2aae87288f3c13b.jpg|200
115115
REMOTE NOT FOUND: OK
116116
LOCAL NOT FOUND: OK
117117
PRINT PROTOCOL ERROR DETAILS: Err: template: index.html:22:36: executing "index.html" at <resources.GetRemote>: error calling GetRemote: Get "gopher://example.org": unsupported protocol scheme "gopher"|

‎resources/image.go

+33-63
Original file line numberDiff line numberDiff line change
@@ -30,7 +30,6 @@ import (
3030

3131
"github.com/gohugoio/hugo/cache/filecache"
3232
"github.com/gohugoio/hugo/common/hashing"
33-
"github.com/gohugoio/hugo/common/hstrings"
3433
"github.com/gohugoio/hugo/common/paths"
3534

3635
"github.com/disintegration/gift"
@@ -205,15 +204,12 @@ func (i *imageResource) cloneWithUpdates(u *transformationUpdate) (baseResource,
205204
}, nil
206205
}
207206

208-
var imageActions = []string{images.ActionResize, images.ActionCrop, images.ActionFit, images.ActionFill}
209-
210207
// Process processes the image with the given spec.
211208
// The spec can contain an optional action, one of "resize", "crop", "fit" or "fill".
212209
// This makes this method a more flexible version that covers all of Resize, Crop, Fit and Fill,
213210
// but it also supports e.g. format conversions without any resize action.
214211
func (i *imageResource) Process(spec string) (images.ImageResource, error) {
215-
action, options := i.resolveActionOptions(spec)
216-
return i.processActionOptions(action, options)
212+
return i.processActionSpec("", spec)
217213
}
218214

219215
// Resize resizes the image to the specified width and height using the specified resampling
@@ -243,55 +239,38 @@ func (i *imageResource) Fill(spec string) (images.ImageResource, error) {
243239
}
244240

245241
func (i *imageResource) Filter(filters ...any) (images.ImageResource, error) {
246-
var conf images.ImageConfig
242+
var confMain images.ImageConfig
247243

248244
var gfilters []gift.Filter
249245

250246
for _, f := range filters {
251247
gfilters = append(gfilters, images.ToFilters(f)...)
252248
}
253249

254-
var (
255-
targetFormat images.Format
256-
configSet bool
257-
)
250+
var options []string
251+
258252
for _, f := range gfilters {
259253
f = images.UnwrapFilter(f)
260254
if specProvider, ok := f.(images.ImageProcessSpecProvider); ok {
261-
action, options := i.resolveActionOptions(specProvider.ImageProcessSpec())
262-
var err error
263-
conf, err = images.DecodeImageConfig(action, options, i.Proc.Cfg, i.Format)
264-
if err != nil {
265-
return nil, err
266-
}
267-
configSet = true
268-
if conf.TargetFormat != 0 {
269-
targetFormat = conf.TargetFormat
270-
// We only support one target format, but prefer the last one,
271-
// so we keep going.
272-
}
255+
options = append(options, strings.Fields(specProvider.ImageProcessSpec())...)
273256
}
274257
}
275258

276-
if !configSet {
277-
conf = images.GetDefaultImageConfig("filter", i.Proc.Cfg)
259+
confMain, err := images.DecodeImageConfig(options, i.Proc.Cfg, i.Format)
260+
if err != nil {
261+
return nil, err
278262
}
279263

280-
conf.Action = "filter"
281-
conf.Key = hashing.HashString(gfilters)
282-
conf.TargetFormat = targetFormat
283-
if conf.TargetFormat == 0 {
284-
conf.TargetFormat = i.Format
285-
}
264+
confMain.Action = "filter"
265+
confMain.Key = hashing.HashString(gfilters)
286266

287-
return i.doWithImageConfig(conf, func(src image.Image) (image.Image, error) {
267+
return i.doWithImageConfig(confMain, func(src image.Image) (image.Image, error) {
288268
var filters []gift.Filter
289269
for _, f := range gfilters {
290270
f = images.UnwrapFilter(f)
291271
if specProvider, ok := f.(images.ImageProcessSpecProvider); ok {
292-
processSpec := specProvider.ImageProcessSpec()
293-
action, options := i.resolveActionOptions(processSpec)
294-
conf, err := images.DecodeImageConfig(action, options, i.Proc.Cfg, i.Format)
272+
options := strings.Fields(specProvider.ImageProcessSpec())
273+
conf, err := images.DecodeImageConfig(options, i.Proc.Cfg, i.Format)
295274
if err != nil {
296275
return nil, err
297276
}
@@ -313,25 +292,13 @@ func (i *imageResource) Filter(filters ...any) (images.ImageResource, error) {
313292
})
314293
}
315294

316-
func (i *imageResource) resolveActionOptions(spec string) (string, []string) {
317-
var action string
318-
options := strings.Fields(spec)
319-
for i, p := range options {
320-
if hstrings.InSlicEqualFold(imageActions, p) {
321-
action = p
322-
options = append(options[:i], options[i+1:]...)
323-
break
324-
}
325-
}
326-
return action, options
327-
}
328-
329295
func (i *imageResource) processActionSpec(action, spec string) (images.ImageResource, error) {
330-
return i.processActionOptions(action, strings.Fields(spec))
296+
options := append([]string{action}, strings.Fields(strings.ToLower(spec))...)
297+
return i.processOptions(options)
331298
}
332299

333-
func (i *imageResource) processActionOptions(action string, options []string) (images.ImageResource, error) {
334-
conf, err := images.DecodeImageConfig(action, options, i.Proc.Cfg, i.Format)
300+
func (i *imageResource) processOptions(options []string) (images.ImageResource, error) {
301+
conf, err := images.DecodeImageConfig(options, i.Proc.Cfg, i.Format)
335302
if err != nil {
336303
return nil, err
337304
}
@@ -343,13 +310,12 @@ func (i *imageResource) processActionOptions(action string, options []string) (i
343310
return nil, err
344311
}
345312

346-
if action == images.ActionFill {
347-
if conf.Anchor == 0 && img.Width() == 0 || img.Height() == 0 {
313+
if conf.Action == images.ActionFill {
314+
if conf.Anchor == images.SmartCropAnchor && img.Width() == 0 || img.Height() == 0 {
348315
// See https://github.com/gohugoio/hugo/issues/7955
349316
// Smartcrop fails silently in some rare cases.
350317
// Fall back to a center fill.
351-
conf.Anchor = gift.CenterAnchor
352-
conf.AnchorStr = "center"
318+
conf = conf.Reanchor(gift.CenterAnchor)
353319
return i.doWithImageConfig(conf, func(src image.Image) (image.Image, error) {
354320
return i.Proc.ApplyFiltersFromConfig(src, conf)
355321
})
@@ -417,7 +383,7 @@ func (i *imageResource) doWithImageConfig(conf images.ImageConfig, f func(src im
417383
}
418384

419385
ci := i.clone(converted)
420-
targetPath := i.relTargetPathFromConfig(conf)
386+
targetPath := i.relTargetPathFromConfig(conf, i.getSpec().imaging.Cfg.SourceHash)
421387
ci.setTargetPath(targetPath)
422388
ci.Format = conf.TargetFormat
423389
ci.setMediaType(conf.TargetFormat.MediaType())
@@ -485,26 +451,30 @@ func (i *imageResource) getImageMetaCacheTargetPath() string {
485451
df := i.getResourcePaths()
486452
p1, _ := paths.FileAndExt(df.File)
487453
h := i.hash()
488-
idStr := hashing.HashString(h, i.size(), imageMetaVersionNumber, cfgHash)
454+
idStr := hashing.HashStringHex(h, i.size(), imageMetaVersionNumber, cfgHash)
489455
df.File = fmt.Sprintf("%s_%s.json", p1, idStr)
490456
return df.TargetPath()
491457
}
492458

493-
func (i *imageResource) relTargetPathFromConfig(conf images.ImageConfig) internal.ResourcePaths {
459+
func (i *imageResource) relTargetPathFromConfig(conf images.ImageConfig, imagingConfigSourceHash string) internal.ResourcePaths {
494460
p1, p2 := paths.FileAndExt(i.getResourcePaths().File)
495461
if conf.TargetFormat != i.Format {
496462
p2 = conf.TargetFormat.DefaultExtension()
497463
}
498-
const prefix = "_hu"
499-
huIdx := strings.LastIndex(p1, prefix)
500-
incomingID := "i"
464+
465+
// Do not change.
466+
const imageHashPrefix = "_hu_"
467+
468+
huIdx := strings.LastIndex(p1, imageHashPrefix)
469+
incomingID := ""
501470
if huIdx > -1 {
502-
incomingID = p1[huIdx+len(prefix):]
471+
incomingID = p1[huIdx+len(imageHashPrefix):]
503472
p1 = p1[:huIdx]
504473
}
505-
hash := hashing.HashUint64(incomingID, i.hash(), conf.GetKey(i.Format))
474+
475+
hash := hashing.HashStringHex(incomingID, i.hash(), conf.Key, imagingConfigSourceHash)
506476
rp := i.getResourcePaths()
507-
rp.File = fmt.Sprintf("%s%s%d%s", p1, prefix, hash, p2)
477+
rp.File = fmt.Sprintf("%s%s%s%s", p1, imageHashPrefix, hash, p2)
508478

509479
return rp
510480
}

‎resources/image_cache.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -37,7 +37,7 @@ func (c *ImageCache) getOrCreate(
3737
parent *imageResource, conf images.ImageConfig,
3838
createImage func() (*imageResource, image.Image, error),
3939
) (*resourceAdapter, error) {
40-
relTarget := parent.relTargetPathFromConfig(conf)
40+
relTarget := parent.relTargetPathFromConfig(conf, parent.getSpec().imaging.Cfg.SourceHash)
4141
relTargetPath := relTarget.TargetPath()
4242
memKey := relTargetPath
4343

‎resources/image_extended_test.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -42,6 +42,6 @@ func TestImageResizeWebP(t *testing.T) {
4242
resized, err := image.Resize("123x")
4343
c.Assert(err, qt.IsNil)
4444
c.Assert(image.MediaType(), qt.Equals, media.Builtin.WEBPType)
45-
c.Assert(resized.RelPermalink(), qt.Equals, "/a/sunrise_hu544374262273649331.webp")
45+
c.Assert(resized.RelPermalink(), qt.Equals, "/a/sunrise_hu_a1deb893888915d9.webp")
4646
c.Assert(resized.Width(), qt.Equals, 123)
4747
}

‎resources/image_test.go

+13-13
Original file line numberDiff line numberDiff line change
@@ -113,28 +113,28 @@ func TestImageTransformBasic(t *testing.T) {
113113
assertWidthHeight(resizedAndRotated, 125, 200)
114114

115115
assertWidthHeight(resized, 300, 200)
116-
c.Assert(resized.RelPermalink(), qt.Equals, "/a/sunset_hu2082030801149749592.jpg")
116+
c.Assert(resized.RelPermalink(), qt.Equals, "/a/sunset_hu_d2115125d9324a79.jpg")
117117

118118
fitted, err := resized.Fit("50x50")
119119
c.Assert(err, qt.IsNil)
120-
c.Assert(fitted.RelPermalink(), qt.Equals, "/a/sunset_hu16263619592447877226.jpg")
120+
c.Assert(fitted.RelPermalink(), qt.Equals, "/a/sunset_hu_c2c98e06123b048e.jpg")
121121
assertWidthHeight(fitted, 50, 33)
122122

123123
// Check the MD5 key threshold
124124
fittedAgain, _ := fitted.Fit("10x20")
125125
fittedAgain, err = fittedAgain.Fit("10x20")
126126
c.Assert(err, qt.IsNil)
127-
c.Assert(fittedAgain.RelPermalink(), qt.Equals, "/a/sunset_hu847809310637164306.jpg")
127+
c.Assert(fittedAgain.RelPermalink(), qt.Equals, "/a/sunset_hu_dc9e89c10109de72.jpg")
128128
assertWidthHeight(fittedAgain, 10, 7)
129129

130130
filled, err := image.Fill("200x100 bottomLeft")
131131
c.Assert(err, qt.IsNil)
132-
c.Assert(filled.RelPermalink(), qt.Equals, "/a/sunset_hu18289448341423092707.jpg")
132+
c.Assert(filled.RelPermalink(), qt.Equals, "/a/sunset_hu_b9f6d350738928fe.jpg")
133133
assertWidthHeight(filled, 200, 100)
134134

135135
smart, err := image.Fill("200x100 smart")
136136
c.Assert(err, qt.IsNil)
137-
c.Assert(smart.RelPermalink(), qt.Equals, "/a/sunset_hu11649371610839769766.jpg")
137+
c.Assert(smart.RelPermalink(), qt.Equals, "/a/sunset_hu_6fd390e7b0d26f0b.jpg")
138138
assertWidthHeight(smart, 200, 100)
139139

140140
// Check cache
@@ -144,12 +144,12 @@ func TestImageTransformBasic(t *testing.T) {
144144

145145
cropped, err := image.Crop("300x300 topRight")
146146
c.Assert(err, qt.IsNil)
147-
c.Assert(cropped.RelPermalink(), qt.Equals, "/a/sunset_hu2242042514052853140.jpg")
147+
c.Assert(cropped.RelPermalink(), qt.Equals, "/a/sunset_hu_3df036e11f4ddd43.jpg")
148148
assertWidthHeight(cropped, 300, 300)
149149

150150
smartcropped, err := image.Crop("200x200 smart")
151151
c.Assert(err, qt.IsNil)
152-
c.Assert(smartcropped.RelPermalink(), qt.Equals, "/a/sunset_hu12983255101170993571.jpg")
152+
c.Assert(smartcropped.RelPermalink(), qt.Equals, "/a/sunset_hu_12e2d26de89b464b.jpg")
153153
assertWidthHeight(smartcropped, 200, 200)
154154

155155
// Check cache
@@ -216,15 +216,15 @@ func TestImageTransformFormat(t *testing.T) {
216216

217217
imagePng, err := image.Resize("450x png")
218218
c.Assert(err, qt.IsNil)
219-
c.Assert(imagePng.RelPermalink(), qt.Equals, "/a/sunset_hu11737890885216583918.png")
219+
c.Assert(imagePng.RelPermalink(), qt.Equals, "/a/sunset_hu_e8b9444dcf2e75ef.png")
220220
c.Assert(imagePng.ResourceType(), qt.Equals, "image")
221221
assertExtWidthHeight(imagePng, ".png", 450, 281)
222222
c.Assert(imagePng.Name(), qt.Equals, "sunset.jpg")
223223
c.Assert(imagePng.MediaType().String(), qt.Equals, "image/png")
224224

225225
imageGif, err := image.Resize("225x gif")
226226
c.Assert(err, qt.IsNil)
227-
c.Assert(imageGif.RelPermalink(), qt.Equals, "/a/sunset_hu1431827106749674475.gif")
227+
c.Assert(imageGif.RelPermalink(), qt.Equals, "/a/sunset_hu_f80842d4c3789345.gif")
228228
c.Assert(imageGif.ResourceType(), qt.Equals, "image")
229229
assertExtWidthHeight(imageGif, ".gif", 225, 141)
230230
c.Assert(imageGif.Name(), qt.Equals, "sunset.jpg")
@@ -247,7 +247,7 @@ func TestImagePermalinkPublishOrder(t *testing.T) {
247247
}()
248248

249249
check1 := func(img images.ImageResource) {
250-
resizedLink := "/a/sunset_hu7919355342577096259.jpg"
250+
resizedLink := "/a/sunset_hu_3910bca82e28c9d6.jpg"
251251
c.Assert(img.RelPermalink(), qt.Equals, resizedLink)
252252
assertImageFile(c, spec.PublishFs, resizedLink, 100, 50)
253253
}
@@ -288,12 +288,12 @@ func TestImageBugs(t *testing.T) {
288288
c.Assert(err, qt.IsNil)
289289
c.Assert(resized, qt.Not(qt.IsNil))
290290
c.Assert(resized.Width(), qt.Equals, 200)
291-
c.Assert(resized.RelPermalink(), qt.Equals, "/a/1234567890qwertyuiopasdfghjklzxcvbnm5to6eeeeee7via8eleph_hu9514381480012510326.jpg")
291+
c.Assert(resized.RelPermalink(), qt.Equals, "/a/1234567890qwertyuiopasdfghjklzxcvbnm5to6eeeeee7via8eleph_hu_951d3980b18c52a9.jpg")
292292
resized, err = resized.Resize("100x")
293293
c.Assert(err, qt.IsNil)
294294
c.Assert(resized, qt.Not(qt.IsNil))
295295
c.Assert(resized.Width(), qt.Equals, 100)
296-
c.Assert(resized.RelPermalink(), qt.Equals, "/a/1234567890qwertyuiopasdfghjklzxcvbnm5to6eeeeee7via8eleph_hu1776700126481066216.jpg")
296+
c.Assert(resized.RelPermalink(), qt.Equals, "/a/1234567890qwertyuiopasdfghjklzxcvbnm5to6eeeeee7via8eleph_hu_1daa203572ecd6ec.jpg")
297297
})
298298

299299
// Issue #6137
@@ -391,7 +391,7 @@ func TestImageResize8BitPNG(t *testing.T) {
391391
resized, err := image.Resize("800x")
392392
c.Assert(err, qt.IsNil)
393393
c.Assert(resized.MediaType().Type, qt.Equals, "image/png")
394-
c.Assert(resized.RelPermalink(), qt.Equals, "/a/gohugoio_hu8582372628235034388.png")
394+
c.Assert(resized.RelPermalink(), qt.Equals, "/a/gohugoio_hu_fe2b762e9cac406c.png")
395395
c.Assert(resized.Width(), qt.Equals, 800)
396396
}
397397

0 commit comments

Comments
 (0)