Skip to content

Commit

Permalink
FIXUP - re-expose ErrFieldNotExist without param
Browse files Browse the repository at this point in the history
  • Loading branch information
AndrewSisley committed Sep 16, 2022
1 parent 4c0c538 commit 1b8af36
Show file tree
Hide file tree
Showing 4 changed files with 16 additions and 11 deletions.
10 changes: 5 additions & 5 deletions client/document.go
Original file line number Diff line number Diff line change
Expand Up @@ -177,7 +177,7 @@ func (doc *Document) GetValue(field string) (Value, error) {
path, subPaths, hasSubPaths := parseFieldPath(field)
f, exists := doc.fields[path]
if !exists {
return nil, ErrFieldNotExist(path)
return nil, NewErrFieldNotExist(path)
}

val, err := doc.GetValueWithField(f)
Expand All @@ -200,7 +200,7 @@ func (doc *Document) GetValueWithField(f Field) (Value, error) {
defer doc.mu.RUnlock()
v, exists := doc.values[f]
if !exists {
return nil, ErrFieldNotExist(f.Name())
return nil, NewErrFieldNotExist(f.Name())
}
return v, nil
}
Expand Down Expand Up @@ -246,7 +246,7 @@ func (doc *Document) Delete(fields ...string) error {
for _, f := range fields {
field, exists := doc.fields[f]
if !exists {
return ErrFieldNotExist(f)
return NewErrFieldNotExist(f)
}
doc.values[field].Delete()
}
Expand Down Expand Up @@ -432,7 +432,7 @@ func (doc *Document) toMap() (map[string]any, error) {
for k, v := range doc.fields {
value, exists := doc.values[v]
if !exists {
return nil, ErrFieldNotExist(v.Name())
return nil, NewErrFieldNotExist(v.Name())
}

if value.IsDocument() {
Expand All @@ -457,7 +457,7 @@ func (doc *Document) toMapWithKey() (map[string]any, error) {
for k, v := range doc.fields {
value, exists := doc.values[v]
if !exists {
return nil, ErrFieldNotExist(v.Name())
return nil, NewErrFieldNotExist(v.Name())
}

if value.IsDocument() {
Expand Down
9 changes: 7 additions & 2 deletions client/errors.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,11 +12,16 @@ package client

import "github.com/sourcenetwork/defradb/errors"

const (
errFieldNotExist string = "The given field does not exist"
)

// Errors returnable from this package.
//
// This list is incomplete and undefined errors may also be returned.
// Errors returned from this package may be tested against these errors with errors.Is.
var (
ErrFieldNotExist = errors.New(errFieldNotExist)
ErrFieldNotObject = errors.New("Trying to access field on a non object type")
ErrValueTypeMismatch = errors.New("Value does not match indicated type")
ErrIndexNotFound = errors.New("No index found for given ID")
Expand All @@ -26,6 +31,6 @@ var (
ErrInvalidDeleteTarget = errors.New("The target document to delete is of invalid type")
)

func ErrFieldNotExist(name string) error {
return errors.New("The given field does not exist", errors.NewKV("Name", name))
func NewErrFieldNotExist(name string) error {
return errors.New(errFieldNotExist, errors.NewKV("Name", name))
}
4 changes: 2 additions & 2 deletions db/collection.go
Original file line number Diff line number Diff line change
Expand Up @@ -600,11 +600,11 @@ func (c *collection) save(
if val.IsDirty() {
fieldKey, fieldExists := c.tryGetFieldKey(primaryKey, k)
if !fieldExists {
return cid.Undef, client.ErrFieldNotExist(k)
return cid.Undef, client.NewErrFieldNotExist(k)
}

if c.isFieldRelationId(k) {
return cid.Undef, client.ErrFieldNotExist(k)
return cid.Undef, client.NewErrFieldNotExist(k)
}

c, err := c.saveDocValue(ctx, txn, fieldKey, val)
Expand Down
4 changes: 2 additions & 2 deletions db/collection_update.go
Original file line number Diff line number Diff line change
Expand Up @@ -365,7 +365,7 @@ func (c *collection) applyMerge(
}

if c.isFieldRelationIdD(&fd) {
return client.ErrFieldNotExist(mfield)
return client.NewErrFieldNotExist(mfield)
}

cborVal, err := validateFieldSchema(mval, fd)
Expand All @@ -377,7 +377,7 @@ func (c *collection) applyMerge(
val := client.NewCBORValue(fd.Typ, cborVal)
fieldKey, fieldExists := c.tryGetFieldKey(key, mfield)
if !fieldExists {
return client.ErrFieldNotExist(mfield)
return client.NewErrFieldNotExist(mfield)
}

c, err := c.saveDocValue(ctx, txn, fieldKey, val)
Expand Down

0 comments on commit 1b8af36

Please sign in to comment.