Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

x/evidence genesis protobuf migration #6864

Merged
merged 19 commits into from
Jul 29, 2020
Merged
Show file tree
Hide file tree
Changes from 11 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion proto/cosmos/evidence/evidence.proto
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,14 @@ option (gogoproto.equal_all) = true;
import "gogoproto/gogo.proto";
import "google/protobuf/timestamp.proto";
import "google/protobuf/any.proto";
import "cosmos_proto/cosmos.proto";

// MsgSubmitEvidence defines an sdk.Msg type that supports submitting arbitrary
// Evidence.
message MsgSubmitEvidence {
option (gogoproto.goproto_getters) = false;
bytes submitter = 1 [(gogoproto.casttype) = "github.com/cosmos/cosmos-sdk/types.AccAddress"];
google.protobuf.Any evidence = 2;
google.protobuf.Any evidence = 2 [(cosmos_proto.accepts_interface) = "Evidence"];;
blushi marked this conversation as resolved.
Show resolved Hide resolved
}

// Equivocation implements the Evidence interface and defines evidence of double
Expand Down
11 changes: 11 additions & 0 deletions proto/cosmos/evidence/genesis.proto
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
syntax = "proto3";
package cosmos.evidence;

option go_package = "github.com/cosmos/cosmos-sdk/x/evidence/types";

import "google/protobuf/any.proto";

// GenesisState defines the evidence module's genesis state.
message GenesisState {
repeated google.protobuf.Any evidence = 1;
}
28 changes: 24 additions & 4 deletions x/evidence/genesis.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,12 @@ package evidence
import (
"fmt"

codectypes "github.com/cosmos/cosmos-sdk/codec/types"
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/cosmos/cosmos-sdk/x/evidence/exported"
"github.com/cosmos/cosmos-sdk/x/evidence/keeper"
"github.com/cosmos/cosmos-sdk/x/evidence/types"
"github.com/gogo/protobuf/proto"
)

// InitGenesis initializes the evidence module's state from a provided genesis
Expand All @@ -16,17 +19,34 @@ func InitGenesis(ctx sdk.Context, k keeper.Keeper, gs types.GenesisState) {
}

for _, e := range gs.Evidence {
if _, ok := k.GetEvidence(ctx, e.Hash()); ok {
panic(fmt.Sprintf("evidence with hash %s already exists", e.Hash()))
evi, ok := e.GetCachedValue().(exported.Evidence)
if !ok {
panic("expected evidence")
}
if _, ok := k.GetEvidence(ctx, evi.Hash()); ok {
panic(fmt.Sprintf("evidence with hash %s already exists", evi.Hash()))
}

k.SetEvidence(ctx, e)
k.SetEvidence(ctx, evi)
}
}

// ExportGenesis returns the evidence module's exported genesis.
func ExportGenesis(ctx sdk.Context, k keeper.Keeper) types.GenesisState {
fedekunze marked this conversation as resolved.
Show resolved Hide resolved
e := k.GetAllEvidence(ctx)
evidence := make([]*codectypes.Any, len(e))
for i, evi := range e {
msg, ok := evi.(proto.Message)
if !ok {
panic(fmt.Errorf("cannot proto marshal %T", evi))
}
any, err := codectypes.NewAnyWithValue(msg)
if err != nil {
panic(err)
}
evidence[i] = any
}
return types.GenesisState{
Evidence: k.GetAllEvidence(ctx),
Evidence: evidence,
}
}
8 changes: 4 additions & 4 deletions x/evidence/simulation/genesis.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,23 +8,23 @@ import (

"github.com/cosmos/cosmos-sdk/codec"

codectypes "github.com/cosmos/cosmos-sdk/codec/types"
"github.com/cosmos/cosmos-sdk/types/module"
simtypes "github.com/cosmos/cosmos-sdk/types/simulation"
"github.com/cosmos/cosmos-sdk/x/evidence/exported"
"github.com/cosmos/cosmos-sdk/x/evidence/types"
)

// Simulation parameter constants
const evidence = "evidence"

