fix(maxreader): treat non-positive limits as unlimited

This commit is contained in:
wjqserver 2026-04-01 00:03:23 +08:00
parent 91c50536c4
commit e6ff0fa6b9
2 changed files with 10 additions and 23 deletions

View file

@ -27,16 +27,6 @@ func (r *zeroNilThenEOFReader) Close() error {
return nil
}
type zeroNilForeverReader struct{}
func (r *zeroNilForeverReader) Read(_ []byte) (int, error) {
return 0, nil
}
func (r *zeroNilForeverReader) Close() error {
return nil
}
func TestFileTextUsesProvidedStatusCode(t *testing.T) {
t.Helper()
@ -107,21 +97,18 @@ func TestMaxBytesReaderAllowsZeroNilThenEOFAtExactLimit(t *testing.T) {
}
}
func TestMaxBytesReaderRejectsOverLimitWithoutProbeLoop(t *testing.T) {
func TestMaxBytesReaderTreatsZeroLimitAsUnlimited(t *testing.T) {
t.Helper()
reader := NewMaxBytesReader(&zeroNilForeverReader{}, 0)
reader := NewMaxBytesReader(io.NopCloser(strings.NewReader("abc")), 0)
defer reader.Close()
buf := make([]byte, 1)
n, err := reader.Read(buf)
if n != 0 || err != nil {
t.Fatalf("expected initial zero,nil read result, got n=%d err=%v", n, err)
data, err := io.ReadAll(reader)
if err != nil {
t.Fatalf("expected zero limit to leave body unlimited, got %v", err)
}
n, err = reader.Read(buf)
if n != 0 || !errors.Is(err, ErrBodyTooLarge) {
t.Fatalf("expected ErrBodyTooLarge after repeated zero,nil reads, got n=%d err=%v", n, err)
if string(data) != "abc" {
t.Fatalf("unexpected data: %q", string(data))
}
}

View file

@ -31,13 +31,13 @@ type maxBytesReader struct {
// 但在读取的字节数超过 n 后会返回 ErrBodyTooLarge 错误.
//
// 如果 r 为 nil, 会 panic.
// 如果 n 小于 0, 则读取不受限制, 直接返回原始的 r.
// 如果 n 小于等于 0, 则读取不受限制, 直接返回原始的 r.
func NewMaxBytesReader(r io.ReadCloser, n int64) io.ReadCloser {
if r == nil {
panic("NewMaxBytesReader called with a nil reader")
}
// 如果限制为数, 意味着不限制, 直接返回原始的 ReadCloser.
if n < 0 {
// 如果限制为非正数, 意味着不限制, 直接返回原始的 ReadCloser.
if n <= 0 {
return r
}
return &maxBytesReader{