mirror of
https://github.com/livekit/livekit.git
synced 2026-04-26 10:57:38 +00:00
* Adaptive publishing improvements * fix tests * proper comment sentence * Address comments from David * proper locking * fix crash * Do not start quality timer if not video
128 lines
3.6 KiB
Go
128 lines
3.6 KiB
Go
package sfu
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/livekit/livekit-server/pkg/testutils"
|
|
)
|
|
|
|
func TestStreamTracker(t *testing.T) {
|
|
t.Run("flips to active on first observe", func(t *testing.T) {
|
|
callbackCalled := atomicBool(0)
|
|
tracker := NewStreamTracker(5, 60, 500*time.Millisecond)
|
|
tracker.OnStatusChanged(func(status StreamStatus) {
|
|
callbackCalled.set(true)
|
|
})
|
|
require.Equal(t, StreamStatusStopped, tracker.Status())
|
|
|
|
// observe first packet
|
|
tracker.Observe(1)
|
|
|
|
testutils.WithTimeout(t, "first packet makes stream active", func() bool {
|
|
return callbackCalled.get()
|
|
})
|
|
|
|
require.Equal(t, StreamStatusActive, tracker.Status())
|
|
require.True(t, callbackCalled.get())
|
|
})
|
|
|
|
t.Run("flips to inactive immediately", func(t *testing.T) {
|
|
tracker := NewStreamTracker(5, 60, 500*time.Millisecond)
|
|
require.Equal(t, StreamStatusStopped, tracker.Status())
|
|
|
|
tracker.Observe(1)
|
|
testutils.WithTimeout(t, "first packet makes stream active", func() bool {
|
|
return tracker.Status() == StreamStatusActive
|
|
})
|
|
|
|
callbackCalled := atomicBool(0)
|
|
tracker.OnStatusChanged(func(status StreamStatus) {
|
|
callbackCalled.set(true)
|
|
})
|
|
require.Equal(t, StreamStatusActive, tracker.Status())
|
|
|
|
// run a single iteration
|
|
tracker.detectChanges()
|
|
require.Equal(t, StreamStatusStopped, tracker.Status())
|
|
require.True(t, callbackCalled.get())
|
|
})
|
|
|
|
t.Run("flips back to active after iterations", func(t *testing.T) {
|
|
tracker := NewStreamTracker(1, 2, 500*time.Millisecond)
|
|
require.Equal(t, StreamStatusStopped, tracker.Status())
|
|
|
|
tracker.Observe(1)
|
|
testutils.WithTimeout(t, "first packet makes stream active", func() bool {
|
|
return tracker.Status() == StreamStatusActive
|
|
})
|
|
|
|
tracker.maybeSetStopped()
|
|
|
|
tracker.Observe(2)
|
|
tracker.detectChanges()
|
|
require.Equal(t, StreamStatusStopped, tracker.Status())
|
|
|
|
tracker.Observe(3)
|
|
tracker.detectChanges()
|
|
require.Equal(t, StreamStatusActive, tracker.Status())
|
|
})
|
|
|
|
t.Run("does not change to inactive when paused", func(t *testing.T) {
|
|
tracker := NewStreamTracker(5, 60, 500*time.Millisecond)
|
|
tracker.Observe(1)
|
|
testutils.WithTimeout(t, "first packet makes stream active", func() bool {
|
|
return tracker.Status() == StreamStatusActive
|
|
})
|
|
|
|
tracker.SetPaused(true)
|
|
tracker.detectChanges()
|
|
require.Equal(t, StreamStatusActive, tracker.Status())
|
|
})
|
|
|
|
t.Run("flips back to active on first observe after reset", func(t *testing.T) {
|
|
callbackCalled := atomicUint32(0)
|
|
tracker := NewStreamTracker(5, 60, 500*time.Millisecond)
|
|
tracker.OnStatusChanged(func(status StreamStatus) {
|
|
callbackCalled.add(1)
|
|
})
|
|
require.Equal(t, StreamStatusStopped, tracker.Status())
|
|
|
|
// observe first packet
|
|
tracker.Observe(1)
|
|
|
|
testutils.WithTimeout(t, "first packet makes stream active", func() bool {
|
|
return callbackCalled.get() == 1
|
|
})
|
|
|
|
require.Equal(t, StreamStatusActive, tracker.Status())
|
|
require.Equal(t, uint32(1), callbackCalled.get())
|
|
|
|
// obaerver a few more
|
|
tracker.Observe(2)
|
|
tracker.Observe(3)
|
|
tracker.Observe(4)
|
|
tracker.Observe(5)
|
|
tracker.detectChanges()
|
|
|
|
// should still be active
|
|
require.Equal(t, StreamStatusActive, tracker.Status())
|
|
|
|
// Reset. The first packet after reset should flip state again
|
|
tracker.Reset()
|
|
require.Equal(t, StreamStatusStopped, tracker.Status())
|
|
|
|
// first packet after reset
|
|
tracker.Observe(1)
|
|
|
|
testutils.WithTimeout(t, "first packet after reset makes stream active", func() bool {
|
|
return callbackCalled.get() == 2
|
|
})
|
|
|
|
require.Equal(t, StreamStatusActive, tracker.Status())
|
|
require.Equal(t, uint32(2), callbackCalled.get())
|
|
})
|
|
}
|