diff options
author | Roland Shoemaker <roland@golang.org> | 2022-07-15 10:43:44 -0700 |
---|---|---|
committer | Cherry Mui <cherryyz@google.com> | 2022-07-29 14:06:18 +0000 |
commit | 703c8ab7e5ba75c95553d4e249309297abad7102 (patch) | |
tree | b01fba8f8fed093e7ebe56f6836c13b4a2f1b651 /src/math/big/ratmarsh_test.go | |
parent | d9242f7a8c29aa17201cd66d29cdd20916c2de60 (diff) | |
download | go-703c8ab7e5ba75c95553d4e249309297abad7102.tar.gz go-703c8ab7e5ba75c95553d4e249309297abad7102.zip |
[release-branch.go1.17] math/big: check buffer lengths in GobDecode
In Float.GobDecode and Rat.GobDecode, check buffer sizes before
indexing slices.
Updates #53871
Fixes #54094
Change-Id: I1b652c32c2bc7a0e8aa7620f7be9b2740c568b0a
Reviewed-on: https://go-review.googlesource.com/c/go/+/417774
TryBot-Result: Gopher Robot <gobot@golang.org>
Reviewed-by: Tatiana Bradley <tatiana@golang.org>
Run-TryBot: Roland Shoemaker <roland@golang.org>
(cherry picked from commit 055113ef364337607e3e72ed7d48df67fde6fc66)
Reviewed-on: https://go-review.googlesource.com/c/go/+/419814
Reviewed-by: Julie Qiu <julieqiu@google.com>
Diffstat (limited to 'src/math/big/ratmarsh_test.go')
-rw-r--r-- | src/math/big/ratmarsh_test.go | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/src/math/big/ratmarsh_test.go b/src/math/big/ratmarsh_test.go index 351d109f8d..55a9878bb8 100644 --- a/src/math/big/ratmarsh_test.go +++ b/src/math/big/ratmarsh_test.go @@ -123,3 +123,15 @@ func TestRatXMLEncoding(t *testing.T) { } } } + +func TestRatGobDecodeShortBuffer(t *testing.T) { + for _, tc := range [][]byte{ + []byte{0x2}, + []byte{0x2, 0x0, 0x0, 0x0, 0xff}, + } { + err := NewRat(1, 2).GobDecode(tc) + if err == nil { + t.Error("expected GobDecode to return error for malformed input") + } + } +} |