* mainly sdk.int to cosmossdk.io/math * staking keys * fumpt * var-naming linter errors and a fumpt * Update CHANGELOG.md * Update .golangci.yml * Update CHANGELOG.md * Update test_helpers.go * Update test_helpers.go * fumpt and lint * this lints the db module, and makes it easier to use. It adds breaking name changes * DBConnection -> Connection * previous commit contained a merge error * Update test_helpers.go * Update test_helpers.go * db renamings * merge master * changelog * DBWriter -> Writer * consistent multistore reciever * standard recievers for multistore v2alpha1 * general cleanup of linting issues * more linter fixes * remove prealloc linter * nolint the secp256k1 import * nolint the secp256k1 package * completenolint resulting in a diff that has only nolints
88 lines
2.2 KiB
Go
88 lines
2.2 KiB
Go
package multi
|
|
|
|
import (
|
|
"bytes"
|
|
"errors"
|
|
|
|
dbm "github.com/cosmos/cosmos-sdk/db"
|
|
)
|
|
|
|
type (
|
|
dbDeleteVersionFails struct{ dbm.Connection }
|
|
dbRWCommitFails struct{ dbm.Connection }
|
|
dbRWCrudFails struct{ dbm.Connection }
|
|
dbSaveVersionFails struct{ dbm.Connection }
|
|
dbRevertFails struct {
|
|
dbm.Connection
|
|
// order of calls to fail on (eg. [1, 0] => first call fails; second succeeds)
|
|
failOn []bool
|
|
}
|
|
)
|
|
|
|
type dbVersionsIs struct {
|
|
dbm.Connection
|
|
vset dbm.VersionSet
|
|
}
|
|
type (
|
|
dbVersionsFails struct{ dbm.Connection }
|
|
rwCommitFails struct{ dbm.ReadWriter }
|
|
rwCrudFails struct {
|
|
dbm.ReadWriter
|
|
onKey []byte
|
|
}
|
|
)
|
|
|
|
func (dbVersionsFails) Versions() (dbm.VersionSet, error) { return nil, errors.New("dbVersionsFails") }
|
|
func (db dbVersionsIs) Versions() (dbm.VersionSet, error) { return db.vset, nil }
|
|
func (db dbRWCrudFails) ReadWriter() dbm.ReadWriter {
|
|
return rwCrudFails{db.Connection.ReadWriter(), nil}
|
|
}
|
|
func (dbSaveVersionFails) SaveVersion(uint64) error { return errors.New("dbSaveVersionFails") }
|
|
func (db dbRevertFails) Revert() error {
|
|
fail := false
|
|
if len(db.failOn) > 0 {
|
|
fail, db.failOn = db.failOn[0], db.failOn[1:]
|
|
}
|
|
if fail {
|
|
return errors.New("dbRevertFails")
|
|
}
|
|
return db.Connection.Revert()
|
|
}
|
|
func (dbDeleteVersionFails) DeleteVersion(uint64) error { return errors.New("dbDeleteVersionFails") }
|
|
func (tx rwCommitFails) Commit() error {
|
|
tx.Discard()
|
|
return errors.New("rwCommitFails")
|
|
}
|
|
|
|
func (db dbRWCommitFails) ReadWriter() dbm.ReadWriter {
|
|
return rwCommitFails{db.Connection.ReadWriter()}
|
|
}
|
|
|
|
func (rw rwCrudFails) Get(k []byte) ([]byte, error) {
|
|
if rw.onKey == nil || bytes.Equal(rw.onKey, k) {
|
|
return nil, errors.New("rwCrudFails.Get")
|
|
}
|
|
return rw.ReadWriter.Get(k)
|
|
}
|
|
|
|
func (rw rwCrudFails) Has(k []byte) (bool, error) {
|
|
if rw.onKey == nil || bytes.Equal(rw.onKey, k) {
|
|
return false, errors.New("rwCrudFails.Has")
|
|
}
|
|
return rw.ReadWriter.Has(k)
|
|
}
|
|
|
|
func (rw rwCrudFails) Set(k []byte, v []byte) error {
|
|
if rw.onKey == nil || bytes.Equal(rw.onKey, k) {
|
|
return errors.New("rwCrudFails.Set")
|
|
}
|
|
return rw.ReadWriter.Set(k, v)
|
|
}
|
|
|
|
func (rw rwCrudFails) Delete(k []byte) error {
|
|
if rw.onKey == nil || bytes.Equal(rw.onKey, k) {
|
|
return errors.New("rwCrudFails.Delete")
|
|
}
|
|
return rw.ReadWriter.Delete(k)
|
|
}
|