mirror of
https://github.com/ethereum/go-ethereum.git
synced 2026-06-26 16:36:17 +00:00
* New struct in consensus/XDPoS/utils/types.go, util functions, and test. (#14) * define vote, timeout, sync info, qc, tc, extra fields in types.go, add test in types_test.go * add json tag in types.go, refine encoder decoder of extra fields * refactor types.go utils.go * re-write types, comments * add Hash SigHash for types, and tests * define Round type * remove unnecessary logs * add v2 engine functions placeholder * typo fix on the consensus v2 function placeholders * add countdown timer * make initilised private to countdown * add v2 specific config struct * rename some config variables * Implement BFT Message receiver (#13) * fix or skip tests due to PR-136 changes * add bft receiver functions * add bft receiver functions * rename tc to TimeoutCert * implement more functions * New struct in consensus/XDPoS/utils/types.go, util functions, and test. (#14) * define vote, timeout, sync info, qc, tc, extra fields in types.go, add test in types_test.go * add json tag in types.go, refine encoder decoder of extra fields * refactor types.go utils.go * re-write types, comments * add Hash SigHash for types, and tests * define Round type * remove unnecessary logs * add temp functions * add v2 engine functions placeholder * typo fix on the consensus v2 function placeholders * add countdown timer * make initilised private to countdown * push verify function * add test on receiving vote * revert type change * add async on broadcast function * add quit initial * fix test Co-authored-by: Jianrong <wjrjerome@gmail.com> Co-authored-by: wgr523 <wgr523@gmail.com> * generate and verify timeout message * Consensus V2 variable, timeout pool (#19) * fill in XDPoS_v2 variables and processQC/TC * add timeout pool, refine engine variables * refactor type functions * solve a small pointer bug * create general pool and its test, refine engine * refine pool, add xdpos v2 config cert threshold * refine config * vote and timeout handlers * fix pool test * bft miner preparation * review comment improvement * update * relocate tests * add and remove comment * fix the syntax error * update network layer and add handler functions (#23) * update network layer and add handler functions * fix test syntax error * add ProcessQC implementation * add ProcessQC tests * add snapshot test * add wait qc process * remove testing files * add route snapshot * fix merge issue * add default v2 behaviour (#24) * add v2 ecrecover functions and refactor test * fix all the tests * put minimun lock variable * debugging prepare and seal v2 blocks * Trigger proposeBlockHandler after v2 block received and verified in fetcher * skip snapshot apply related tests * update test check * rename bfter to bft handler and ignore normal behviour * fix bugs during local 4 node run * fix test * fix sync info test * fix bugs during local 4 node run * rebase and fix bug * remove hook validators function" Co-authored-by: wgr523 <wgr523@gmail.com> Co-authored-by: Jianrong <wjrjerome@gmail.com>
86 lines
2.7 KiB
Go
86 lines
2.7 KiB
Go
package tests
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/XinFinOrg/XDPoSChain/consensus/XDPoS"
|
|
"github.com/XinFinOrg/XDPoSChain/consensus/XDPoS/utils"
|
|
"github.com/XinFinOrg/XDPoSChain/params"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
// Timeout handler
|
|
func TestTimeoutMessageHandlerSuccessfullyGenerateTCandSyncInfo(t *testing.T) {
|
|
blockchain, _, _, _ := PrepareXDCTestBlockChainForV2Engine(t, 11, params.TestXDPoSMockChainConfigWithV2Engine)
|
|
engineV2 := blockchain.Engine().(*XDPoS.XDPoS).EngineV2
|
|
|
|
// Set round to 1
|
|
engineV2.SetNewRoundFaker(utils.Round(1), false)
|
|
// Create two timeout message which will not reach timeout pool threshold
|
|
timeoutMsg := &utils.Timeout{
|
|
Round: utils.Round(1),
|
|
Signature: []byte{1},
|
|
}
|
|
|
|
err := engineV2.TimeoutHandler(timeoutMsg)
|
|
assert.Nil(t, err)
|
|
currentRound, _, _ := engineV2.GetProperties()
|
|
assert.Equal(t, utils.Round(1), currentRound)
|
|
timeoutMsg = &utils.Timeout{
|
|
Round: utils.Round(1),
|
|
Signature: []byte{2},
|
|
}
|
|
err = engineV2.TimeoutHandler(timeoutMsg)
|
|
assert.Nil(t, err)
|
|
currentRound, _, _ = engineV2.GetProperties()
|
|
assert.Equal(t, utils.Round(1), currentRound)
|
|
// Create a timeout message that should trigger timeout pool hook
|
|
timeoutMsg = &utils.Timeout{
|
|
Round: utils.Round(1),
|
|
Signature: []byte{3},
|
|
}
|
|
|
|
err = engineV2.TimeoutHandler(timeoutMsg)
|
|
assert.Nil(t, err)
|
|
|
|
syncInfoMsg := <-engineV2.BroadcastCh
|
|
|
|
currentRound, _, _ = engineV2.GetProperties()
|
|
|
|
assert.NotNil(t, syncInfoMsg)
|
|
|
|
// Shouldn't have QC, however, we did not inilise it, hence will show default empty value
|
|
qc := syncInfoMsg.(*utils.SyncInfo).HighestQuorumCert
|
|
assert.Nil(t, qc)
|
|
|
|
tc := syncInfoMsg.(*utils.SyncInfo).HighestTimeoutCert
|
|
assert.NotNil(t, tc)
|
|
assert.Equal(t, tc.Round, utils.Round(1))
|
|
sigatures := []utils.Signature{[]byte{1}, []byte{2}, []byte{3}}
|
|
assert.ElementsMatch(t, tc.Signatures, sigatures)
|
|
assert.Equal(t, utils.Round(2), currentRound)
|
|
}
|
|
|
|
func TestThrowErrorIfTimeoutMsgRoundNotEqualToCurrentRound(t *testing.T) {
|
|
blockchain, _, _, _ := PrepareXDCTestBlockChainForV2Engine(t, 11, params.TestXDPoSMockChainConfigWithV2Engine)
|
|
engineV2 := blockchain.Engine().(*XDPoS.XDPoS).EngineV2
|
|
|
|
// Set round to 3
|
|
engineV2.SetNewRoundFaker(utils.Round(3), false)
|
|
timeoutMsg := &utils.Timeout{
|
|
Round: utils.Round(2),
|
|
Signature: []byte{1},
|
|
}
|
|
|
|
err := engineV2.TimeoutHandler(timeoutMsg)
|
|
assert.NotNil(t, err)
|
|
// Timeout msg round > currentRound
|
|
assert.Equal(t, "Timeout message round number: 2 does not match currentRound: 3", err.Error())
|
|
|
|
// Set round to 1
|
|
engineV2.SetNewRoundFaker(utils.Round(1), false)
|
|
err = engineV2.TimeoutHandler(timeoutMsg)
|
|
assert.NotNil(t, err)
|
|
// Timeout msg round < currentRound
|
|
assert.Equal(t, "Timeout message round number: 2 does not match currentRound: 1", err.Error())
|
|
}
|