// GenEvidences returns an empty slice of evidences.
func GenEvidences(_ *rand.Rand, _ []simtypes.Account) []exported.Evidence {
return []exported.Evidence{}
func GenEvidences(_ *rand.Rand, _ []simtypes.Account) []*codectypes.Any {
blushi marked this conversation as resolved.
Show resolved Hide resolved
return []*codectypes.Any{}
}

// RandomizedGenState generates a random GenesisState for evidence
func RandomizedGenState(simState *module.SimulationState) {
var ev []exported.Evidence
var ev []*codectypes.Any

simState.AppParams.GetOrGenerate(
simState.Cdc, evidence, &ev, simState.Rand,
Expand Down
25 changes: 0 additions & 25 deletions x/evidence/simulation/genesis_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,6 @@ import (
// Abonormal scenarios are not tested here.
func TestRandomizedGenState(t *testing.T) {
cdc := codec.New()
// Make sure to register cdc.
// Otherwise RandomizedGenState will panic!
types.RegisterCodec(cdc)

s := rand.NewSource(1)
r := rand.New(s)
Expand All @@ -42,25 +39,3 @@ func TestRandomizedGenState(t *testing.T) {

require.Len(t, evidenceGenesis.Evidence, 0)
}

// TestRandomizedGenState tests the execution of RandomizedGenState
// without registering the evidence interfaces.
// We expect the test to panic.
func TestRandomizedGenState1(t *testing.T) {
cdc := codec.New()

s := rand.NewSource(1)
r := rand.New(s)

simState := module.SimulationState{
AppParams: make(simtypes.AppParams),
Cdc: cdc,
Rand: r,
NumBonded: 3,
Accounts: simtypes.RandomAccounts(r, 3),
InitialStake: 1000,
GenState: make(map[string]json.RawMessage),
}

require.Panicsf(t, func() { simulation.RandomizedGenState(&simState) }, "failed to marshal JSON: Unregistered interface exported.Evidence")
}
54 changes: 28 additions & 26 deletions x/evidence/types/evidence.pb.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

44 changes: 36 additions & 8 deletions x/evidence/types/genesis.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,40 +3,68 @@ package types
import (
"fmt"

"github.com/cosmos/cosmos-sdk/codec/types"
"github.com/cosmos/cosmos-sdk/x/evidence/exported"
proto "github.com/gogo/protobuf/proto"
)

// DONTCOVER

blushi marked this conversation as resolved.
Show resolved Hide resolved
// GenesisState defines the evidence module's genesis state.
type GenesisState struct {
Evidence []exported.Evidence `json:"evidence" yaml:"evidence"`
}
var _ types.UnpackInterfacesMessage = GenesisState{}

// NewGenesisState creates a new genesis state for the evidence module.
func NewGenesisState(e []exported.Evidence) GenesisState {
evidence := make([]*types.Any, len(e))
for i, evi := range e {
msg, ok := evi.(proto.Message)
if !ok {
panic(fmt.Errorf("cannot proto marshal %T", evi))
}
any, err := types.NewAnyWithValue(msg)
if err != nil {
panic(err)
}
evidence[i] = any
}
return GenesisState{
Evidence: e,
Evidence: evidence,
}
}

// DefaultGenesisState returns the evidence module's default genesis state.
func DefaultGenesisState() GenesisState {
return GenesisState{
Evidence: []exported.Evidence{},
Evidence: []*types.Any{},
}
}

// Validate performs basic gensis state validation returning an error upon any
// failure.
func (gs GenesisState) Validate() error {
for i, e := range gs.Evidence {
if e == nil {
evi, ok := e.GetCachedValue().(exported.Evidence)
if !ok {
return fmt.Errorf("expected evidence")
}
if evi == nil {
return fmt.Errorf("evidence %d cannot be nil", i)
}
if err := e.ValidateBasic(); err != nil {
if err := evi.ValidateBasic(); err != nil {
return err
}
}

return nil
}

// UnpackInterfaces implements UnpackInterfacesMessage.UnpackInterfaces
func (gs GenesisState) UnpackInterfaces(unpacker types.AnyUnpacker) error {
blushi marked this conversation as resolved.
Show resolved Hide resolved
for _, any := range gs.Evidence {
var evi exported.Evidence
err := unpacker.UnpackAny(any, &evi)
if err != nil {
return err
}
}
return nil
}
Loading