Move negotation test out of peerconnection_test

No functional change
This commit is contained in:
Sean DuBois
2023-03-08 10:04:30 -08:00
committed by Sean DuBois
parent 777e03ca3c
commit 595f1c03d1
2 changed files with 35 additions and 36 deletions

View File

@@ -1285,3 +1285,38 @@ func TestPeerConnection_Regegotiation_AnswerAddsTrack(t *testing.T) {
closePairNow(t, pcOffer, pcAnswer)
}
func TestNegotiationNeededWithRecvonlyTrack(t *testing.T) {
lim := test.TimeOut(time.Second * 30)
defer lim.Stop()
report := test.CheckRoutines(t)
defer report()
pcOffer, pcAnswer, err := newPair()
if err != nil {
t.Fatal(err)
}
var wg sync.WaitGroup
wg.Add(1)
pcAnswer.OnNegotiationNeeded(wg.Done)
_, err = pcOffer.AddTransceiverFromKind(RTPCodecTypeVideo, RTPTransceiverInit{Direction: RTPTransceiverDirectionRecvonly})
if err != nil {
t.Fatal(err)
}
if err := signalPair(pcOffer, pcAnswer); err != nil {
t.Fatal(err)
}
onDataChannel, onDataChannelCancel := context.WithCancel(context.Background())
pcAnswer.OnDataChannel(func(d *DataChannel) {
onDataChannelCancel()
})
<-onDataChannel.Done()
wg.Wait()
closePairNow(t, pcOffer, pcAnswer)
}

View File

@@ -1,7 +1,6 @@
package webrtc
import (
"context"
"reflect"
"sync"
"sync/atomic"
@@ -752,38 +751,3 @@ func TestTransportChain(t *testing.T) {
closePairNow(t, offer, answer)
}
func TestNegotiationNeededWithRecvonlyTrack(t *testing.T) {
lim := test.TimeOut(time.Second * 30)
defer lim.Stop()
report := test.CheckRoutines(t)
defer report()
pcOffer, pcAnswer, err := newPair()
if err != nil {
t.Fatal(err)
}
var wg sync.WaitGroup
wg.Add(1)
pcAnswer.OnNegotiationNeeded(wg.Done)
_, err = pcOffer.AddTransceiverFromKind(RTPCodecTypeVideo, RTPTransceiverInit{Direction: RTPTransceiverDirectionRecvonly})
if err != nil {
t.Fatal(err)
}
if err := signalPair(pcOffer, pcAnswer); err != nil {
t.Fatal(err)
}
onDataChannel, onDataChannelCancel := context.WithCancel(context.Background())
pcAnswer.OnDataChannel(func(d *DataChannel) {
onDataChannelCancel()
})
<-onDataChannel.Done()
wg.Wait()
closePairNow(t, pcOffer, pcAnswer)
}