Skip to content

Commit

Permalink
resources: Replace error handling in GetRemote with try (note)
Browse files Browse the repository at this point in the history
  • Loading branch information
bep committed Jan 5, 2025
1 parent 5d2cbee commit 06d35d6
Show file tree
Hide file tree
Showing 11 changed files with 28 additions and 193 deletions.
14 changes: 13 additions & 1 deletion hugolib/hugo_sites_build.go
Original file line number Diff line number Diff line change
Expand Up @@ -343,6 +343,18 @@ func (h *HugoSites) render(l logg.LevelLogger, config *BuildCfg) error {

siteRenderContext := &siteRenderContext{cfg: config, multihost: h.Configs.IsMultihost}

renderErr := func(err error) error {
if err == nil {
return nil
}
if strings.Contains(err.Error(), "can't evaluate field Err in type resource.Resource") {
// In Hugo 0.141.0 we replaced the special error handling for resources.GetRemote
// with the more general try.
return fmt.Errorf("%s: Resource.Err was removed in Hugo v0.141.0 and replaced with a new try keyword, see https://gohugo.io/getting-started/glossary/#try", err)
}
return err
}

i := 0
for _, s := range h.Sites {
segmentFilter := s.conf.C.SegmentFilter
Expand Down Expand Up @@ -390,7 +402,7 @@ func (h *HugoSites) render(l logg.LevelLogger, config *BuildCfg) error {
}
} else {
if err := s.render(siteRenderContext); err != nil {
return err
return renderErr(err)
}
}
loggers.TimeTrackf(ll, start, nil, "")
Expand Down
4 changes: 0 additions & 4 deletions hugolib/page.go
Original file line number Diff line number Diff line change
Expand Up @@ -185,10 +185,6 @@ func (p *pageState) isContentNodeBranch() bool {
return p.IsNode()
}

func (p *pageState) Err() resource.ResourceError {
return nil
}

// Eq returns whether the current page equals the given page.
// This is what's invoked when doing `{{ if eq $page $otherPage }}`
func (p *pageState) Eq(other any) bool {
Expand Down
6 changes: 3 additions & 3 deletions hugolib/resource_chain_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -67,19 +67,19 @@ FIT: {{ $fit.Name }}|{{ $fit.RelPermalink }}|{{ $fit.Width }}
CSS integrity Data first: {{ $cssFingerprinted1.Data.Integrity }} {{ $cssFingerprinted1.RelPermalink }}
CSS integrity Data last: {{ $cssFingerprinted2.RelPermalink }} {{ $cssFingerprinted2.Data.Integrity }}
{{ $failedImg := resources.GetRemote "%[1]s/fail.jpg" }}
{{ $failedImg := try resources.GetRemote "%[1]s/fail.jpg" }}
{{ $rimg := resources.GetRemote "%[1]s/sunset.jpg" }}
{{ $remotenotfound := resources.GetRemote "%[1]s/notfound.jpg" }}
{{ $localnotfound := resources.Get "images/notfound.jpg" }}
{{ $gopherprotocol := resources.GetRemote "gopher://example.org" }}
{{ $gopherprotocol := try resources.GetRemote "gopher://example.org" }}
{{ $rfit := $rimg.Fit "200x200" }}
{{ $rfit2 := $rfit.Fit "100x200" }}
{{ $rimg = $rimg | fingerprint }}
SUNSET REMOTE: {{ $rimg.Name }}|{{ $rimg.RelPermalink }}|{{ $rimg.Width }}|{{ len $rimg.Content }}
FIT REMOTE: {{ $rfit.Name }}|{{ $rfit.RelPermalink }}|{{ $rfit.Width }}
REMOTE NOT FOUND: {{ if $remotenotfound }}FAILED{{ else}}OK{{ end }}
LOCAL NOT FOUND: {{ if $localnotfound }}FAILED{{ else}}OK{{ end }}
PRINT PROTOCOL ERROR1: {{ with $gopherprotocol }}{{ . | safeHTML }}{{ end }}
PRINT PROTOCOL ERROR1: {{ with $gopherprotocol }}{{ .Value | safeHTML }}{{ end }}
PRINT PROTOCOL ERROR2: {{ with $gopherprotocol }}{{ .Err | safeHTML }}{{ end }}
PRINT PROTOCOL ERROR DETAILS: {{ with $gopherprotocol }}Err: {{ .Err | safeHTML }}{{ with .Err }}|{{ with .Data }}Body: {{ .Body }}|StatusCode: {{ .StatusCode }}{{ end }}|{{ end }}{{ end }}
FAILED REMOTE ERROR DETAILS CONTENT: {{ with $failedImg.Err }}|{{ . }}|{{ with .Data }}Body: {{ .Body }}|StatusCode: {{ .StatusCode }}|ContentLength: {{ .ContentLength }}|ContentType: {{ .ContentType }}{{ end }}{{ end }}|
Expand Down
145 changes: 0 additions & 145 deletions resources/errorResource.go

This file was deleted.

4 changes: 0 additions & 4 deletions resources/page/page_nop.go
Original file line number Diff line number Diff line change
Expand Up @@ -61,10 +61,6 @@ type nopPage int

var noOpPathInfo = media.DefaultPathParser.Parse(files.ComponentFolderContent, "no-op.md")

func (p *nopPage) Err() resource.ResourceError {
return nil
}

func (p *nopPage) Aliases() []string {
return nil
}
Expand Down
4 changes: 0 additions & 4 deletions resources/page/testhelpers_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -111,10 +111,6 @@ type testPage struct {
sectionEntries []string
}

func (p *testPage) Err() resource.ResourceError {
return nil
}

func (p *testPage) Aliases() []string {
panic("testpage: not implemented")
}
Expand Down
7 changes: 0 additions & 7 deletions resources/resource.go
Original file line number Diff line number Diff line change
Expand Up @@ -224,9 +224,6 @@ type resourceCopier interface {

// Copy copies r to the targetPath given.
func Copy(r resource.Resource, targetPath string) resource.Resource {
if r.Err() != nil {
panic(fmt.Sprintf("Resource has an .Err: %s", r.Err()))
}
return r.(resourceCopier).cloneTo(targetPath)
}

Expand Down Expand Up @@ -439,10 +436,6 @@ func (l *genericResource) Content(context.Context) (any, error) {
return hugio.ReadString(r)
}

func (r *genericResource) Err() resource.ResourceError {
return nil
}

func (l *genericResource) Data() any {
return l.sd.Data
}
Expand Down
8 changes: 0 additions & 8 deletions resources/resource/resourcetypes.go
Original file line number Diff line number Diff line change
Expand Up @@ -65,13 +65,6 @@ type ResourceError interface {
ResourceDataProvider
}

// ErrProvider provides an Err.
type ErrProvider interface {
// Err returns an error if this resource is in an error state.
// This will currently only be set for resources obtained from resources.GetRemote.
Err() ResourceError
}

// Resource represents a linkable resource, i.e. a content page, image etc.
type Resource interface {
ResourceWithoutMeta
Expand All @@ -83,7 +76,6 @@ type ResourceWithoutMeta interface {
MediaTypeProvider
ResourceLinksProvider
ResourceDataProvider
ErrProvider
}

type ResourceWrapper interface {
Expand Down
17 changes: 8 additions & 9 deletions resources/resource_factories/create/create_integration_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,18 +31,17 @@ func TestGetRemoteHead(t *testing.T) {
[security.http]
methods = ['(?i)GET|POST|HEAD']
urls = ['.*gohugo\.io.*']
-- layouts/index.html --
{{ $url := "https://gohugo.io/img/hugo.png" }}
{{ $opts := dict "method" "head" }}
{{ with resources.GetRemote $url $opts }}
{{ with try (resources.GetRemote $url $opts) }}
{{ with .Err }}
{{ errorf "Unable to get remote resource: %s" . }}
{{ else }}
{{ else with .Value }}
Head Content: {{ .Content }}. Head Data: {{ .Data }}
{{ end }}
{{ else }}
{{ else }}
{{ errorf "Unable to get remote resource: %s" $url }}
{{ end }}
{{ end }}
`

Expand Down Expand Up @@ -90,14 +89,14 @@ mediaTypes = ['text/plain']
-- layouts/_default/single.html --
{{ $url := printf "%s%s" "URL" .RelPermalink}}
{{ $opts := dict }}
{{ with resources.GetRemote $url $opts }}
{{ with try (resources.GetRemote $url $opts) }}
{{ with .Err }}
{{ errorf "Got Err: %s. Data: %v" . .Data }}
{{ else }}
{{ else with .Value }}
Content: {{ .Content }}
{{ else }}
{{ errorf "Unable to get remote resource: %s" $url }}
{{ end }}
{{ else }}
{{ errorf "Unable to get remote resource: %s" $url }}
{{ end }}
`

Expand Down
4 changes: 0 additions & 4 deletions resources/transform.go
Original file line number Diff line number Diff line change
Expand Up @@ -192,10 +192,6 @@ func (r *resourceAdapter) Content(ctx context.Context) (any, error) {
return r.target.Content(ctx)
}

func (r *resourceAdapter) Err() resource.ResourceError {
return nil
}

func (r *resourceAdapter) GetIdentity() identity.Identity {
return identity.FirstIdentity(r.target)
}
Expand Down
8 changes: 4 additions & 4 deletions tpl/resources/resources.go
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ func (ns *Namespace) Get(filename any) resource.Resource {
//
// Note: This method does not return any error as a second return value,
// for any error situations the error can be checked in .Err.
func (ns *Namespace) GetRemote(args ...any) resource.Resource {
func (ns *Namespace) GetRemote(args ...any) (resource.Resource, error) {
get := func(args ...any) (resource.Resource, error) {
if len(args) < 1 {
return nil, errors.New("must provide an URL")
Expand Down Expand Up @@ -146,12 +146,12 @@ func (ns *Namespace) GetRemote(args ...any) resource.Resource {
if err != nil {
switch v := err.(type) {
case *create.HTTPError:
return resources.NewErrorResource(resource.NewResourceError(v, v.Data))
return nil, resource.NewResourceError(v, v.Data)
default:
return resources.NewErrorResource(resource.NewResourceError(fmt.Errorf("error calling resources.GetRemote: %w", err), make(map[string]any)))
return nil, resource.NewResourceError(fmt.Errorf("error calling resources.GetRemote: %w", err), make(map[string]any))
}
}
return r
return r, nil
}

// GetMatch finds the first Resource matching the given pattern, or nil if none found.
Expand Down

0 comments on commit 06d35d6

Please sign in to comment.