Skip to content

Commit

Permalink
fix over-reading while de-serializing
Browse files Browse the repository at this point in the history
  • Loading branch information
thanhpk committed Sep 7, 2022
1 parent 8e934f5 commit 473d6b8
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 2 deletions.
5 changes: 3 additions & 2 deletions bitset.go
Original file line number Diff line number Diff line change
Expand Up @@ -945,10 +945,11 @@ func (b *BitSet) ReadFrom(stream io.Reader) (int64, error) {
// binary.Read for large set
reader := bufio.NewReader(stream)
var item = make([]byte, binary.Size(uint64(0))) // one uint64
for i := uint64(0); i < length; i++ {
nWords := uint64(wordsNeeded(uint(length)))
for i := uint64(0); i < nWords; i++ {
if _, err := reader.Read(item); err != nil {
if err == io.EOF {
break // done
return 0, io.ErrUnexpectedEOF
}
return 0, err
}
Expand Down
27 changes: 27 additions & 0 deletions bitset_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1270,6 +1270,33 @@ func TestMarshalUnmarshalJSON(t *testing.T) {
}
}

func TestMarshalUnmarshalJSONWithTrailingData(t *testing.T) {
a := New(1010).Set(10).Set(1001)
data, err := json.Marshal(a)
if err != nil {
t.Errorf(err.Error())
return
}

// appending some noise
data = data[:len(data) - 3] // remove "
data = append(data, []byte(`AAAAAAAAAA"`)...)

b := new(BitSet)
err = json.Unmarshal(data, b)
if err != nil {
t.Errorf(err.Error())
return
}

// Bitsets must be equal after marshalling and unmarshalling
// Do not over-reading when unmarshalling
if !a.Equal(b) {
t.Error("Bitsets are not equal:\n\t", a.DumpAsBits(), "\n\t", b.DumpAsBits())
return
}
}

func TestMarshalUnmarshalJSONByStdEncoding(t *testing.T) {
Base64StdEncoding()
a := New(1010).Set(10).Set(1001)
Expand Down

0 comments on commit 473d6b8

Please sign in to comment.