mirror of
https://github.com/pion/webrtc.git
synced 2025-10-28 17:41:49 +08:00
New Track API
The Pion WebRTC API has been dramatically redesigned. The design docs are located here [0] You can also read the release notes [1] on how to migrate your application. [0] https://github.com/pion/webrtc-v3-design [1] https://github.com/pion/webrtc/wiki/Release-WebRTC@v3.0.0
This commit is contained in:
@@ -3,6 +3,7 @@ package samplebuilder
|
||||
import (
|
||||
"fmt"
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
"github.com/pion/rtp"
|
||||
"github.com/pion/webrtc/v3/pkg/media"
|
||||
@@ -58,7 +59,7 @@ func TestSampleBuilder(t *testing.T) {
|
||||
{Header: rtp.Header{SequenceNumber: 5002, Timestamp: 7}, Payload: []byte{0x03}},
|
||||
},
|
||||
samples: []*media.Sample{
|
||||
{Data: []byte{0x02}, Samples: 1},
|
||||
{Data: []byte{0x02}, Duration: time.Second},
|
||||
},
|
||||
timestamps: []uint32{
|
||||
6,
|
||||
@@ -74,7 +75,7 @@ func TestSampleBuilder(t *testing.T) {
|
||||
{Header: rtp.Header{SequenceNumber: 5003, Timestamp: 7}, Payload: []byte{0x04}},
|
||||
},
|
||||
samples: []*media.Sample{
|
||||
{Data: []byte{0x02, 0x03}, Samples: 1},
|
||||
{Data: []byte{0x02, 0x03}, Duration: time.Second},
|
||||
},
|
||||
timestamps: []uint32{
|
||||
6,
|
||||
@@ -102,7 +103,7 @@ func TestSampleBuilder(t *testing.T) {
|
||||
withHeadChecker: true,
|
||||
headBytes: []byte{0x02},
|
||||
samples: []*media.Sample{
|
||||
{Data: []byte{0x02}, Samples: 0},
|
||||
{Data: []byte{0x02}, Duration: 0},
|
||||
},
|
||||
timestamps: []uint32{
|
||||
6,
|
||||
@@ -133,10 +134,10 @@ func TestSampleBuilder(t *testing.T) {
|
||||
{Header: rtp.Header{SequenceNumber: 5005, Timestamp: 6}, Payload: []byte{0x06}},
|
||||
},
|
||||
samples: []*media.Sample{
|
||||
{Data: []byte{0x02}, Samples: 1},
|
||||
{Data: []byte{0x03}, Samples: 1},
|
||||
{Data: []byte{0x04}, Samples: 1},
|
||||
{Data: []byte{0x05}, Samples: 1},
|
||||
{Data: []byte{0x02}, Duration: time.Second},
|
||||
{Data: []byte{0x03}, Duration: time.Second},
|
||||
{Data: []byte{0x04}, Duration: time.Second},
|
||||
{Data: []byte{0x05}, Duration: time.Second},
|
||||
},
|
||||
timestamps: []uint32{
|
||||
2,
|
||||
@@ -159,7 +160,7 @@ func TestSampleBuilder(t *testing.T) {
|
||||
))
|
||||
}
|
||||
|
||||
s := New(t.maxLate, &fakeDepacketizer{}, opts...)
|
||||
s := New(t.maxLate, &fakeDepacketizer{}, 1, opts...)
|
||||
samples := []*media.Sample{}
|
||||
|
||||
for _, p := range t.packets {
|
||||
@@ -183,7 +184,7 @@ func TestSampleBuilder(t *testing.T) {
|
||||
))
|
||||
}
|
||||
|
||||
s := New(t.maxLate, &fakeDepacketizer{}, opts...)
|
||||
s := New(t.maxLate, &fakeDepacketizer{}, 1, opts...)
|
||||
samples := []*media.Sample{}
|
||||
timestamps := []uint32{}
|
||||
|
||||
@@ -204,17 +205,17 @@ func TestSampleBuilder(t *testing.T) {
|
||||
// SampleBuilder should respect maxLate if we popped successfully but then have a gap larger then maxLate
|
||||
func TestSampleBuilderMaxLate(t *testing.T) {
|
||||
assert := assert.New(t)
|
||||
s := New(50, &fakeDepacketizer{})
|
||||
s := New(50, &fakeDepacketizer{}, 1)
|
||||
|
||||
s.Push(&rtp.Packet{Header: rtp.Header{SequenceNumber: 0, Timestamp: 1}, Payload: []byte{0x01}})
|
||||
s.Push(&rtp.Packet{Header: rtp.Header{SequenceNumber: 1, Timestamp: 2}, Payload: []byte{0x01}})
|
||||
s.Push(&rtp.Packet{Header: rtp.Header{SequenceNumber: 2, Timestamp: 3}, Payload: []byte{0x01}})
|
||||
assert.Equal(s.Pop(), &media.Sample{Data: []byte{0x01}, Samples: 1}, "Failed to build samples before gap")
|
||||
assert.Equal(s.Pop(), &media.Sample{Data: []byte{0x01}, Duration: time.Second}, "Failed to build samples before gap")
|
||||
|
||||
s.Push(&rtp.Packet{Header: rtp.Header{SequenceNumber: 5000, Timestamp: 500}, Payload: []byte{0x02}})
|
||||
s.Push(&rtp.Packet{Header: rtp.Header{SequenceNumber: 5001, Timestamp: 501}, Payload: []byte{0x02}})
|
||||
s.Push(&rtp.Packet{Header: rtp.Header{SequenceNumber: 5002, Timestamp: 502}, Payload: []byte{0x02}})
|
||||
assert.Equal(s.Pop(), &media.Sample{Data: []byte{0x02}, Samples: 1}, "Failed to build samples after large gap")
|
||||
assert.Equal(s.Pop(), &media.Sample{Data: []byte{0x02}, Duration: time.Second}, "Failed to build samples after large gap")
|
||||
}
|
||||
|
||||
func TestSeqnumDistance(t *testing.T) {
|
||||
@@ -247,7 +248,7 @@ func TestSampleBuilderCleanReference(t *testing.T) {
|
||||
} {
|
||||
seqStart := seqStart
|
||||
t.Run(fmt.Sprintf("From%d", seqStart), func(t *testing.T) {
|
||||
s := New(10, &fakeDepacketizer{})
|
||||
s := New(10, &fakeDepacketizer{}, 1)
|
||||
|
||||
s.Push(&rtp.Packet{Header: rtp.Header{SequenceNumber: 0 + seqStart, Timestamp: 0}, Payload: []byte{0x01}})
|
||||
s.Push(&rtp.Packet{Header: rtp.Header{SequenceNumber: 1 + seqStart, Timestamp: 0}, Payload: []byte{0x02}})
|
||||
|
||||
Reference in New Issue
Block a user