Files
livekit/pkg/sfu/streamtracker_test.go
Raja Subramanian 03000f88cb Adaptive publishing improvements (#295)
* Adaptive publishing improvements

* fix tests

* proper comment sentence

* Address comments from David

* proper locking

* fix crash

* Do not start quality timer if not video
2021-12-30 09:50:53 +05:30

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())
})
}