mirror of
https://github.com/fluencelabs/tendermint
synced 2025-06-25 10:41:41 +00:00
make BlockTimeIota a consensus parameter, not a locally configurable … (#3048)
* make BlockTimeIota a consensus parameter, not a locally configurable option Refs #2920 * make TimeIota int64 ms Refs #2920 * update Gopkg.toml * fixes after Ethan's review * fix TestRemoteSignerProposalSigningFailed * update changelog
This commit is contained in:
@ -19,22 +19,23 @@ func TestConsensusParamsValidation(t *testing.T) {
|
||||
params ConsensusParams
|
||||
valid bool
|
||||
}{
|
||||
// test block size
|
||||
0: {makeParams(1, 0, 1, valEd25519), true},
|
||||
1: {makeParams(0, 0, 1, valEd25519), false},
|
||||
2: {makeParams(47*1024*1024, 0, 1, valEd25519), true},
|
||||
3: {makeParams(10, 0, 1, valEd25519), true},
|
||||
4: {makeParams(100*1024*1024, 0, 1, valEd25519), true},
|
||||
5: {makeParams(101*1024*1024, 0, 1, valEd25519), false},
|
||||
6: {makeParams(1024*1024*1024, 0, 1, valEd25519), false},
|
||||
7: {makeParams(1024*1024*1024, 0, -1, valEd25519), false},
|
||||
// test evidence age
|
||||
8: {makeParams(1, 0, 0, valEd25519), false},
|
||||
9: {makeParams(1, 0, -1, valEd25519), false},
|
||||
// test block params
|
||||
0: {makeParams(1, 0, 10, 1, valEd25519), true},
|
||||
1: {makeParams(0, 0, 10, 1, valEd25519), false},
|
||||
2: {makeParams(47*1024*1024, 0, 10, 1, valEd25519), true},
|
||||
3: {makeParams(10, 0, 10, 1, valEd25519), true},
|
||||
4: {makeParams(100*1024*1024, 0, 10, 1, valEd25519), true},
|
||||
5: {makeParams(101*1024*1024, 0, 10, 1, valEd25519), false},
|
||||
6: {makeParams(1024*1024*1024, 0, 10, 1, valEd25519), false},
|
||||
7: {makeParams(1024*1024*1024, 0, 10, -1, valEd25519), false},
|
||||
8: {makeParams(1, 0, -10, 1, valEd25519), false},
|
||||
// test evidence params
|
||||
9: {makeParams(1, 0, 10, 0, valEd25519), false},
|
||||
10: {makeParams(1, 0, 10, -1, valEd25519), false},
|
||||
// test no pubkey type provided
|
||||
10: {makeParams(1, 0, 1, []string{}), false},
|
||||
11: {makeParams(1, 0, 10, 1, []string{}), false},
|
||||
// test invalid pubkey type provided
|
||||
11: {makeParams(1, 0, 1, []string{"potatoes make good pubkeys"}), false},
|
||||
12: {makeParams(1, 0, 10, 1, []string{"potatoes make good pubkeys"}), false},
|
||||
}
|
||||
for i, tc := range testCases {
|
||||
if tc.valid {
|
||||
@ -45,11 +46,17 @@ func TestConsensusParamsValidation(t *testing.T) {
|
||||
}
|
||||
}
|
||||
|
||||
func makeParams(blockBytes, blockGas, evidenceAge int64, pubkeyTypes []string) ConsensusParams {
|
||||
func makeParams(
|
||||
blockBytes, blockGas int64,
|
||||
blockTimeIotaMs int64,
|
||||
evidenceAge int64,
|
||||
pubkeyTypes []string,
|
||||
) ConsensusParams {
|
||||
return ConsensusParams{
|
||||
BlockSize: BlockSizeParams{
|
||||
MaxBytes: blockBytes,
|
||||
MaxGas: blockGas,
|
||||
Block: BlockParams{
|
||||
MaxBytes: blockBytes,
|
||||
MaxGas: blockGas,
|
||||
TimeIotaMs: blockTimeIotaMs,
|
||||
},
|
||||
Evidence: EvidenceParams{
|
||||
MaxAge: evidenceAge,
|
||||
@ -62,14 +69,14 @@ func makeParams(blockBytes, blockGas, evidenceAge int64, pubkeyTypes []string) C
|
||||
|
||||
func TestConsensusParamsHash(t *testing.T) {
|
||||
params := []ConsensusParams{
|
||||
makeParams(4, 2, 3, valEd25519),
|
||||
makeParams(1, 4, 3, valEd25519),
|
||||
makeParams(1, 2, 4, valEd25519),
|
||||
makeParams(2, 5, 7, valEd25519),
|
||||
makeParams(1, 7, 6, valEd25519),
|
||||
makeParams(9, 5, 4, valEd25519),
|
||||
makeParams(7, 8, 9, valEd25519),
|
||||
makeParams(4, 6, 5, valEd25519),
|
||||
makeParams(4, 2, 10, 3, valEd25519),
|
||||
makeParams(1, 4, 10, 3, valEd25519),
|
||||
makeParams(1, 2, 10, 4, valEd25519),
|
||||
makeParams(2, 5, 10, 7, valEd25519),
|
||||
makeParams(1, 7, 10, 6, valEd25519),
|
||||
makeParams(9, 5, 10, 4, valEd25519),
|
||||
makeParams(7, 8, 10, 9, valEd25519),
|
||||
makeParams(4, 6, 10, 5, valEd25519),
|
||||
}
|
||||
|
||||
hashes := make([][]byte, len(params))
|
||||
@ -95,26 +102,27 @@ func TestConsensusParamsUpdate(t *testing.T) {
|
||||
}{
|
||||
// empty updates
|
||||
{
|
||||
makeParams(1, 2, 3, valEd25519),
|
||||
makeParams(1, 2, 10, 3, valEd25519),
|
||||
&abci.ConsensusParams{},
|
||||
makeParams(1, 2, 3, valEd25519),
|
||||
makeParams(1, 2, 10, 3, valEd25519),
|
||||
},
|
||||
// fine updates
|
||||
{
|
||||
makeParams(1, 2, 3, valEd25519),
|
||||
makeParams(1, 2, 10, 3, valEd25519),
|
||||
&abci.ConsensusParams{
|
||||
BlockSize: &abci.BlockSizeParams{
|
||||
MaxBytes: 100,
|
||||
MaxGas: 200,
|
||||
Block: &abci.BlockParams{
|
||||
MaxBytes: 100,
|
||||
MaxGas: 200,
|
||||
TimeIotaMs: 300,
|
||||
},
|
||||
Evidence: &abci.EvidenceParams{
|
||||
MaxAge: 300,
|
||||
MaxAge: 400,
|
||||
},
|
||||
Validator: &abci.ValidatorParams{
|
||||
PubKeyTypes: valSecp256k1,
|
||||
},
|
||||
},
|
||||
makeParams(100, 200, 300, valSecp256k1),
|
||||
makeParams(100, 200, 300, 400, valSecp256k1),
|
||||
},
|
||||
}
|
||||
for _, tc := range testCases {
|
||||
|
Reference in New Issue
Block a user