floatmarsh_test.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. // Copyright 2015 The Go Authors. All rights reserved.
  2. // Use of this source code is governed by a BSD-style
  3. // license that can be found in the LICENSE file.
  4. package big
  5. import (
  6. "bytes"
  7. "encoding/gob"
  8. "encoding/json"
  9. "io"
  10. "testing"
  11. )
  12. var floatVals = []string{
  13. "0",
  14. "1",
  15. "0.1",
  16. "2.71828",
  17. "1234567890",
  18. "3.14e1234",
  19. "3.14e-1234",
  20. "0.738957395793475734757349579759957975985497e100",
  21. "0.73895739579347546656564656573475734957975995797598589749859834759476745986795497e100",
  22. "inf",
  23. "Inf",
  24. }
  25. func TestFloatGobEncoding(t *testing.T) {
  26. var medium bytes.Buffer
  27. enc := gob.NewEncoder(&medium)
  28. dec := gob.NewDecoder(&medium)
  29. for _, test := range floatVals {
  30. for _, sign := range []string{"", "+", "-"} {
  31. for _, prec := range []uint{0, 1, 2, 10, 53, 64, 100, 1000} {
  32. for _, mode := range []RoundingMode{ToNearestEven, ToNearestAway, ToZero, AwayFromZero, ToNegativeInf, ToPositiveInf} {
  33. medium.Reset() // empty buffer for each test case (in case of failures)
  34. x := sign + test
  35. var tx Float
  36. _, _, err := tx.SetPrec(prec).SetMode(mode).Parse(x, 0)
  37. if err != nil {
  38. t.Errorf("parsing of %s (%dbits, %v) failed (invalid test case): %v", x, prec, mode, err)
  39. continue
  40. }
  41. // If tx was set to prec == 0, tx.Parse(x, 0) assumes precision 64. Correct it.
  42. if prec == 0 {
  43. tx.SetPrec(0)
  44. }
  45. if err := enc.Encode(&tx); err != nil {
  46. t.Errorf("encoding of %v (%dbits, %v) failed: %v", &tx, prec, mode, err)
  47. continue
  48. }
  49. var rx Float
  50. if err := dec.Decode(&rx); err != nil {
  51. t.Errorf("decoding of %v (%dbits, %v) failed: %v", &tx, prec, mode, err)
  52. continue
  53. }
  54. if rx.Cmp(&tx) != 0 {
  55. t.Errorf("transmission of %s failed: got %s want %s", x, rx.String(), tx.String())
  56. continue
  57. }
  58. if rx.Prec() != prec {
  59. t.Errorf("transmission of %s's prec failed: got %d want %d", x, rx.Prec(), prec)
  60. }
  61. if rx.Mode() != mode {
  62. t.Errorf("transmission of %s's mode failed: got %s want %s", x, rx.Mode(), mode)
  63. }
  64. if rx.Acc() != tx.Acc() {
  65. t.Errorf("transmission of %s's accuracy failed: got %s want %s", x, rx.Acc(), tx.Acc())
  66. }
  67. }
  68. }
  69. }
  70. }
  71. }
  72. func TestFloatCorruptGob(t *testing.T) {
  73. var buf bytes.Buffer
  74. tx := NewFloat(4 / 3).SetPrec(1000).SetMode(ToPositiveInf)
  75. if err := gob.NewEncoder(&buf).Encode(tx); err != nil {
  76. t.Fatal(err)
  77. }
  78. b := buf.Bytes()
  79. var rx Float
  80. if err := gob.NewDecoder(bytes.NewReader(b)).Decode(&rx); err != nil {
  81. t.Fatal(err)
  82. }
  83. if err := gob.NewDecoder(bytes.NewReader(b[:10])).Decode(&rx); err != io.ErrUnexpectedEOF {
  84. t.Errorf("got %v want EOF", err)
  85. }
  86. b[1] = 0
  87. if err := gob.NewDecoder(bytes.NewReader(b)).Decode(&rx); err == nil {
  88. t.Fatal("got nil want version error")
  89. }
  90. }
  91. func TestFloatJSONEncoding(t *testing.T) {
  92. for _, test := range floatVals {
  93. for _, sign := range []string{"", "+", "-"} {
  94. for _, prec := range []uint{0, 1, 2, 10, 53, 64, 100, 1000} {
  95. if prec > 53 && testing.Short() {
  96. continue
  97. }
  98. x := sign + test
  99. var tx Float
  100. _, _, err := tx.SetPrec(prec).Parse(x, 0)
  101. if err != nil {
  102. t.Errorf("parsing of %s (prec = %d) failed (invalid test case): %v", x, prec, err)
  103. continue
  104. }
  105. b, err := json.Marshal(&tx)
  106. if err != nil {
  107. t.Errorf("marshaling of %v (prec = %d) failed: %v", &tx, prec, err)
  108. continue
  109. }
  110. var rx Float
  111. rx.SetPrec(prec)
  112. if err := json.Unmarshal(b, &rx); err != nil {
  113. t.Errorf("unmarshaling of %v (prec = %d) failed: %v", &tx, prec, err)
  114. continue
  115. }
  116. if rx.Cmp(&tx) != 0 {
  117. t.Errorf("JSON encoding of %v (prec = %d) failed: got %v want %v", &tx, prec, &rx, &tx)
  118. }
  119. }
  120. }
  121. }
  122. }