Skip to content

Commit

Permalink
Fix setting HUGO_MODULE_PROXY etc. via env vars
Browse files Browse the repository at this point in the history
Fixes #7903
  • Loading branch information
bep committed Oct 30, 2020
1 parent 6d95dc9 commit 8a1c637
Show file tree
Hide file tree
Showing 4 changed files with 32 additions and 1 deletion.
4 changes: 4 additions & 0 deletions common/maps/params.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,11 @@ func getNested(m map[string]interface{}, indices []string) (interface{}, string,
first := indices[0]
v, found := m[strings.ToLower(cast.ToString(first))]
if !found {
if len(indices) == 1 {
return nil, first, m
}
return nil, "", nil

}

if len(indices) == 1 {
Expand Down
24 changes: 24 additions & 0 deletions common/maps/params_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -47,5 +47,29 @@ func TestGetNestedParam(t *testing.T) {
c.Assert(must("nested_color", "_", m), qt.Equals, "blue")
c.Assert(must("nested.nestednested.color", ".", m), qt.Equals, "green")
c.Assert(must("string.name", ".", m), qt.IsNil)
c.Assert(must("nested.foo", ".", m), qt.IsNil)

}

// https://github.com/gohugoio/hugo/issues/7903
func TestGetNestedParamFnNestedNewKey(t *testing.T) {

c := qt.New(t)

nested := map[string]interface{}{
"color": "blue",
}
m := map[string]interface{}{
"nested": nested,
}

existing, nestedKey, owner, err := GetNestedParamFn("nested.new", ".", func(key string) interface{} {
return m[key]
})

c.Assert(err, qt.IsNil)
c.Assert(existing, qt.IsNil)
c.Assert(nestedKey, qt.Equals, "new")
c.Assert(owner, qt.DeepEquals, nested)

}
2 changes: 2 additions & 0 deletions hugolib/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -198,6 +198,8 @@ func LoadConfig(d ConfigSourceDescriptor, doWithConfig ...func(cfg config.Provid
} else {
v.Set(key, val)
}
} else if nestedKey != "" {
owner[nestedKey] = valStr
} else {
v.Set(key, valStr)
}
Expand Down
3 changes: 2 additions & 1 deletion hugolib/config_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -495,7 +495,6 @@ stringSlice = ["a", "b"]
[imaging]
anchor = "smart"
quality = 75
resamplefilter = "CatmullRom"
`

b := newTestSitesBuilder(t).WithConfigFile("toml", baseConfig)
Expand All @@ -505,6 +504,7 @@ resamplefilter = "CatmullRom"
"HUGO_NEW", "new", // key not in config.toml
"HUGO_ENABLEGITINFO", "false",
"HUGO_IMAGING_ANCHOR", "top",
"HUGO_IMAGING_RESAMPLEFILTER", "CatmullRom",
"HUGO_STRINGSLICE", `["c", "d"]`,
"HUGO_INTSLICE", `[5, 8, 9]`,
"HUGO_FLOATSLICE", `[5.32]`,
Expand All @@ -519,6 +519,7 @@ resamplefilter = "CatmullRom"
c.Assert(cfg.Get("new"), qt.Equals, "new")
c.Assert(cfg.Get("imaging.anchor"), qt.Equals, "top")
c.Assert(cfg.Get("imaging.quality"), qt.Equals, int64(75))
c.Assert(cfg.Get("imaging.resamplefilter"), qt.Equals, "CatmullRom")
c.Assert(cfg.Get("stringSlice"), qt.DeepEquals, []interface{}{"c", "d"})
c.Assert(cfg.Get("floatSlice"), qt.DeepEquals, []interface{}{5.32})
c.Assert(cfg.Get("intSlice"), qt.DeepEquals, []interface{}{5, 8, 9})
Expand Down

0 comments on commit 8a1c637

Please sign in to comment.