2022-04-16 08:40:21 +00:00
// 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 resources_test
import (
"strings"
"testing"
2022-05-25 16:06:20 +00:00
qt "github.com/frankban/quicktest"
2022-04-16 08:40:21 +00:00
"github.com/gohugoio/hugo/hugolib"
)
// Issue 8931
func TestImageCache ( t * testing . T ) {
2022-05-25 16:06:20 +00:00
t . Parallel ( )
2022-04-16 08:40:21 +00:00
files := `
-- config . toml --
baseURL = "https://example.org"
-- content / mybundle / index . md --
-- -
title : "My Bundle"
-- -
-- content / mybundle / pixel . png --
iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR42mNkYPhfDwAChwGA60e6kgAAAABJRU5ErkJggg ==
2023-06-14 06:14:39 +00:00
-- content / mybundle / giphy . gif --
sourcefilename : testdata / giphy . gif
2022-04-16 08:40:21 +00:00
-- layouts / foo . html --
-- layouts / index . html --
{ { $ p := site . GetPage "mybundle" } }
{ { $ img := $ p . Resources . Get "pixel.png" } }
2023-06-14 06:14:39 +00:00
{ { $ giphy := $ p . Resources . Get "giphy.gif" } }
{ { $ gif := $ img . Resize "1x2 gif" } }
{ { $ bmp := $ img . Resize "2x3 bmp" } }
{ { $ anigif := $ giphy . Resize "4x5" } }
2022-04-16 08:40:21 +00:00
2023-06-14 06:14:39 +00:00
gif : { { $ gif . RelPermalink } } | } | { { $ gif . Width } } | { { $ gif . Height } } | { { $ gif . MediaType } } |
bmp : { { $ bmp . RelPermalink } } | } | { { $ bmp . Width } } | { { $ bmp . Height } } | { { $ bmp . MediaType } } |
anigif : { { $ anigif . RelPermalink } } | { { $ anigif . Width } } | { { $ anigif . Height } } | { { $ anigif . MediaType } } |
2022-04-16 08:40:21 +00:00
`
b := hugolib . NewIntegrationTestBuilder (
hugolib . IntegrationTestConfig {
T : t ,
TxtarString : files ,
NeedsOsFS : true ,
Running : true ,
} ) . Build ( )
assertImages := func ( ) {
b . AssertFileContent ( "public/index.html" , `
2023-06-14 06:14:39 +00:00
gif : / mybundle / pixel_hu8aa3346827e49d756ff4e630147c42b5_70_1x2_resize_box_3 . gif | } | 1 | 2 | image / gif |
bmp : / mybundle / pixel_hu8aa3346827e49d756ff4e630147c42b5_70_2x3_resize_box_3 . bmp | } | 2 | 3 | image / bmp |
anigif : / mybundle / giphy_hu3eafc418e52414ace6236bf1d31f82e1_52213_4x5_resize_box_1 . gif | 4 | 5 | image / gif |
2022-04-16 08:40:21 +00:00
` )
}
assertImages ( )
b . EditFileReplace ( "content/mybundle/index.md" , func ( s string ) string { return strings . ReplaceAll ( s , "Bundle" , "BUNDLE" ) } )
b . Build ( )
assertImages ( )
}
2022-05-25 16:06:20 +00:00
func TestSVGError ( t * testing . T ) {
t . Parallel ( )
files := `
-- config . toml --
-- assets / circle . svg --
< svg height = "100" width = "100" > < circle cx = "50" cy = "50" r = "40" stroke = "black" stroke - width = "3" fill = "red" / > < / svg >
-- layouts / index . html --
{ { $ svg := resources . Get "circle.svg" } }
Width : { { $ svg . Width } }
`
b , err := hugolib . NewIntegrationTestBuilder (
hugolib . IntegrationTestConfig {
T : t ,
TxtarString : files ,
NeedsOsFS : true ,
Running : true ,
} ) . BuildE ( )
b . Assert ( err , qt . IsNotNil )
b . Assert ( err . Error ( ) , qt . Contains , ` error calling Width: this method is only available for raster images. To determine if an image is SVG, you can do {{ if eq .MediaType .SubType "svg" }} {{ end }} ` )
}