package types
|
|
|
|
import (
|
|
"bytes"
|
|
"sort"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
abci "github.com/tendermint/tendermint/abci/types"
|
|
)
|
|
|
|
func newConsensusParams(blockSize, partSize int) ConsensusParams {
|
|
return ConsensusParams{
|
|
BlockSize: BlockSize{MaxBytes: blockSize},
|
|
BlockGossip: BlockGossip{BlockPartSizeBytes: partSize},
|
|
}
|
|
}
|
|
|
|
func TestConsensusParamsValidation(t *testing.T) {
|
|
testCases := []struct {
|
|
params ConsensusParams
|
|
valid bool
|
|
}{
|
|
{newConsensusParams(1, 1), true},
|
|
{newConsensusParams(1, 0), false},
|
|
{newConsensusParams(0, 1), false},
|
|
{newConsensusParams(0, 0), false},
|
|
{newConsensusParams(0, 10), false},
|
|
{newConsensusParams(10, -1), false},
|
|
{newConsensusParams(47*1024*1024, 400), true},
|
|
{newConsensusParams(10, 400), true},
|
|
{newConsensusParams(100*1024*1024, 400), true},
|
|
{newConsensusParams(101*1024*1024, 400), false},
|
|
{newConsensusParams(1024*1024*1024, 400), false},
|
|
}
|
|
for _, testCase := range testCases {
|
|
if testCase.valid {
|
|
assert.NoError(t, testCase.params.Validate(), "expected no error for valid params")
|
|
} else {
|
|
assert.Error(t, testCase.params.Validate(), "expected error for non valid params")
|
|
}
|
|
}
|
|
}
|
|
|
|
func makeParams(blockBytes, blockTx, blockGas, txBytes,
|
|
txGas, partSize int) ConsensusParams {
|
|
|
|
return ConsensusParams{
|
|
BlockSize: BlockSize{
|
|
MaxBytes: blockBytes,
|
|
MaxTxs: blockTx,
|
|
MaxGas: int64(blockGas),
|
|
},
|
|
TxSize: TxSize{
|
|
MaxBytes: txBytes,
|
|
MaxGas: int64(txGas),
|
|
},
|
|
BlockGossip: BlockGossip{
|
|
BlockPartSizeBytes: partSize,
|
|
},
|
|
}
|
|
}
|
|
|
|
func TestConsensusParamsHash(t *testing.T) {
|
|
params := []ConsensusParams{
|
|
makeParams(1, 2, 3, 4, 5, 6),
|
|
makeParams(7, 2, 3, 4, 5, 6),
|
|
makeParams(1, 7, 3, 4, 5, 6),
|
|
makeParams(1, 2, 7, 4, 5, 6),
|
|
makeParams(1, 2, 3, 7, 5, 6),
|
|
makeParams(1, 2, 3, 4, 7, 6),
|
|
makeParams(1, 2, 3, 4, 5, 7),
|
|
makeParams(6, 5, 4, 3, 2, 1),
|
|
}
|
|
|
|
hashes := make([][]byte, len(params))
|
|
for i := range params {
|
|
hashes[i] = params[i].Hash()
|
|
}
|
|
|
|
// make sure there are no duplicates...
|
|
// sort, then check in order for matches
|
|
sort.Slice(hashes, func(i, j int) bool {
|
|
return bytes.Compare(hashes[i], hashes[j]) < 0
|
|
})
|
|
for i := 0; i < len(hashes)-1; i++ {
|
|
assert.NotEqual(t, hashes[i], hashes[i+1])
|
|
}
|
|
}
|
|
|
|
func TestConsensusParamsUpdate(t *testing.T) {
|
|
testCases := []struct {
|
|
params ConsensusParams
|
|
updates *abci.ConsensusParams
|
|
updatedParams ConsensusParams
|
|
}{
|
|
// empty updates
|
|
{
|
|
makeParams(1, 2, 3, 4, 5, 6),
|
|
&abci.ConsensusParams{},
|
|
makeParams(1, 2, 3, 4, 5, 6),
|
|
},
|
|
// negative BlockPartSizeBytes
|
|
{
|
|
makeParams(1, 2, 3, 4, 5, 6),
|
|
&abci.ConsensusParams{
|
|
BlockSize: &abci.BlockSize{
|
|
MaxBytes: -100,
|
|
MaxTxs: -200,
|
|
MaxGas: -300,
|
|
},
|
|
TxSize: &abci.TxSize{
|
|
MaxBytes: -400,
|
|
MaxGas: -500,
|
|
},
|
|
BlockGossip: &abci.BlockGossip{
|
|
BlockPartSizeBytes: -600,
|
|
},
|
|
},
|
|
makeParams(1, 2, 3, 4, 5, 6),
|
|
},
|
|
// fine updates
|
|
{
|
|
makeParams(1, 2, 3, 4, 5, 6),
|
|
&abci.ConsensusParams{
|
|
BlockSize: &abci.BlockSize{
|
|
MaxBytes: 100,
|
|
MaxTxs: 200,
|
|
MaxGas: 300,
|
|
},
|
|
TxSize: &abci.TxSize{
|
|
MaxBytes: 400,
|
|
MaxGas: 500,
|
|
},
|
|
BlockGossip: &abci.BlockGossip{
|
|
BlockPartSizeBytes: 600,
|
|
},
|
|
},
|
|
makeParams(100, 200, 300, 400, 500, 600),
|
|
},
|
|
}
|
|
for _, tc := range testCases {
|
|
assert.Equal(t, tc.updatedParams, tc.params.Update(tc.updates))
|
|
}
|
|
}
|