forked from TrueCloudLab/frostfs-sdk-go
[#131] client: Fix false io.ErrUnexpectedEOF
return in readers
Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
This commit is contained in:
parent
69ffface78
commit
32458baeb7
1 changed files with 8 additions and 6 deletions
|
@ -240,6 +240,9 @@ func (x *ObjectReader) Close() (*ResObjectGet, error) {
|
||||||
// Read implements io.Reader of the object payload.
|
// Read implements io.Reader of the object payload.
|
||||||
func (x *ObjectReader) Read(p []byte) (int, error) {
|
func (x *ObjectReader) Read(p []byte) (int, error) {
|
||||||
n, ok := x.readChunk(p)
|
n, ok := x.readChunk(p)
|
||||||
|
|
||||||
|
x.remainingPayloadLen -= n
|
||||||
|
|
||||||
if !ok {
|
if !ok {
|
||||||
res, err := x.close(false)
|
res, err := x.close(false)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -249,12 +252,10 @@ func (x *ObjectReader) Read(p []byte) (int, error) {
|
||||||
return n, apistatus.ErrFromStatus(res.Status())
|
return n, apistatus.ErrFromStatus(res.Status())
|
||||||
}
|
}
|
||||||
|
|
||||||
if n > x.remainingPayloadLen {
|
if x.remainingPayloadLen < 0 {
|
||||||
return n, errors.New("payload size overflow")
|
return n, errors.New("payload size overflow")
|
||||||
}
|
}
|
||||||
|
|
||||||
x.remainingPayloadLen -= n
|
|
||||||
|
|
||||||
return n, nil
|
return n, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -615,6 +616,9 @@ func (x *ObjectRangeReader) Close() (*ResObjectRange, error) {
|
||||||
// Read implements io.Reader of the object payload.
|
// Read implements io.Reader of the object payload.
|
||||||
func (x *ObjectRangeReader) Read(p []byte) (int, error) {
|
func (x *ObjectRangeReader) Read(p []byte) (int, error) {
|
||||||
n, ok := x.readChunk(p)
|
n, ok := x.readChunk(p)
|
||||||
|
|
||||||
|
x.remainingPayloadLen -= n
|
||||||
|
|
||||||
if !ok {
|
if !ok {
|
||||||
res, err := x.close(false)
|
res, err := x.close(false)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -624,12 +628,10 @@ func (x *ObjectRangeReader) Read(p []byte) (int, error) {
|
||||||
return n, apistatus.ErrFromStatus(res.Status())
|
return n, apistatus.ErrFromStatus(res.Status())
|
||||||
}
|
}
|
||||||
|
|
||||||
if n > x.remainingPayloadLen {
|
if x.remainingPayloadLen < 0 {
|
||||||
return n, errors.New("payload range size overflow")
|
return n, errors.New("payload range size overflow")
|
||||||
}
|
}
|
||||||
|
|
||||||
x.remainingPayloadLen -= n
|
|
||||||
|
|
||||||
return n, nil
|
return n, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue