Skip to content

Commit

Permalink
tpl/data: Revise error handling in getJSON and getCSV
Browse files Browse the repository at this point in the history
The most important part being: Log ERROR, but do not stop the build on remote errors.

Fixes gohugoio#5076
  • Loading branch information
bep committed Sep 11, 2018
1 parent fe6676c commit d4d7ae1
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 21 deletions.
36 changes: 23 additions & 13 deletions tpl/data/data.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import (
"encoding/csv"
"encoding/json"
"errors"
"fmt"
"net/http"
"strings"
"time"
Expand Down Expand Up @@ -50,7 +51,7 @@ func (ns *Namespace) GetCSV(sep string, urlParts ...string) (d [][]string, err e
url := strings.Join(urlParts, "")

var clearCacheSleep = func(i int, u string) {
jww.ERROR.Printf("Retry #%d for %s and sleeping for %s", i, url, resSleep)
ns.deps.Log.WARN.Printf("Retry #%d for %s and sleeping for %s", i, url, resSleep)
time.Sleep(resSleep)
deleteCache(url, ns.deps.Fs.Source, ns.deps.Cfg)
}
Expand All @@ -59,8 +60,7 @@ func (ns *Namespace) GetCSV(sep string, urlParts ...string) (d [][]string, err e
var req *http.Request
req, err = http.NewRequest("GET", url, nil)
if err != nil {
jww.ERROR.Printf("Failed to create request for getCSV: %s", err)
return nil, err
return nil, fmt.Errorf("Failed to create request for getCSV: %s", err)
}

req.Header.Add("Accept", "text/csv")
Expand All @@ -69,22 +69,28 @@ func (ns *Namespace) GetCSV(sep string, urlParts ...string) (d [][]string, err e
var c []byte
c, err = ns.getResource(req)
if err != nil {
jww.ERROR.Printf("Failed to read csv resource %q with error message %s", url, err)
return nil, err
ns.deps.Log.ERROR.Printf("Failed to read CSV resource %q: %s", url, err)
return nil, nil
}

if !bytes.Contains(c, []byte(sep)) {
err = errors.New("Cannot find separator " + sep + " in CSV.")
return
ns.deps.Log.ERROR.Printf("Cannot find separator %s in CSV for %s", sep, url)
return nil, nil
}

if d, err = parseCSV(c, sep); err != nil {
jww.ERROR.Printf("Failed to parse csv file %s with error message %s", url, err)
ns.deps.Log.WARN.Printf("Failed to parse CSV file %s: %s", url, err)
clearCacheSleep(i, url)
continue
}
break
}

if err != nil {
ns.deps.Log.ERROR.Printf("Failed to read CSV resource %q: %s", url, err)
return nil, nil
}

return
}

Expand All @@ -98,29 +104,33 @@ func (ns *Namespace) GetJSON(urlParts ...string) (v interface{}, err error) {
var req *http.Request
req, err = http.NewRequest("GET", url, nil)
if err != nil {
jww.ERROR.Printf("Failed to create request for getJSON: %s", err)
return nil, err
return nil, fmt.Errorf("Failed to create request for getJSON: %s", err)
}

req.Header.Add("Accept", "application/json")

var c []byte
c, err = ns.getResource(req)
if err != nil {
jww.ERROR.Printf("Failed to get json resource %s with error message %s", url, err)
jww.ERROR.Printf("Failed to get JSON resource %s: %s", url, err)
return nil, err
}

err = json.Unmarshal(c, &v)
if err != nil {
jww.ERROR.Printf("Cannot read json from resource %s with error message %s", url, err)
jww.ERROR.Printf("Retry #%d for %s and sleeping for %s", i, url, resSleep)
ns.deps.Log.WARN.Printf("Cannot read JSON from resource %s: %s", url, err)
ns.deps.Log.WARN.Printf("Retry #%d for %s and sleeping for %s", i, url, resSleep)
time.Sleep(resSleep)
deleteCache(url, ns.deps.Fs.Source, ns.deps.Cfg)
continue
}
break
}

if err != nil {
jww.ERROR.Printf("Failed to get JSON resource %s: %s", url, err)
return nil, err
}
return
}

Expand Down
14 changes: 9 additions & 5 deletions tpl/data/data_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,14 +21,13 @@ import (
"strings"
"testing"

jww "github.com/spf13/jwalterweatherman"

"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)

func TestGetCSV(t *testing.T) {
t.Parallel()

ns := newTestNs()

for i, test := range []struct {
sep string
Expand Down Expand Up @@ -78,6 +77,8 @@ func TestGetCSV(t *testing.T) {
} {
msg := fmt.Sprintf("Test %d", i)

ns := newTestNs()

// Setup HTTP test server
var srv *httptest.Server
srv, ns.client = getTestServer(func(w http.ResponseWriter, r *http.Request) {
Expand Down Expand Up @@ -108,11 +109,14 @@ func TestGetCSV(t *testing.T) {
// Get on with it
got, err := ns.GetCSV(test.sep, test.url)

require.NoError(t, err, msg)

if _, ok := test.expect.(bool); ok {
assert.Error(t, err, msg)
assert.Equal(t, 1, int(ns.deps.Log.LogCountForLevelsGreaterThanorEqualTo(jww.LevelError)))
assert.Nil(t, got)
continue
}
require.NoError(t, err, msg)
assert.Equal(t, 0, int(ns.deps.Log.LogCountForLevelsGreaterThanorEqualTo(jww.LevelError)))
require.NotNil(t, got, msg)

assert.EqualValues(t, test.expect, got, msg)
Expand Down
12 changes: 9 additions & 3 deletions tpl/data/resources_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ import (
"testing"
"time"

"github.com/gohugoio/hugo/common/loggers"
"github.com/gohugoio/hugo/config"
"github.com/gohugoio/hugo/deps"
"github.com/gohugoio/hugo/helpers"
Expand Down Expand Up @@ -171,10 +172,15 @@ func newDeps(cfg config.Provider) *deps.Deps {
if err != nil {
panic(err)
}

logger := loggers.NewErrorLogger()

return &deps.Deps{
Cfg: cfg,
Fs: hugofs.NewMem(l),
ContentSpec: cs,
Cfg: cfg,
Fs: hugofs.NewMem(l),
ContentSpec: cs,
Log: logger,
DistinctErrorLog: helpers.NewDistinctLogger(logger.ERROR),
}
}

Expand Down

0 comments on commit d4d7ae1

Please sign in to comment.