From f3a48f74a347ab1a01fca80c370be423620ff499 Mon Sep 17 00:00:00 2001 From: Zack Newman Date: Fri, 5 Aug 2022 11:47:35 -0600 Subject: [PATCH] refactor!: rename "InitLocal" to "Init" (#354) * refactor!: rename "InitLocal" to "Init" Straightforward find/replace: find . -name '*.go' | xargs sed -i 's/InitLocal/Init/g' BREAKING CHANGE: the method signature of `Init()` has changed since the last release to take in the raw `root.json` metadata. Fixes #208. Signed-off-by: Zachary Newman * test: remove now-obsolete duplicate test Signed-off-by: Zachary Newman --- client/client.go | 4 +-- client/client_test.go | 35 +++++--------------- client/delegations_test.go | 2 +- client/interop_test.go | 2 +- client/python_interop/python_interop_test.go | 2 +- cmd/tuf-client/init.go | 2 +- 6 files changed, 14 insertions(+), 33 deletions(-) diff --git a/client/client.go b/client/client.go index 42756f8a..188d8a8a 100644 --- a/client/client.go +++ b/client/client.go @@ -106,13 +106,13 @@ func NewClient(local LocalStore, remote RemoteStore) *Client { } } -// InitLocal initializes a local repository from root metadata. +// Init initializes a local repository from root metadata. // // The root's keys are extracted from the root and saved in local storage. // Root expiration is not checked. // It is expected that rootJSON was securely distributed with the software // being updated. -func (c *Client) InitLocal(rootJSON []byte) error { +func (c *Client) Init(rootJSON []byte) error { err := c.loadAndVerifyRootMeta(rootJSON, true /*ignoreExpiredCheck*/) if err != nil { return err diff --git a/client/client_test.go b/client/client_test.go index c23a9666..f312f847 100644 --- a/client/client_test.go +++ b/client/client_test.go @@ -185,7 +185,7 @@ func (s *ClientSuite) rootMeta(c *C) []byte { func (s *ClientSuite) newClient(c *C) *Client { s.local = MemoryLocalStore() client := NewClient(s.local, s.remote) - c.Assert(client.InitLocal(s.rootMeta(c)), IsNil) + c.Assert(client.Init(s.rootMeta(c)), IsNil) return client } @@ -244,26 +244,7 @@ func (s *ClientSuite) assertErrExpired(c *C, err error, file string) { c.Assert(expiredErr.Expired.Unix(), Equals, s.expiredTime.Round(time.Second).Unix()) } -func (s *ClientSuite) TestInit(c *C) { - client := NewClient(MemoryLocalStore(), s.remote) - - // check invalid json - c.Assert(client.InitLocal(make([]byte, 0)), NotNil) - rootJson := `{ "signatures": [], "signed": {"version": "wrongtype"}, "spec_version": "1.0.0", "version": 1}` - err := client.InitLocal([]byte(rootJson)) - c.Assert(err.Error(), Matches, "json: cannot unmarshal string.*") - - // check Update() returns ErrNoRootKeys when uninitialized - _, err = client.Update() - c.Assert(err, Equals, ErrNoRootKeys) - - // check Update() does not return ErrNoRootKeys after initialization - c.Assert(client.InitLocal(s.rootMeta(c)), IsNil) - _, err = client.Update() - c.Assert(err, IsNil) -} - -func (s *ClientSuite) TestInitLocalAllowsExpired(c *C) { +func (s *ClientSuite) TestInitAllowsExpired(c *C) { s.genKeyExpired(c, "targets") c.Assert(s.repo.Snapshot(), IsNil) c.Assert(s.repo.Timestamp(), IsNil) @@ -273,11 +254,11 @@ func (s *ClientSuite) TestInitLocalAllowsExpired(c *C) { bytes, err := io.ReadAll(s.remote.meta["root.json"]) c.Assert(err, IsNil) s.withMetaExpired(func() { - c.Assert(client.InitLocal(bytes), IsNil) + c.Assert(client.Init(bytes), IsNil) }) } -func (s *ClientSuite) TestInitLocal(c *C) { +func (s *ClientSuite) TestInit(c *C) { client := NewClient(MemoryLocalStore(), s.remote) bytes, err := io.ReadAll(s.remote.meta["root.json"]) c.Assert(err, IsNil) @@ -290,7 +271,7 @@ func (s *ClientSuite) TestInitLocal(c *C) { _, err = client.Update() c.Assert(err, Equals, ErrNoRootKeys) - // check InitLocal() returns ErrInvalid when the root's signature is + // check Init() returns ErrInvalid when the root's signature is // invalid // modify root and marshal without regenerating signatures root.Version = root.Version + 1 @@ -299,10 +280,10 @@ func (s *ClientSuite) TestInitLocal(c *C) { dataSigned.Signed = rootBytes dataBytes, err := json.Marshal(dataSigned) c.Assert(err, IsNil) - c.Assert(client.InitLocal(dataBytes), Equals, verify.ErrInvalid) + c.Assert(client.Init(dataBytes), Equals, verify.ErrInvalid) // check Update() does not return ErrNoRootKeys after initialization - c.Assert(client.InitLocal(bytes), IsNil) + c.Assert(client.Init(bytes), IsNil) _, err = client.Update() c.Assert(err, IsNil) } @@ -1042,7 +1023,7 @@ func (s *ClientSuite) TestUpdateHTTP(c *C) { c.Assert(err, IsNil) rootJsonBytes, err := json.Marshal(rootMeta) c.Assert(err, IsNil) - c.Assert(client.InitLocal(rootJsonBytes), IsNil) + c.Assert(client.Init(rootJsonBytes), IsNil) // check update is ok targets, err := client.Update() diff --git a/client/delegations_test.go b/client/delegations_test.go index c7303aca..250e7b70 100644 --- a/client/delegations_test.go +++ b/client/delegations_test.go @@ -275,7 +275,7 @@ func initTestDelegationClient(t *testing.T, dirPrefix string) (*Client, func() e c := NewClient(MemoryLocalStore(), remote) rawFile, err := ioutil.ReadFile(initialStateDir + "/" + "root.json") assert.Nil(t, err) - assert.Nil(t, c.InitLocal(rawFile)) + assert.Nil(t, c.Init(rawFile)) files, err := ioutil.ReadDir(initialStateDir) assert.Nil(t, err) diff --git a/client/interop_test.go b/client/interop_test.go index 8e4becbc..15ece0d3 100644 --- a/client/interop_test.go +++ b/client/interop_test.go @@ -153,7 +153,7 @@ func (t *testCase) runStep(c *C, stepName string) { c.Assert(err, IsNil) rootJsonBytes, err := io.ReadAll(ioReader) c.Assert(err, IsNil) - c.Assert(client.InitLocal(rootJsonBytes), IsNil) + c.Assert(client.Init(rootJsonBytes), IsNil) // check update returns the correct updated targets files, err := client.Update() diff --git a/client/python_interop/python_interop_test.go b/client/python_interop/python_interop_test.go index 7a4abdc6..e2e2a915 100644 --- a/client/python_interop/python_interop_test.go +++ b/client/python_interop/python_interop_test.go @@ -59,7 +59,7 @@ func (InteropSuite) TestGoClientPythonGenerated(c *C) { client := client.NewClient(client.MemoryLocalStore(), remote) rootJSON, err := ioutil.ReadFile(filepath.Join(testDataDir, dir, "repository", "metadata", "root.json")) c.Assert(err, IsNil) - c.Assert(client.InitLocal(rootJSON), IsNil) + c.Assert(client.Init(rootJSON), IsNil) // check update returns the correct updated targets files, err := client.Update() diff --git a/cmd/tuf-client/init.go b/cmd/tuf-client/init.go index f043c0b7..b3a0f6ae 100644 --- a/cmd/tuf-client/init.go +++ b/cmd/tuf-client/init.go @@ -35,5 +35,5 @@ func cmdInit(args *docopt.Args, client *tuf.Client) error { if err != nil { return err } - return client.InitLocal(bytes) + return client.Init(bytes) }