aboutsummaryrefslogtreecommitdiff
path: root/src/math/big/floatmarsh_test.go
diff options
context:
space:
mode:
authorOneOfOne <oneofone@gmail.com>2016-04-10 03:50:11 +0200
committerRobert Griesemer <gri@golang.org>2016-04-20 17:51:01 +0000
commitd8c9dd604801958c649a32511deef373adeecfe0 (patch)
tree493c61ade210c32a50b5c0cc8346314232127295 /src/math/big/floatmarsh_test.go
parent7acb642e4f0b77763a13c99c756aa846b01a428c (diff)
downloadgo-d8c9dd604801958c649a32511deef373adeecfe0.tar.gz
go-d8c9dd604801958c649a32511deef373adeecfe0.zip
math/big: implement GobDecode/Encode for big.Float
Added GobEncode/Decode and a test for them. Fixes #14593 Change-Id: Ic8d3efd24d0313a1a66f01da293c4c1fd39764a8 Reviewed-on: https://go-review.googlesource.com/21755 Reviewed-by: Robert Griesemer <gri@golang.org>
Diffstat (limited to 'src/math/big/floatmarsh_test.go')
-rw-r--r--src/math/big/floatmarsh_test.go63
1 files changed, 63 insertions, 0 deletions
diff --git a/src/math/big/floatmarsh_test.go b/src/math/big/floatmarsh_test.go
index d7ef2fca68..f726c35e99 100644
--- a/src/math/big/floatmarsh_test.go
+++ b/src/math/big/floatmarsh_test.go
@@ -5,7 +5,10 @@
package big
import (
+ "bytes"
+ "encoding/gob"
"encoding/json"
+ "io"
"testing"
)
@@ -23,6 +26,66 @@ var floatVals = []string{
"Inf",
}
+func TestFloatGobEncoding(t *testing.T) {
+ var medium bytes.Buffer
+ for _, test := range floatVals {
+ for _, sign := range []string{"", "+", "-"} {
+ for _, prec := range []uint{0, 1, 2, 10, 53, 64, 100, 1000} {
+ medium.Reset() // empty buffer for each test case (in case of failures)
+ enc := gob.NewEncoder(&medium)
+ dec := gob.NewDecoder(&medium)
+ x := sign + test
+ var tx Float
+ _, _, err := tx.SetPrec(prec).Parse(x, 0)
+ if err != nil {
+ t.Errorf("parsing of %s (prec = %d) failed (invalid test case): %v", x, prec, err)
+ continue
+ }
+ tx.SetMode(ToPositiveInf)
+ if err := enc.Encode(&tx); err != nil {
+ t.Errorf("encoding of %v (prec = %d) failed: %v", &tx, prec, err)
+ continue
+ }
+
+ var rx Float
+ if err := dec.Decode(&rx); err != nil {
+ t.Errorf("decoding of %v (prec = %d) failed: %v", &tx, prec, err)
+ continue
+ }
+
+ if rx.Cmp(&tx) != 0 {
+ t.Errorf("transmission of %s failed: got %s want %s", x, rx.String(), tx.String())
+ continue
+ }
+
+ if rx.Mode() != ToPositiveInf {
+ t.Errorf("transmission of %s's mode failed: got %s want %s", x, rx.Mode(), ToPositiveInf)
+ }
+ }
+ }
+ }
+}
+func TestFloatCorruptGob(t *testing.T) {
+ var buf bytes.Buffer
+ tx := NewFloat(4 / 3).SetPrec(1000).SetMode(ToPositiveInf)
+ if err := gob.NewEncoder(&buf).Encode(tx); err != nil {
+ t.Fatal(err)
+ }
+ b := buf.Bytes()
+ var rx Float
+ if err := gob.NewDecoder(bytes.NewReader(b)).Decode(&rx); err != nil {
+ t.Fatal(err)
+ }
+ var rx2 Float
+ if err := gob.NewDecoder(bytes.NewReader(b[:10])).Decode(&rx2); err != io.ErrUnexpectedEOF {
+ t.Errorf("expected io.ErrUnexpectedEOF, got %v", err)
+ }
+ b[1] = 0
+ if err := gob.NewDecoder(bytes.NewReader(b)).Decode(&rx); err == nil {
+ t.Fatal("expected a version error, got nil")
+ }
+
+}
func TestFloatJSONEncoding(t *testing.T) {
for _, test := range floatVals {
for _, sign := range []string{"", "+", "-"} {