forked from quic-go/quic-go
implement Stream.ReadByte
This commit is contained in:
14
stream.go
14
stream.go
@@ -53,6 +53,20 @@ func (s *Stream) Read(p []byte) (int, error) {
|
|||||||
return bytesRead, nil
|
return bytesRead, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ReadByte implements io.ByteReader
|
||||||
|
func (s *Stream) ReadByte() (byte, error) {
|
||||||
|
// TODO: Optimize
|
||||||
|
p := make([]byte, 1)
|
||||||
|
n, err := s.Read(p)
|
||||||
|
if err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
if n != 1 {
|
||||||
|
panic("Stream: should have returned error")
|
||||||
|
}
|
||||||
|
return p[0], nil
|
||||||
|
}
|
||||||
|
|
||||||
func (s *Stream) Write(p []byte) (int, error) {
|
func (s *Stream) Write(p []byte) (int, error) {
|
||||||
frame := &frames.StreamFrame{
|
frame := &frames.StreamFrame{
|
||||||
StreamID: s.StreamID,
|
StreamID: s.StreamID,
|
||||||
|
|||||||
@@ -23,6 +23,45 @@ var _ = Describe("Stream", func() {
|
|||||||
Expect(b).To(Equal([]byte{0xDE, 0xAD, 0xBE, 0xEF}))
|
Expect(b).To(Equal([]byte{0xDE, 0xAD, 0xBE, 0xEF}))
|
||||||
})
|
})
|
||||||
|
|
||||||
|
It("reads a single StreamFrame in multiple goes", func() {
|
||||||
|
frame := frames.StreamFrame{
|
||||||
|
Offset: 0,
|
||||||
|
Data: []byte{0xDE, 0xAD, 0xBE, 0xEF},
|
||||||
|
}
|
||||||
|
stream := NewStream(nil, 1337)
|
||||||
|
stream.AddStreamFrame(&frame)
|
||||||
|
b := make([]byte, 2)
|
||||||
|
n, err := stream.Read(b)
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
Expect(n).To(Equal(2))
|
||||||
|
Expect(b).To(Equal([]byte{0xDE, 0xAD}))
|
||||||
|
n, err = stream.Read(b)
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
Expect(n).To(Equal(2))
|
||||||
|
Expect(b).To(Equal([]byte{0xBE, 0xEF}))
|
||||||
|
})
|
||||||
|
|
||||||
|
It("reads single bytes", func() {
|
||||||
|
frame := frames.StreamFrame{
|
||||||
|
Offset: 0,
|
||||||
|
Data: []byte{0xDE, 0xAD, 0xBE, 0xEF},
|
||||||
|
}
|
||||||
|
stream := NewStream(nil, 1337)
|
||||||
|
stream.AddStreamFrame(&frame)
|
||||||
|
b, err := stream.ReadByte()
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
Expect(b).To(Equal(byte(0xDE)))
|
||||||
|
b, err = stream.ReadByte()
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
Expect(b).To(Equal(byte(0xAD)))
|
||||||
|
b, err = stream.ReadByte()
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
Expect(b).To(Equal(byte(0xBE)))
|
||||||
|
b, err = stream.ReadByte()
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
Expect(b).To(Equal(byte(0xEF)))
|
||||||
|
})
|
||||||
|
|
||||||
It("reads all data available", func() {
|
It("reads all data available", func() {
|
||||||
frame1 := frames.StreamFrame{
|
frame1 := frames.StreamFrame{
|
||||||
Offset: 0,
|
Offset: 0,
|
||||||
|
|||||||
Reference in New Issue
Block a user