X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/a93774da6449567a2759672cf329be6ec96f91e3..f69605f9427aa401b0f83c1e131e3c455eae4e38:/sdk/go/arvados/config_test.go diff --git a/sdk/go/arvados/config_test.go b/sdk/go/arvados/config_test.go index b984cb5669..8c77e29287 100644 --- a/sdk/go/arvados/config_test.go +++ b/sdk/go/arvados/config_test.go @@ -5,6 +5,8 @@ package arvados import ( + "encoding/json" + "github.com/ghodss/yaml" check "gopkg.in/check.v1" ) @@ -45,3 +47,36 @@ func (s *ConfigSuite) TestInstanceTypeSize(c *check.C) { c.Check(int64(it.Scratch), check.Equals, int64(4000000000)) c.Check(int64(it.RAM), check.Equals, int64(4294967296)) } + +func (s *ConfigSuite) TestInstanceTypeFixup(c *check.C) { + for _, confdata := range []string{ + // Current format: map of entries + `{foo4: {IncludedScratch: 4GB}, foo8: {ProviderType: foo_8, Scratch: 8GB}}`, + // Legacy format: array of entries with key in "Name" field + `[{Name: foo4, IncludedScratch: 4GB}, {Name: foo8, ProviderType: foo_8, Scratch: 8GB}]`, + } { + c.Log(confdata) + var itm InstanceTypeMap + err := yaml.Unmarshal([]byte(confdata), &itm) + c.Check(err, check.IsNil) + + c.Check(itm["foo4"].Name, check.Equals, "foo4") + c.Check(itm["foo4"].ProviderType, check.Equals, "foo4") + c.Check(itm["foo4"].Scratch, check.Equals, ByteSize(4000000000)) + c.Check(itm["foo4"].AddedScratch, check.Equals, ByteSize(0)) + c.Check(itm["foo4"].IncludedScratch, check.Equals, ByteSize(4000000000)) + + c.Check(itm["foo8"].Name, check.Equals, "foo8") + c.Check(itm["foo8"].ProviderType, check.Equals, "foo_8") + c.Check(itm["foo8"].Scratch, check.Equals, ByteSize(8000000000)) + c.Check(itm["foo8"].AddedScratch, check.Equals, ByteSize(8000000000)) + c.Check(itm["foo8"].IncludedScratch, check.Equals, ByteSize(0)) + } +} + +func (s *ConfigSuite) TestURLTrailingSlash(c *check.C) { + var a, b map[URL]bool + json.Unmarshal([]byte(`{"https://foo.example": true}`), &a) + json.Unmarshal([]byte(`{"https://foo.example/": true}`), &b) + c.Check(a, check.DeepEquals, b) +}