mirror of
https://github.com/aler9/gortsplib
synced 2025-10-05 15:16:51 +08:00
base: rename content into body
This commit is contained in:
@@ -7,12 +7,12 @@ import (
|
|||||||
"strconv"
|
"strconv"
|
||||||
)
|
)
|
||||||
|
|
||||||
type payload []byte
|
type body []byte
|
||||||
|
|
||||||
func (c *payload) read(rb *bufio.Reader, header Header) error {
|
func (b *body) read(header Header, rb *bufio.Reader) error {
|
||||||
cls, ok := header["Content-Length"]
|
cls, ok := header["Content-Length"]
|
||||||
if !ok || len(cls) != 1 {
|
if !ok || len(cls) != 1 {
|
||||||
*c = nil
|
*b = nil
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -26,21 +26,21 @@ func (c *payload) read(rb *bufio.Reader, header Header) error {
|
|||||||
rtspMaxContentLength, cl)
|
rtspMaxContentLength, cl)
|
||||||
}
|
}
|
||||||
|
|
||||||
*c = make([]byte, cl)
|
*b = make([]byte, cl)
|
||||||
n, err := io.ReadFull(rb, *c)
|
n, err := io.ReadFull(rb, *b)
|
||||||
if err != nil && n != len(*c) {
|
if err != nil && n != len(*b) {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c payload) write(bw *bufio.Writer) error {
|
func (b body) write(bw *bufio.Writer) error {
|
||||||
if len(c) == 0 {
|
if len(b) == 0 {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err := bw.Write(c)
|
_, err := bw.Write(b)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
92
pkg/base/body_test.go
Normal file
92
pkg/base/body_test.go
Normal file
@@ -0,0 +1,92 @@
|
|||||||
|
package base
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bufio"
|
||||||
|
"bytes"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
)
|
||||||
|
|
||||||
|
var casesBody = []struct {
|
||||||
|
name string
|
||||||
|
h Header
|
||||||
|
byts []byte
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
"standard",
|
||||||
|
Header{
|
||||||
|
"Content-Length": HeaderValue{"4"},
|
||||||
|
},
|
||||||
|
[]byte{0x01, 0x02, 0x03, 0x04},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"nil",
|
||||||
|
Header{},
|
||||||
|
[]byte(nil),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestBodyRead(t *testing.T) {
|
||||||
|
for _, ca := range casesBody {
|
||||||
|
t.Run(ca.name, func(t *testing.T) {
|
||||||
|
var p body
|
||||||
|
err := p.read(ca.h, bufio.NewReader(bytes.NewReader(ca.byts)))
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, ca.byts, []byte(p))
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestBodyWrite(t *testing.T) {
|
||||||
|
for _, ca := range casesBody {
|
||||||
|
t.Run(ca.name, func(t *testing.T) {
|
||||||
|
var buf bytes.Buffer
|
||||||
|
bw := bufio.NewWriter(&buf)
|
||||||
|
err := body(ca.byts).write(bw)
|
||||||
|
require.NoError(t, err)
|
||||||
|
bw.Flush()
|
||||||
|
require.Equal(t, ca.byts, buf.Bytes())
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestBodyReadErrors(t *testing.T) {
|
||||||
|
for _, ca := range []struct {
|
||||||
|
name string
|
||||||
|
h Header
|
||||||
|
byts []byte
|
||||||
|
err string
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
"invalid body",
|
||||||
|
Header{
|
||||||
|
"Content-Length": HeaderValue{"17"},
|
||||||
|
},
|
||||||
|
[]byte("123"),
|
||||||
|
"unexpected EOF",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"invalid content-length",
|
||||||
|
Header{
|
||||||
|
"Content-Length": HeaderValue{"aaa"},
|
||||||
|
},
|
||||||
|
[]byte("123"),
|
||||||
|
"invalid Content-Length",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"too big content-length",
|
||||||
|
Header{
|
||||||
|
"Content-Length": HeaderValue{"1000000"},
|
||||||
|
},
|
||||||
|
[]byte("123"),
|
||||||
|
"Content-Length exceeds 131072 (it's 1000000)",
|
||||||
|
},
|
||||||
|
} {
|
||||||
|
t.Run(ca.name, func(t *testing.T) {
|
||||||
|
var p body
|
||||||
|
err := p.read(ca.h, bufio.NewReader(bytes.NewReader(ca.byts)))
|
||||||
|
require.Equal(t, ca.err, err.Error())
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
@@ -91,7 +91,7 @@ func (req *Request) Read(rb *bufio.Reader) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = (*payload)(&req.Body).read(rb, req.Header)
|
err = (*body)(&req.Body).read(req.Header, rb)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@@ -137,7 +137,7 @@ func (req Request) Write(bw *bufio.Writer) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = payload(req.Body).write(bw)
|
err = body(req.Body).write(bw)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@@ -222,16 +222,6 @@ func TestRequestReadErrors(t *testing.T) {
|
|||||||
[]byte("GET rtsp://testing123 RTSP/1.0\r\nContent-Length: 17\r\n\r\n123"),
|
[]byte("GET rtsp://testing123 RTSP/1.0\r\nContent-Length: 17\r\n\r\n123"),
|
||||||
"unexpected EOF",
|
"unexpected EOF",
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"invalid content-length",
|
|
||||||
[]byte("GET rtsp://testing123 RTSP/1.0\r\nContent-Length: aaa\r\n\r\n123"),
|
|
||||||
"invalid Content-Length",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"too big content-length",
|
|
||||||
[]byte("GET rtsp://testing123 RTSP/1.0\r\nContent-Length: 1000000\r\n\r\n123"),
|
|
||||||
"Content-Length exceeds 131072 (it's 1000000)",
|
|
||||||
},
|
|
||||||
} {
|
} {
|
||||||
t.Run(ca.name, func(t *testing.T) {
|
t.Run(ca.name, func(t *testing.T) {
|
||||||
var req Request
|
var req Request
|
||||||
|
@@ -177,7 +177,7 @@ func (res *Response) Read(rb *bufio.Reader) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = (*payload)(&res.Body).read(rb, res.Header)
|
err = (*body)(&res.Body).read(res.Header, rb)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@@ -228,7 +228,7 @@ func (res Response) Write(bw *bufio.Writer) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = payload(res.Body).write(bw)
|
err = body(res.Body).write(bw)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@@ -179,16 +179,6 @@ func TestResponseReadErrors(t *testing.T) {
|
|||||||
[]byte("RTSP/1.0 200 OK\r\nContent-Length: 17\r\n\r\n123"),
|
[]byte("RTSP/1.0 200 OK\r\nContent-Length: 17\r\n\r\n123"),
|
||||||
"unexpected EOF",
|
"unexpected EOF",
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"invalid content-length",
|
|
||||||
[]byte("RTSP/1.0 200 OK\r\nContent-Length: aaa\r\n\r\n123"),
|
|
||||||
"invalid Content-Length",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"too big content-length",
|
|
||||||
[]byte("RTSP/1.0 200 OK\r\nContent-Length: 1000000\r\n\r\n123"),
|
|
||||||
"Content-Length exceeds 131072 (it's 1000000)",
|
|
||||||
},
|
|
||||||
} {
|
} {
|
||||||
t.Run(ca.name, func(t *testing.T) {
|
t.Run(ca.name, func(t *testing.T) {
|
||||||
var res Response
|
var res Response
|
||||||
|
Reference in New Issue
Block a user