Skip to content

Commit

Permalink
Merge pull request distribution#2446 from legionus/docker-configurati…
Browse files Browse the repository at this point in the history
…on-ptr

Fix the pointer initialization
  • Loading branch information
dmcgowan authored Feb 23, 2020
2 parents 861aa2a + e698374 commit f593b8d
Show file tree
Hide file tree
Showing 2 changed files with 71 additions and 1 deletion.
2 changes: 1 addition & 1 deletion configuration/parser.go
Original file line number Diff line number Diff line change
Expand Up @@ -220,7 +220,7 @@ func (p *Parser) overwriteStruct(v reflect.Value, fullpath string, path []string
}
case reflect.Ptr:
if field.IsNil() {
field.Set(reflect.New(sf.Type))
field.Set(reflect.New(field.Type().Elem()))
}
}

Expand Down
70 changes: 70 additions & 0 deletions configuration/parser_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
package configuration

import (
"os"
"reflect"

. "gopkg.in/check.v1"
)

type localConfiguration struct {
Version Version `yaml:"version"`
Log *Log `yaml:"log"`
}

type Log struct {
Formatter string `yaml:"formatter,omitempty"`
}

var expectedConfig = localConfiguration{
Version: "0.1",
Log: &Log{
Formatter: "json",
},
}

type ParserSuite struct{}

var _ = Suite(new(ParserSuite))

func (suite *ParserSuite) TestParserOverwriteIninitializedPoiner(c *C) {
config := localConfiguration{}

os.Setenv("REGISTRY_LOG_FORMATTER", "json")
defer os.Unsetenv("REGISTRY_LOG_FORMATTER")

p := NewParser("registry", []VersionedParseInfo{
{
Version: "0.1",
ParseAs: reflect.TypeOf(config),
ConversionFunc: func(c interface{}) (interface{}, error) {
return c, nil
},
},
})

err := p.Parse([]byte(`{version: "0.1", log: {formatter: "text"}}`), &config)
c.Assert(err, IsNil)
c.Assert(config, DeepEquals, expectedConfig)
}

func (suite *ParserSuite) TestParseOverwriteUnininitializedPoiner(c *C) {
config := localConfiguration{}

os.Setenv("REGISTRY_LOG_FORMATTER", "json")
defer os.Unsetenv("REGISTRY_LOG_FORMATTER")

p := NewParser("registry", []VersionedParseInfo{
{
Version: "0.1",
ParseAs: reflect.TypeOf(config),
ConversionFunc: func(c interface{}) (interface{}, error) {
return c, nil
},
},
})

err := p.Parse([]byte(`{version: "0.1"}`), &config)
c.Assert(err, IsNil)
c.Assert(config, DeepEquals, expectedConfig)
}

0 comments on commit f593b8d

Please sign in to comment.