From 0e127562bf60228a0824c15c11eeeba7f1101d9f Mon Sep 17 00:00:00 2001 From: Ethan Buchman Date: Thu, 26 Jul 2018 18:53:19 -0400 Subject: [PATCH 1/4] register evidence interface wherever its used --- blockchain/wire.go | 2 ++ consensus/reactor_test.go | 46 +++++++++++++++++++++++++++++++++++++++ consensus/types/wire.go | 2 ++ evidence/wire.go | 10 --------- types/evidence.go | 4 ++++ types/wire.go | 1 + 6 files changed, 55 insertions(+), 10 deletions(-) diff --git a/blockchain/wire.go b/blockchain/wire.go index ff02d58c1..cfd261abb 100644 --- a/blockchain/wire.go +++ b/blockchain/wire.go @@ -3,6 +3,7 @@ package blockchain import ( "github.com/tendermint/go-amino" cryptoAmino "github.com/tendermint/tendermint/crypto/encoding/amino" + "github.com/tendermint/tendermint/types" ) var cdc = amino.NewCodec() @@ -10,4 +11,5 @@ var cdc = amino.NewCodec() func init() { RegisterBlockchainMessages(cdc) cryptoAmino.RegisterAmino(cdc) + types.RegisterEvidences(cdc) } diff --git a/consensus/reactor_test.go b/consensus/reactor_test.go index 9e2aa0a0b..90def612b 100644 --- a/consensus/reactor_test.go +++ b/consensus/reactor_test.go @@ -13,6 +13,7 @@ import ( "github.com/tendermint/tendermint/abci/example/kvstore" cmn "github.com/tendermint/tendermint/libs/common" "github.com/tendermint/tendermint/libs/log" + sm "github.com/tendermint/tendermint/state" cfg "github.com/tendermint/tendermint/config" "github.com/tendermint/tendermint/p2p" @@ -91,6 +92,51 @@ func TestReactorBasic(t *testing.T) { }, css) } +// Ensure we can process blocks with evidence +func TestReactorWithEvidence(t *testing.T) { + N := 4 + css := randConsensusNet(N, "consensus_reactor_test", newMockTickerFunc(true), newCounter) + evpool := mockEvidencePool{ + t: t, + ev: []types.Evidence{types.NewMockGoodEvidence(1, 1, []byte("somone"))}, + } + for i := 0; i < N; i++ { + css[i].evpool = evpool + } + reactors, eventChans, eventBuses := startConsensusNet(t, css, N) + defer stopConsensusNet(log.TestingLogger(), reactors, eventBuses) + // wait till everyone makes the first new block + timeoutWaitGroup(t, N, func(j int) { + <-eventChans[j] + }, css) + + // second block should have evidence + timeoutWaitGroup(t, N, func(j int) { + <-eventChans[j] + }, css) +} + +type mockEvidencePool struct { + height int + ev []types.Evidence + t *testing.T +} + +func (m mockEvidencePool) PendingEvidence() []types.Evidence { + if m.height > 0 { + return m.ev + } + return nil +} +func (m mockEvidencePool) AddEvidence(types.Evidence) error { return nil } +func (m mockEvidencePool) Update(block *types.Block, state sm.State) { + m.height += 1 + + if m.height > 0 { + require.True(m.t, len(block.Evidence.Evidence) > 0) + } +} + // Ensure a testnet sends proposal heartbeats and makes blocks when there are txs func TestReactorProposalHeartbeats(t *testing.T) { N := 4 diff --git a/consensus/types/wire.go b/consensus/types/wire.go index 9221de968..c0b858ddf 100644 --- a/consensus/types/wire.go +++ b/consensus/types/wire.go @@ -3,10 +3,12 @@ package types import ( "github.com/tendermint/go-amino" cryptoAmino "github.com/tendermint/tendermint/crypto/encoding/amino" + "github.com/tendermint/tendermint/types" ) var cdc = amino.NewCodec() func init() { cryptoAmino.RegisterAmino(cdc) + types.RegisterEvidences(cdc) } diff --git a/evidence/wire.go b/evidence/wire.go index c61b86184..73ff33b2b 100644 --- a/evidence/wire.go +++ b/evidence/wire.go @@ -12,14 +12,4 @@ func init() { RegisterEvidenceMessages(cdc) cryptoAmino.RegisterAmino(cdc) types.RegisterEvidences(cdc) - RegisterMockEvidences(cdc) // For testing -} - -//------------------------------------------- - -func RegisterMockEvidences(cdc *amino.Codec) { - cdc.RegisterConcrete(types.MockGoodEvidence{}, - "tendermint/MockGoodEvidence", nil) - cdc.RegisterConcrete(types.MockBadEvidence{}, - "tendermint/MockBadEvidence", nil) } diff --git a/types/evidence.go b/types/evidence.go index 6313f43a5..b04d0ece5 100644 --- a/types/evidence.go +++ b/types/evidence.go @@ -41,6 +41,10 @@ type Evidence interface { func RegisterEvidences(cdc *amino.Codec) { cdc.RegisterInterface((*Evidence)(nil), nil) cdc.RegisterConcrete(&DuplicateVoteEvidence{}, "tendermint/DuplicateVoteEvidence", nil) + + // mocks + cdc.RegisterConcrete(&MockGoodEvidence{}, "tendermint/MockGoodEvidence", nil) + cdc.RegisterConcrete(&MockBadEvidence{}, "tendermint/MockBadEvidence", nil) } //------------------------------------------- diff --git a/types/wire.go b/types/wire.go index 9221de968..4f7a38c59 100644 --- a/types/wire.go +++ b/types/wire.go @@ -9,4 +9,5 @@ var cdc = amino.NewCodec() func init() { cryptoAmino.RegisterAmino(cdc) + RegisterEvidences(cdc) } From e4dfab6349026c40bd737933a1ff86e6dcb033ef Mon Sep 17 00:00:00 2001 From: Ethan Buchman Date: Thu, 26 Jul 2018 18:54:15 -0400 Subject: [PATCH 2/4] changelog and version --- CHANGELOG.md | 9 +++++++++ version/version.go | 4 ++-- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 929d11d97..c0dca0af1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,14 @@ # Changelog +## 0.22.7 + +*July 26th, 2018* + +BUG FIXES + +- [consensus, blockchain] Register the Evidence interface so it can be + marshalled/unmarshalled by the blockchain and consensus reactors + ## 0.22.6 *July 24th, 2018* diff --git a/version/version.go b/version/version.go index 5ef4aadbf..474c43a38 100644 --- a/version/version.go +++ b/version/version.go @@ -4,13 +4,13 @@ package version const ( Maj = "0" Min = "22" - Fix = "6" + Fix = "7" ) var ( // Version is the current version of Tendermint // Must be a string because scripts like dist.sh read this file. - Version = "0.22.6" + Version = "0.22.7" // GitCommit is the current HEAD set using ldflags. GitCommit string From 49b52ee3c77e1e7350de801c65b76961f6b9b934 Mon Sep 17 00:00:00 2001 From: Hendrik Hofstadt Date: Fri, 27 Jul 2018 00:41:15 +0200 Subject: [PATCH 3/4] Add test for MakePartSet with evidence --- types/block_test.go | 21 ++++++++++++++++++++- types/evidence.go | 4 ++-- types/wire.go | 2 +- 3 files changed, 23 insertions(+), 4 deletions(-) diff --git a/types/block_test.go b/types/block_test.go index 714029bf2..50695c84b 100644 --- a/types/block_test.go +++ b/types/block_test.go @@ -6,7 +6,7 @@ import ( "github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" - crypto "github.com/tendermint/tendermint/crypto" + "github.com/tendermint/tendermint/crypto" cmn "github.com/tendermint/tendermint/libs/common" ) @@ -101,6 +101,25 @@ func TestBlockMakePartSet(t *testing.T) { assert.Equal(t, 1, partSet.Total()) } +func TestBlockMakePartSetWithEvidence(t *testing.T) { + assert.Nil(t, (*Block)(nil).MakePartSet(2)) + + txs := []Tx{Tx("foo"), Tx("bar")} + lastID := makeBlockIDRandom() + h := int64(3) + + voteSet, valSet, vals := randVoteSet(h-1, 1, VoteTypePrecommit, 10, 1) + commit, err := MakeCommit(lastID, h-1, 1, voteSet, vals) + require.NoError(t, err) + + ev := NewMockGoodEvidence(h, 0, valSet.Validators[0].Address) + evList := []Evidence{ev} + + partSet := MakeBlock(h, txs, commit, evList).MakePartSet(1024) + assert.NotNil(t, partSet) + assert.Equal(t, 3, partSet.Total()) +} + func TestBlockHashesTo(t *testing.T) { assert.False(t, (*Block)(nil).HashesTo(nil)) diff --git a/types/evidence.go b/types/evidence.go index b04d0ece5..92675868f 100644 --- a/types/evidence.go +++ b/types/evidence.go @@ -43,8 +43,8 @@ func RegisterEvidences(cdc *amino.Codec) { cdc.RegisterConcrete(&DuplicateVoteEvidence{}, "tendermint/DuplicateVoteEvidence", nil) // mocks - cdc.RegisterConcrete(&MockGoodEvidence{}, "tendermint/MockGoodEvidence", nil) - cdc.RegisterConcrete(&MockBadEvidence{}, "tendermint/MockBadEvidence", nil) + cdc.RegisterConcrete(MockGoodEvidence{}, "tendermint/MockGoodEvidence", nil) + cdc.RegisterConcrete(MockBadEvidence{}, "tendermint/MockBadEvidence", nil) } //------------------------------------------- diff --git a/types/wire.go b/types/wire.go index 4f7a38c59..569ea3213 100644 --- a/types/wire.go +++ b/types/wire.go @@ -2,7 +2,7 @@ package types import ( "github.com/tendermint/go-amino" - cryptoAmino "github.com/tendermint/tendermint/crypto/encoding/amino" + "github.com/tendermint/tendermint/crypto/encoding/amino" ) var cdc = amino.NewCodec() From d542d2c3945116697f60451e6a407082c41c3cc9 Mon Sep 17 00:00:00 2001 From: Jae Kwon Date: Thu, 26 Jul 2018 18:08:09 -0700 Subject: [PATCH 4/4] Fix 0.22.7, bump to 0.22.8 --- CHANGELOG.md | 8 ++++++++ blockchain/wire.go | 4 +--- consensus/types/wire.go | 4 +--- consensus/wire.go | 4 ++-- lite/files/wire.go | 4 ++-- rpc/core/types/wire.go | 4 +--- types/wire.go | 4 ++++ version/version.go | 4 ++-- 8 files changed, 21 insertions(+), 15 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index c0dca0af1..0c7446783 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,13 @@ # Changelog +## 0.22.8 + +*July 26th, 2018* + +BUG FIXES + +- [consensus, blockchain] Fix 0.22.7 below. + ## 0.22.7 *July 26th, 2018* diff --git a/blockchain/wire.go b/blockchain/wire.go index cfd261abb..91156fa8f 100644 --- a/blockchain/wire.go +++ b/blockchain/wire.go @@ -2,7 +2,6 @@ package blockchain import ( "github.com/tendermint/go-amino" - cryptoAmino "github.com/tendermint/tendermint/crypto/encoding/amino" "github.com/tendermint/tendermint/types" ) @@ -10,6 +9,5 @@ var cdc = amino.NewCodec() func init() { RegisterBlockchainMessages(cdc) - cryptoAmino.RegisterAmino(cdc) - types.RegisterEvidences(cdc) + types.RegisterBlockAmino(cdc) } diff --git a/consensus/types/wire.go b/consensus/types/wire.go index c0b858ddf..db674816d 100644 --- a/consensus/types/wire.go +++ b/consensus/types/wire.go @@ -2,13 +2,11 @@ package types import ( "github.com/tendermint/go-amino" - cryptoAmino "github.com/tendermint/tendermint/crypto/encoding/amino" "github.com/tendermint/tendermint/types" ) var cdc = amino.NewCodec() func init() { - cryptoAmino.RegisterAmino(cdc) - types.RegisterEvidences(cdc) + types.RegisterBlockAmino(cdc) } diff --git a/consensus/wire.go b/consensus/wire.go index cc172bead..567e6095e 100644 --- a/consensus/wire.go +++ b/consensus/wire.go @@ -2,7 +2,7 @@ package consensus import ( "github.com/tendermint/go-amino" - cryptoAmino "github.com/tendermint/tendermint/crypto/encoding/amino" + "github.com/tendermint/tendermint/types" ) var cdc = amino.NewCodec() @@ -10,5 +10,5 @@ var cdc = amino.NewCodec() func init() { RegisterConsensusMessages(cdc) RegisterWALMessages(cdc) - cryptoAmino.RegisterAmino(cdc) + types.RegisterBlockAmino(cdc) } diff --git a/lite/files/wire.go b/lite/files/wire.go index f45e4c630..e7864831e 100644 --- a/lite/files/wire.go +++ b/lite/files/wire.go @@ -2,11 +2,11 @@ package files import ( "github.com/tendermint/go-amino" - cryptoAmino "github.com/tendermint/tendermint/crypto/encoding/amino" + "github.com/tendermint/tendermint/types" ) var cdc = amino.NewCodec() func init() { - cryptoAmino.RegisterAmino(cdc) + types.RegisterBlockAmino(cdc) } diff --git a/rpc/core/types/wire.go b/rpc/core/types/wire.go index d49b977eb..ef1fa8001 100644 --- a/rpc/core/types/wire.go +++ b/rpc/core/types/wire.go @@ -2,12 +2,10 @@ package core_types import ( "github.com/tendermint/go-amino" - cryptoAmino "github.com/tendermint/tendermint/crypto/encoding/amino" "github.com/tendermint/tendermint/types" ) func RegisterAmino(cdc *amino.Codec) { types.RegisterEventDatas(cdc) - types.RegisterEvidences(cdc) - cryptoAmino.RegisterAmino(cdc) + types.RegisterBlockAmino(cdc) } diff --git a/types/wire.go b/types/wire.go index 569ea3213..c56089983 100644 --- a/types/wire.go +++ b/types/wire.go @@ -8,6 +8,10 @@ import ( var cdc = amino.NewCodec() func init() { + RegisterBlockAmino(cdc) +} + +func RegisterBlockAmino(cdc *amino.Codec) { cryptoAmino.RegisterAmino(cdc) RegisterEvidences(cdc) } diff --git a/version/version.go b/version/version.go index 474c43a38..85b1f1918 100644 --- a/version/version.go +++ b/version/version.go @@ -4,13 +4,13 @@ package version const ( Maj = "0" Min = "22" - Fix = "7" + Fix = "8" ) var ( // Version is the current version of Tendermint // Must be a string because scripts like dist.sh read this file. - Version = "0.22.7" + Version = "0.22.8" // GitCommit is the current HEAD set using ldflags. GitCommit string