|
4 | 4 | package rtpbuffer
|
5 | 5 |
|
6 | 6 | import (
|
| 7 | + "bytes" |
7 | 8 | "testing"
|
8 | 9 |
|
9 | 10 | "github.com/pion/rtp"
|
@@ -218,3 +219,50 @@ func TestRTPBuffer_Overridden_WithRTX_NILPayload(t *testing.T) {
|
218 | 219 |
|
219 | 220 | require.Nil(t, sb.Get(1))
|
220 | 221 | }
|
| 222 | + |
| 223 | +func TestRTPBuffer_Padding(t *testing.T) { |
| 224 | + pm := NewPacketFactoryCopy() |
| 225 | + sb, err := NewRTPBuffer(1) |
| 226 | + require.NoError(t, err) |
| 227 | + require.Equal(t, uint16(1), sb.size) |
| 228 | + |
| 229 | + t.Run("valid padding is stripped", func(t *testing.T) { |
| 230 | + origPayload := []byte{116, 101, 115, 116} |
| 231 | + expected := []byte{0, 1, 116, 101, 115, 116} |
| 232 | + |
| 233 | + padLen := 120 |
| 234 | + padded := make([]byte, 0) |
| 235 | + padded = append(padded, origPayload...) |
| 236 | + padded = append(padded, bytes.Repeat([]byte{0}, padLen-1)...) |
| 237 | + padded = append(padded, byte(padLen)) |
| 238 | + |
| 239 | + pkt, err := pm.NewPacket(&rtp.Header{ |
| 240 | + SequenceNumber: 1, |
| 241 | + Padding: true, |
| 242 | + }, padded, 1, 1) |
| 243 | + require.NoError(t, err) |
| 244 | + |
| 245 | + sb.Add(pkt) |
| 246 | + |
| 247 | + retrieved := sb.Get(1) |
| 248 | + require.NotNil(t, retrieved) |
| 249 | + defer retrieved.Release() |
| 250 | + |
| 251 | + require.False(t, retrieved.Header().Padding, "P-bit should be cleared after trimming") |
| 252 | + |
| 253 | + actual := retrieved.Payload() |
| 254 | + require.Equal(t, len(expected), len(actual), "payload length after trimming") |
| 255 | + require.Equal(t, expected, actual, "payload content after trimming") |
| 256 | + }) |
| 257 | + |
| 258 | + t.Run("overflow padding returns io.ErrShortBuffer", func(t *testing.T) { |
| 259 | + overflow := []byte{0, 1, 200} |
| 260 | + |
| 261 | + _, err := pm.NewPacket(&rtp.Header{ |
| 262 | + SequenceNumber: 2, |
| 263 | + Padding: true, |
| 264 | + }, overflow, 1, 1) |
| 265 | + |
| 266 | + require.ErrorIs(t, err, errPaddingOverflow, "factory should reject invalid padding") |
| 267 | + }) |
| 268 | +} |
0 commit comments