From 6deb47d3bf148db556cf3df905f236770a15b24d Mon Sep 17 00:00:00 2001 From: Michael Klingbeil Date: Mon, 4 Mar 2024 18:29:56 -0500 Subject: [PATCH] Properly update metadata when PayloadType is 0 In the case where a remote track is sending PCMU with payload type 0 checkAndUpdateTrack will fail to update the track codec and params (because t.PayloadType() is already 0). Add an extra check to handle this case. --- peerconnection_media_test.go | 45 ++++++++++++++++++++++++++++++++++++ track_remote.go | 3 ++- 2 files changed, 47 insertions(+), 1 deletion(-) diff --git a/peerconnection_media_test.go b/peerconnection_media_test.go index 4d638ebdf9f..228cfed4bc2 100644 --- a/peerconnection_media_test.go +++ b/peerconnection_media_test.go @@ -1512,3 +1512,48 @@ func TestPeerConnection_Simulcast_NoDataChannel(t *testing.T) { closePairNow(t, pcSender, pcReceiver) } + +// Check that PayloadType of 0 is handled correctly. At one point +// we incorrectly assumed 0 meant an invalid stream and wouldn't update things +// properly +func TestPeerConnection_Zero_PayloadType(t *testing.T) { + lim := test.TimeOut(time.Second * 5) + defer lim.Stop() + + report := test.CheckRoutines(t) + defer report() + + pcOffer, pcAnswer, err := newPair() + require.NoError(t, err) + + audioTrack, err := NewTrackLocalStaticSample(RTPCodecCapability{MimeType: MimeTypePCMU}, "audio", "audio") + require.NoError(t, err) + + _, err = pcOffer.AddTrack(audioTrack) + require.NoError(t, err) + + assert.NoError(t, signalPair(pcOffer, pcAnswer)) + + onTrackFired, onTrackFiredCancel := context.WithCancel(context.Background()) + pcAnswer.OnTrack(func(track *TrackRemote, _ *RTPReceiver) { + require.Equal(t, track.Codec().MimeType, MimeTypePCMU) + onTrackFiredCancel() + }) + + go func() { + ticker := time.NewTicker(20 * time.Millisecond) + defer ticker.Stop() + + select { + case <-onTrackFired.Done(): + return + case <-ticker.C: + if routineErr := audioTrack.WriteSample(media.Sample{Data: []byte{0x00}, Duration: time.Second}); routineErr != nil { + fmt.Println(routineErr) + } + } + }() + + <-onTrackFired.Done() + closePairNow(t, pcOffer, pcAnswer) +} diff --git a/track_remote.go b/track_remote.go index dfdb12b9594..691b488d83e 100644 --- a/track_remote.go +++ b/track_remote.go @@ -153,7 +153,8 @@ func (t *TrackRemote) checkAndUpdateTrack(b []byte) error { return errRTPTooShort } - if payloadType := PayloadType(b[1] & rtpPayloadTypeBitmask); payloadType != t.PayloadType() { + payloadType := PayloadType(b[1] & rtpPayloadTypeBitmask) + if payloadType != t.PayloadType() || len(t.params.Codecs) == 0 { t.mu.Lock() defer t.mu.Unlock()