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.

90 lines
2.1 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
  1. package types
  2. import (
  3. "bytes"
  4. "io/ioutil"
  5. "testing"
  6. . "github.com/tendermint/go-common"
  7. )
  8. const (
  9. testPartSize = 65536 // 64KB ... 4096 // 4KB
  10. )
  11. func TestBasicPartSet(t *testing.T) {
  12. // Construct random data of size partSize * 100
  13. data := RandBytes(testPartSize * 100)
  14. partSet := NewPartSetFromData(data, testPartSize)
  15. if len(partSet.Hash()) == 0 {
  16. t.Error("Expected to get hash")
  17. }
  18. if partSet.Total() != 100 {
  19. t.Errorf("Expected to get 100 parts, but got %v", partSet.Total())
  20. }
  21. if !partSet.IsComplete() {
  22. t.Errorf("PartSet should be complete")
  23. }
  24. // Test adding parts to a new partSet.
  25. partSet2 := NewPartSetFromHeader(partSet.Header())
  26. for i := 0; i < partSet.Total(); i++ {
  27. part := partSet.GetPart(i)
  28. //t.Logf("\n%v", part)
  29. added, err := partSet2.AddPart(part, true)
  30. if !added || err != nil {
  31. t.Errorf("Failed to add part %v, error: %v", i, err)
  32. }
  33. }
  34. if !bytes.Equal(partSet.Hash(), partSet2.Hash()) {
  35. t.Error("Expected to get same hash")
  36. }
  37. if partSet2.Total() != 100 {
  38. t.Errorf("Expected to get 100 parts, but got %v", partSet2.Total())
  39. }
  40. if !partSet2.IsComplete() {
  41. t.Errorf("Reconstructed PartSet should be complete")
  42. }
  43. // Reconstruct data, assert that they are equal.
  44. data2Reader := partSet2.GetReader()
  45. data2, err := ioutil.ReadAll(data2Reader)
  46. if err != nil {
  47. t.Errorf("Error reading data2Reader: %v", err)
  48. }
  49. if !bytes.Equal(data, data2) {
  50. t.Errorf("Got wrong data.")
  51. }
  52. }
  53. func TestWrongProof(t *testing.T) {
  54. // Construct random data of size partSize * 100
  55. data := RandBytes(testPartSize * 100)
  56. partSet := NewPartSetFromData(data, testPartSize)
  57. // Test adding a part with wrong data.
  58. partSet2 := NewPartSetFromHeader(partSet.Header())
  59. // Test adding a part with wrong trail.
  60. part := partSet.GetPart(0)
  61. part.Proof.Aunts[0][0] += byte(0x01)
  62. added, err := partSet2.AddPart(part, true)
  63. if added || err == nil {
  64. t.Errorf("Expected to fail adding a part with bad trail.")
  65. }
  66. // Test adding a part with wrong bytes.
  67. part = partSet.GetPart(1)
  68. part.Bytes[0] += byte(0x01)
  69. added, err = partSet2.AddPart(part, true)
  70. if added || err == nil {
  71. t.Errorf("Expected to fail adding a part with bad bytes.")
  72. }
  73. }