Prathamesh Musale
213c390c37
Some checks failed
Integration Tests / test-integration (push) Successful in 2m48s
E2E Tests / test-e2e (push) Successful in 4m56s
Lint / Run golangci-lint (push) Successful in 5m6s
Unit Tests / test-unit (push) Successful in 3m22s
SDK Tests / sdk_tests_nameservice_expiry (push) Successful in 10m40s
SDK Tests / sdk_tests (push) Successful in 10m55s
SDK Tests / sdk_tests_auctions (push) Failing after 16m7s
Part of https://www.notion.so/Rename-laconic2d-to-laconicd-9028d0c020d24d1288e92ebcb773d7a7 Co-authored-by: neeraj <neeraj.rtly@gmail.com> Reviewed-on: cerc-io/laconic2d#26 Co-authored-by: Prathamesh Musale <prathamesh@noreply.git.vdb.to> Co-committed-by: Prathamesh Musale <prathamesh@noreply.git.vdb.to>
76 lines
1.9 KiB
Go
76 lines
1.9 KiB
Go
package keeper
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
|
|
types "git.vdb.to/cerc-io/laconicd/x/registry"
|
|
)
|
|
|
|
// RegisterInvariants registers all registry invariants
|
|
func RegisterInvariants(ir sdk.InvariantRegistry, k Keeper) {
|
|
ir.RegisterRoute(types.ModuleName, "module-account", ModuleAccountInvariant(&k))
|
|
ir.RegisterRoute(types.ModuleName, "record-bond", RecordBondInvariant(&k))
|
|
}
|
|
|
|
// AllInvariants runs all invariants of the registry module.
|
|
func AllInvariants(k *Keeper) sdk.Invariant {
|
|
return func(ctx sdk.Context) (string, bool) {
|
|
res, stop := ModuleAccountInvariant(k)(ctx)
|
|
if stop {
|
|
return res, stop
|
|
}
|
|
|
|
return RecordBondInvariant(k)(ctx)
|
|
}
|
|
}
|
|
|
|
// ModuleAccountInvariant checks that the 'registry' module account balance is non-negative.
|
|
func ModuleAccountInvariant(k *Keeper) sdk.Invariant {
|
|
return func(ctx sdk.Context) (string, bool) {
|
|
moduleAddress := k.accountKeeper.GetModuleAddress(types.ModuleName)
|
|
if k.bankKeeper.GetAllBalances(ctx, moduleAddress).IsAnyNegative() {
|
|
return sdk.FormatInvariant(
|
|
types.ModuleName,
|
|
"module-account",
|
|
fmt.Sprintf("Module account '%s' has negative balance.", types.ModuleName),
|
|
), true
|
|
}
|
|
|
|
return "", false
|
|
}
|
|
}
|
|
|
|
// RecordBondInvariant checks that for every record:
|
|
// if bondId is not null, associated bond exists
|
|
func RecordBondInvariant(k *Keeper) sdk.Invariant {
|
|
return func(ctx sdk.Context) (string, bool) {
|
|
err := k.Records.Walk(ctx, nil, func(key string, record types.Record) (bool, error) {
|
|
if record.BondId != "" {
|
|
bondExists, err := k.bondKeeper.HasBond(ctx, record.BondId)
|
|
if err != nil {
|
|
return true, err
|
|
}
|
|
|
|
if !bondExists {
|
|
return true, errors.New(record.Id)
|
|
}
|
|
}
|
|
|
|
return false, nil
|
|
})
|
|
|
|
if err != nil {
|
|
return sdk.FormatInvariant(
|
|
types.ModuleName,
|
|
"record-bond",
|
|
fmt.Sprintf("Bond not found for record id: '%s'.", err.Error()),
|
|
), true
|
|
}
|
|
|
|
return "", false
|
|
}
|
|
}
|