-
Notifications
You must be signed in to change notification settings - Fork 336
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
25 changed files
with
1,152 additions
and
1,260 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
package nutsdb | ||
|
||
import "errors" | ||
|
||
// IsDBClosed is true if the error indicates the db was closed. | ||
func IsDBClosed(err error) bool { | ||
return errors.Is(err, ErrDBClosed) | ||
} | ||
|
||
// IsKeyNotFound is true if the error indicates the key is not found. | ||
func IsKeyNotFound(err error) bool { | ||
return errors.Is(err, ErrKeyNotFound) | ||
} | ||
|
||
// IsBucketNotFound is true if the error indicates the bucket is not exists. | ||
func IsBucketNotFound(err error) bool { | ||
return errors.Is(err, ErrBucketNotFound) | ||
} | ||
|
||
// IsBucketEmpty is true if the bucket is empty. | ||
func IsBucketEmpty(err error) bool { | ||
return errors.Is(err, ErrBucketEmpty) | ||
} | ||
|
||
// IsKeyEmpty is true if the key is empty. | ||
func IsKeyEmpty(err error) bool { | ||
return errors.Is(err, ErrKeyEmpty) | ||
} | ||
|
||
// IsPrefixScan is true if prefix scanning not found the result. | ||
func IsPrefixScan(err error) bool { | ||
return errors.Is(err, ErrPrefixScan) | ||
} | ||
|
||
// IsPrefixSearchScan is true if prefix and search scanning not found the result. | ||
func IsPrefixSearchScan(err error) bool { | ||
return errors.Is(err, ErrPrefixScan) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
package nutsdb | ||
|
||
import ( | ||
"testing" | ||
|
||
"github.com/pkg/errors" | ||
"github.com/stretchr/testify/assert" | ||
) | ||
|
||
func TestIsKeyNotFound(t *testing.T) { | ||
|
||
ts := []struct { | ||
err error | ||
|
||
want bool | ||
}{ | ||
{ | ||
ErrKeyNotFound, | ||
true, | ||
}, | ||
{ | ||
errors.Wrap(ErrKeyNotFound, "foobar"), | ||
true, | ||
}, | ||
{ | ||
errors.New("foo bar"), | ||
false, | ||
}, | ||
} | ||
|
||
for _, tc := range ts { | ||
got := IsKeyNotFound(tc.err) | ||
|
||
assert.Equal(t, tc.want, got) | ||
} | ||
} |
Oops, something went wrong.