|
|
- 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.")
- }
- }
|