Add tests for Provisioner Admin API

This commit is contained in:
Herman Slatman 2021-12-09 23:15:38 +01:00
parent 43a78f495f
commit 5f224b729e
No known key found for this signature in database
GPG key ID: F4D8A44EA0A75A4F
4 changed files with 1125 additions and 18 deletions

View file

@ -487,7 +487,7 @@ type MockAuthority struct {
rekey func(oldCert *x509.Certificate, pk crypto.PublicKey) ([]*x509.Certificate, error) rekey func(oldCert *x509.Certificate, pk crypto.PublicKey) ([]*x509.Certificate, error)
loadProvisionerByCertificate func(cert *x509.Certificate) (provisioner.Interface, error) loadProvisionerByCertificate func(cert *x509.Certificate) (provisioner.Interface, error)
MockLoadProvisionerByName func(name string) (provisioner.Interface, error) MockLoadProvisionerByName func(name string) (provisioner.Interface, error)
getProvisioners func(nextCursor string, limit int) (provisioner.List, string, error) MockGetProvisioners func(nextCursor string, limit int) (provisioner.List, string, error)
revoke func(context.Context, *authority.RevokeOptions) error revoke func(context.Context, *authority.RevokeOptions) error
getEncryptedKey func(kid string) (string, error) getEncryptedKey func(kid string) (string, error)
getRoots func() ([]*x509.Certificate, error) getRoots func() ([]*x509.Certificate, error)
@ -567,8 +567,8 @@ func (m *MockAuthority) Rekey(oldcert *x509.Certificate, pk crypto.PublicKey) ([
} }
func (m *MockAuthority) GetProvisioners(nextCursor string, limit int) (provisioner.List, string, error) { func (m *MockAuthority) GetProvisioners(nextCursor string, limit int) (provisioner.List, string, error) {
if m.getProvisioners != nil { if m.MockGetProvisioners != nil {
return m.getProvisioners(nextCursor, limit) return m.MockGetProvisioners(nextCursor, limit)
} }
return m.ret1.(provisioner.List), m.ret2.(string), m.err return m.ret1.(provisioner.List), m.ret2.(string), m.err
} }

View file

@ -1154,7 +1154,9 @@ func TestHandler_GetExternalAccountKeys(t *testing.T) {
assert.Equals(t, tc.err.StatusCode(), res.StatusCode) assert.Equals(t, tc.err.StatusCode(), res.StatusCode)
assert.Equals(t, tc.err.Detail, adminErr.Detail) assert.Equals(t, tc.err.Detail, adminErr.Detail)
assert.Equals(t, []string{"application/json"}, res.Header["Content-Type"]) assert.Equals(t, []string{"application/json"}, res.Header["Content-Type"])
} else { return
}
body, err := io.ReadAll(res.Body) body, err := io.ReadAll(res.Body)
res.Body.Close() res.Body.Close()
assert.FatalError(t, err) assert.FatalError(t, err)
@ -1168,7 +1170,7 @@ func TestHandler_GetExternalAccountKeys(t *testing.T) {
if !cmp.Equal(tc.resp, response, opts...) { if !cmp.Equal(tc.resp, response, opts...) {
t.Errorf("h.GetExternalAccountKeys diff =\n%s", cmp.Diff(tc.resp, response, opts...)) t.Errorf("h.GetExternalAccountKeys diff =\n%s", cmp.Diff(tc.resp, response, opts...))
} }
}
}) })
} }
} }

View file

@ -54,7 +54,7 @@ func (h *Handler) GetProvisioners(w http.ResponseWriter, r *http.Request) {
cursor, limit, err := api.ParseCursor(r) cursor, limit, err := api.ParseCursor(r)
if err != nil { if err != nil {
api.WriteError(w, admin.WrapError(admin.ErrorBadRequestType, err, api.WriteError(w, admin.WrapError(admin.ErrorBadRequestType, err,
"error parsing cursor & limit query params")) "error parsing cursor and limit from query params"))
return return
} }

File diff suppressed because it is too large Load diff