You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

194 lines
5.0 KiB

10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
  1. package types
  2. import (
  3. "io"
  4. "testing"
  5. "github.com/stretchr/testify/assert"
  6. "github.com/stretchr/testify/require"
  7. "github.com/tendermint/tendermint/crypto/merkle"
  8. tmrand "github.com/tendermint/tendermint/libs/rand"
  9. )
  10. const (
  11. testPartSize = 65536 // 64KB ... 4096 // 4KB
  12. )
  13. func TestBasicPartSet(t *testing.T) {
  14. // Construct random data of size partSize * 100
  15. nParts := 100
  16. data := tmrand.Bytes(testPartSize * nParts)
  17. partSet := NewPartSetFromData(data, testPartSize)
  18. assert.NotEmpty(t, partSet.Hash())
  19. assert.EqualValues(t, nParts, partSet.Total())
  20. assert.Equal(t, nParts, partSet.BitArray().Size())
  21. assert.True(t, partSet.HashesTo(partSet.Hash()))
  22. assert.True(t, partSet.IsComplete())
  23. assert.EqualValues(t, nParts, partSet.Count())
  24. assert.EqualValues(t, testPartSize*nParts, partSet.ByteSize())
  25. // Test adding parts to a new partSet.
  26. partSet2 := NewPartSetFromHeader(partSet.Header())
  27. assert.True(t, partSet2.HasHeader(partSet.Header()))
  28. for i := 0; i < int(partSet.Total()); i++ {
  29. part := partSet.GetPart(i)
  30. // t.Logf("\n%v", part)
  31. added, err := partSet2.AddPart(part)
  32. if !added || err != nil {
  33. t.Errorf("failed to add part %v, error: %v", i, err)
  34. }
  35. }
  36. // adding part with invalid index
  37. added, err := partSet2.AddPart(&Part{Index: 10000})
  38. assert.False(t, added)
  39. assert.Error(t, err)
  40. // adding existing part
  41. added, err = partSet2.AddPart(partSet2.GetPart(0))
  42. assert.False(t, added)
  43. assert.NoError(t, err)
  44. assert.Equal(t, partSet.Hash(), partSet2.Hash())
  45. assert.EqualValues(t, nParts, partSet2.Total())
  46. assert.EqualValues(t, nParts*testPartSize, partSet.ByteSize())
  47. assert.True(t, partSet2.IsComplete())
  48. // Reconstruct data, assert that they are equal.
  49. data2Reader := partSet2.GetReader()
  50. data2, err := io.ReadAll(data2Reader)
  51. require.NoError(t, err)
  52. assert.Equal(t, data, data2)
  53. }
  54. func TestWrongProof(t *testing.T) {
  55. // Construct random data of size partSize * 100
  56. data := tmrand.Bytes(testPartSize * 100)
  57. partSet := NewPartSetFromData(data, testPartSize)
  58. // Test adding a part with wrong data.
  59. partSet2 := NewPartSetFromHeader(partSet.Header())
  60. // Test adding a part with wrong trail.
  61. part := partSet.GetPart(0)
  62. part.Proof.Aunts[0][0] += byte(0x01)
  63. added, err := partSet2.AddPart(part)
  64. if added || err == nil {
  65. t.Errorf("expected to fail adding a part with bad trail.")
  66. }
  67. // Test adding a part with wrong bytes.
  68. part = partSet.GetPart(1)
  69. part.Bytes[0] += byte(0x01)
  70. added, err = partSet2.AddPart(part)
  71. if added || err == nil {
  72. t.Errorf("expected to fail adding a part with bad bytes.")
  73. }
  74. }
  75. func TestPartSetHeaderValidateBasic(t *testing.T) {
  76. testCases := []struct {
  77. testName string
  78. malleatePartSetHeader func(*PartSetHeader)
  79. expectErr bool
  80. }{
  81. {"Good PartSet", func(psHeader *PartSetHeader) {}, false},
  82. {"Invalid Hash", func(psHeader *PartSetHeader) { psHeader.Hash = make([]byte, 1) }, true},
  83. }
  84. for _, tc := range testCases {
  85. tc := tc
  86. t.Run(tc.testName, func(t *testing.T) {
  87. data := tmrand.Bytes(testPartSize * 100)
  88. ps := NewPartSetFromData(data, testPartSize)
  89. psHeader := ps.Header()
  90. tc.malleatePartSetHeader(&psHeader)
  91. assert.Equal(t, tc.expectErr, psHeader.ValidateBasic() != nil, "Validate Basic had an unexpected result")
  92. })
  93. }
  94. }
  95. func TestPartValidateBasic(t *testing.T) {
  96. testCases := []struct {
  97. testName string
  98. malleatePart func(*Part)
  99. expectErr bool
  100. }{
  101. {"Good Part", func(pt *Part) {}, false},
  102. {"Too big part", func(pt *Part) { pt.Bytes = make([]byte, BlockPartSizeBytes+1) }, true},
  103. {"Too big proof", func(pt *Part) {
  104. pt.Proof = merkle.Proof{
  105. Total: 1,
  106. Index: 1,
  107. LeafHash: make([]byte, 1024*1024),
  108. }
  109. }, true},
  110. }
  111. for _, tc := range testCases {
  112. tc := tc
  113. t.Run(tc.testName, func(t *testing.T) {
  114. data := tmrand.Bytes(testPartSize * 100)
  115. ps := NewPartSetFromData(data, testPartSize)
  116. part := ps.GetPart(0)
  117. tc.malleatePart(part)
  118. assert.Equal(t, tc.expectErr, part.ValidateBasic() != nil, "Validate Basic had an unexpected result")
  119. })
  120. }
  121. }
  122. func TestParSetHeaderProtoBuf(t *testing.T) {
  123. testCases := []struct {
  124. msg string
  125. ps1 *PartSetHeader
  126. expPass bool
  127. }{
  128. {"success empty", &PartSetHeader{}, true},
  129. {"success",
  130. &PartSetHeader{Total: 1, Hash: []byte("hash")}, true},
  131. }
  132. for _, tc := range testCases {
  133. protoBlockID := tc.ps1.ToProto()
  134. psh, err := PartSetHeaderFromProto(&protoBlockID)
  135. if tc.expPass {
  136. require.Equal(t, tc.ps1, psh, tc.msg)
  137. } else {
  138. require.Error(t, err, tc.msg)
  139. }
  140. }
  141. }
  142. func TestPartProtoBuf(t *testing.T) {
  143. proof := merkle.Proof{
  144. Total: 1,
  145. Index: 1,
  146. LeafHash: tmrand.Bytes(32),
  147. }
  148. testCases := []struct {
  149. msg string
  150. ps1 *Part
  151. expPass bool
  152. }{
  153. {"failure empty", &Part{}, false},
  154. {"failure nil", nil, false},
  155. {"success",
  156. &Part{Index: 1, Bytes: tmrand.Bytes(32), Proof: proof}, true},
  157. }
  158. for _, tc := range testCases {
  159. proto, err := tc.ps1.ToProto()
  160. if tc.expPass {
  161. require.NoError(t, err, tc.msg)
  162. }
  163. p, err := PartFromProto(proto)
  164. if tc.expPass {
  165. require.NoError(t, err)
  166. require.Equal(t, tc.ps1, p, tc.msg)
  167. }
  168. }
  169. }