|
|
- package types
-
- import (
- "io/ioutil"
- "testing"
-
- "github.com/stretchr/testify/assert"
- "github.com/stretchr/testify/require"
-
- cmn "github.com/tendermint/tendermint/libs/common"
- )
-
- const (
- testPartSize = 65536 // 64KB ... 4096 // 4KB
- )
-
- func TestBasicPartSet(t *testing.T) {
- // Construct random data of size partSize * 100
- data := cmn.RandBytes(testPartSize * 100)
- partSet := NewPartSetFromData(data, testPartSize)
-
- assert.NotEmpty(t, partSet.Hash())
- assert.Equal(t, 100, partSet.Total())
- assert.Equal(t, 100, partSet.BitArray().Size())
- assert.True(t, partSet.HashesTo(partSet.Hash()))
- assert.True(t, partSet.IsComplete())
- assert.Equal(t, 100, partSet.Count())
-
- // Test adding parts to a new partSet.
- partSet2 := NewPartSetFromHeader(partSet.Header())
-
- assert.True(t, partSet2.HasHeader(partSet.Header()))
- for i := 0; i < partSet.Total(); i++ {
- part := partSet.GetPart(i)
- //t.Logf("\n%v", part)
- added, err := partSet2.AddPart(part)
- if !added || err != nil {
- t.Errorf("Failed to add part %v, error: %v", i, err)
- }
- }
- // adding part with invalid index
- added, err := partSet2.AddPart(&Part{Index: 10000})
- assert.False(t, added)
- assert.Error(t, err)
- // adding existing part
- added, err = partSet2.AddPart(partSet2.GetPart(0))
- assert.False(t, added)
- assert.Nil(t, err)
-
- assert.Equal(t, partSet.Hash(), partSet2.Hash())
- assert.Equal(t, 100, partSet2.Total())
- assert.True(t, partSet2.IsComplete())
-
- // Reconstruct data, assert that they are equal.
- data2Reader := partSet2.GetReader()
- data2, err := ioutil.ReadAll(data2Reader)
- require.NoError(t, err)
-
- assert.Equal(t, data, data2)
- }
-
- func TestWrongProof(t *testing.T) {
- // Construct random data of size partSize * 100
- data := cmn.RandBytes(testPartSize * 100)
- partSet := NewPartSetFromData(data, testPartSize)
-
- // Test adding a part with wrong data.
- partSet2 := NewPartSetFromHeader(partSet.Header())
-
- // Test adding a part with wrong trail.
- part := partSet.GetPart(0)
- part.Proof.Aunts[0][0] += byte(0x01)
- added, err := partSet2.AddPart(part)
- if added || err == nil {
- t.Errorf("Expected to fail adding a part with bad trail.")
- }
-
- // Test adding a part with wrong bytes.
- part = partSet.GetPart(1)
- part.Bytes[0] += byte(0x01)
- added, err = partSet2.AddPart(part)
- if added || err == nil {
- t.Errorf("Expected to fail adding a part with bad bytes.")
- }
- }
-
- func TestPartSetHeaderValidateBasic(t *testing.T) {
- testCases := []struct {
- testName string
- malleatePartSetHeader func(*PartSetHeader)
- expectErr bool
- }{
- {"Good PartSet", func(psHeader *PartSetHeader) {}, false},
- {"Negative Total", func(psHeader *PartSetHeader) { psHeader.Total = -2 }, true},
- {"Invalid Hash", func(psHeader *PartSetHeader) { psHeader.Hash = make([]byte, 1) }, true},
- }
- for _, tc := range testCases {
- t.Run(tc.testName, func(t *testing.T) {
- data := cmn.RandBytes(testPartSize * 100)
- ps := NewPartSetFromData(data, testPartSize)
- psHeader := ps.Header()
- tc.malleatePartSetHeader(&psHeader)
- assert.Equal(t, tc.expectErr, psHeader.ValidateBasic() != nil, "Validate Basic had an unexpected result")
- })
- }
- }
-
- func TestPartValidateBasic(t *testing.T) {
- testCases := []struct {
- testName string
- malleatePart func(*Part)
- expectErr bool
- }{
- {"Good Part", func(pt *Part) {}, false},
- {"Negative index", func(pt *Part) { pt.Index = -1 }, true},
- {"Too big part", func(pt *Part) { pt.Bytes = make([]byte, BlockPartSizeBytes+1) }, true},
- }
-
- for _, tc := range testCases {
- t.Run(tc.testName, func(t *testing.T) {
- data := cmn.RandBytes(testPartSize * 100)
- ps := NewPartSetFromData(data, testPartSize)
- part := ps.GetPart(0)
- tc.malleatePart(part)
- assert.Equal(t, tc.expectErr, part.ValidateBasic() != nil, "Validate Basic had an unexpected result")
- })
- }
- }
|