diff --git a/player/src/androidTest/kotlin/com/tidal/sdk/player/playlog/PlayLogTest.kt b/player/src/androidTest/kotlin/com/tidal/sdk/player/playlog/SingleMediaProductPlayLogTest.kt similarity index 80% rename from player/src/androidTest/kotlin/com/tidal/sdk/player/playlog/PlayLogTest.kt rename to player/src/androidTest/kotlin/com/tidal/sdk/player/playlog/SingleMediaProductPlayLogTest.kt index 34c1372e..4e9cbc93 100644 --- a/player/src/androidTest/kotlin/com/tidal/sdk/player/playlog/PlayLogTest.kt +++ b/player/src/androidTest/kotlin/com/tidal/sdk/player/playlog/SingleMediaProductPlayLogTest.kt @@ -26,11 +26,8 @@ import com.tidal.sdk.player.events.playlogtest.PlayLogTestDefaultEventReporterCo import com.tidal.sdk.player.events.reflectionComponentFactoryF import com.tidal.sdk.player.playbackengine.model.Event import com.tidal.sdk.player.playbackengine.model.Event.MediaProductEnded -import com.tidal.sdk.player.repeatableflakytest.RepeatableFlakyTest import com.tidal.sdk.player.repeatableflakytest.RepeatableFlakyTestRule import com.tidal.sdk.player.setBodyFromFile -import kotlin.time.Duration.Companion.milliseconds -import kotlin.time.Duration.Companion.seconds import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.delay import kotlinx.coroutines.flow.Flow @@ -55,6 +52,8 @@ import org.junit.Before import org.junit.BeforeClass import org.junit.Rule import org.junit.Test +import org.junit.runner.RunWith +import org.junit.runners.Parameterized import org.mockito.Mockito.atMost import org.mockito.Mockito.mock import org.mockito.Mockito.verifyNoMoreInteractions @@ -62,8 +61,11 @@ import org.mockito.kotlin.anyOrNull import org.mockito.kotlin.argThat import org.mockito.kotlin.eq import org.mockito.kotlin.verify +import kotlin.time.Duration.Companion.milliseconds +import kotlin.time.Duration.Companion.seconds -class PlayLogTest { +@RunWith(Parameterized::class) +internal class SingleMediaProductPlayLogTest(private val mediaProduct: MediaProduct) { @get:Rule val server = MockWebServer() @@ -79,6 +81,16 @@ class PlayLogTest { @Before fun setUp() { + responseDispatcher[ + "https://api.tidal.com/v1/tracks/${mediaProduct.productId}/playbackinfo?playbackmode=STREAM&assetpresentation=FULL&audioquality=LOW&immersiveaudio=true".toHttpUrl(), + ] = { + MockResponse().setBodyFromFile( + "api-responses/playbackinfo/tracks/playlogtest/get_1_bts.json", + ) + } + responseDispatcher["https://test.audio.tidal.com/1_bts.m4a".toHttpUrl()] = { + MockResponse().setBodyFromFile("raw/playlogtest/1_bts.m4a") + } EventReporterModuleRoot.reflectionComponentFactoryF = { PlayLogTestDefaultEventReporterComponentFactory(eventReporterCoroutineScope) } @@ -130,6 +142,15 @@ class PlayLogTest { originalEventReporterComponentFactoryF = EventReporterModuleRoot.reflectionComponentFactoryF } + + @JvmStatic + @Parameterized.Parameters + fun parameters() = setOf( + MediaProduct(ProductType.TRACK, "1", "TESTA", "456"), + MediaProduct(ProductType.TRACK, "1", null, "789"), + MediaProduct(ProductType.TRACK, "1", "TESTB", null), + MediaProduct(ProductType.TRACK, "1", null, null), + ) } @After @@ -147,38 +168,8 @@ class PlayLogTest { verifyNoMoreInteractions(eventSender) } - @RepeatableFlakyTest // Playback may take longer in practice than it should in theory - @Test - fun loadAndPlayUntilEndNoNulls() = - loadAndPlayUntilEnd(MediaProduct(ProductType.TRACK, "1", "TESTA", "456")) - - @RepeatableFlakyTest // Playback may take longer in practice than it should in theory - @Test - fun loadAndPlayUntilEndNullSourceType() = - loadAndPlayUntilEnd(MediaProduct(ProductType.TRACK, "1", null, "789")) - - @RepeatableFlakyTest // Playback may take longer in practice than it should in theory - @Test - fun loadAndPlayUntilEndNullSourceId() = - loadAndPlayUntilEnd(MediaProduct(ProductType.TRACK, "1", "TESTB", null)) - - @RepeatableFlakyTest // Playback may take longer in practice than it should in theory @Test - fun loadAndPlayUntilEndNullSourceTypeNullSourceId() = - loadAndPlayUntilEnd(MediaProduct(ProductType.TRACK, "1", null, null)) - - private fun loadAndPlayUntilEnd(mediaProduct: MediaProduct) = runTest { - responseDispatcher[ - "https://api.tidal.com/v1/tracks/1/playbackinfo?playbackmode=STREAM&assetpresentation=FULL&audioquality=LOW&immersiveaudio=true".toHttpUrl(), - ] = { - MockResponse().setBodyFromFile( - "api-responses/playbackinfo/tracks/playlogtest/get_1_bts.json" - ) - } - responseDispatcher["https://test.audio.tidal.com/1_bts.m4a".toHttpUrl()] = { - MockResponse().setBodyFromFile("raw/playlogtest/1_bts.m4a") - } - + fun loadAndPlayUntilEnd() = runTest { player.playbackEngine.load(mediaProduct) player.playbackEngine.play() withContext(Dispatchers.Default.limitedParallelism(1)) { @@ -208,35 +199,10 @@ class PlayLogTest { ) } - @Test - fun loadAndPlayThenPauseThenPlayNoNulls() = - loadAndPlayThenPauseThenPlay(MediaProduct(ProductType.TRACK, "1", "TESTA", "456")) - - @Test - fun loadAndPlayThenPauseThenPlayNullSourceType() = - loadAndPlayThenPauseThenPlay(MediaProduct(ProductType.TRACK, "1", null, "789")) - - @Test - fun loadAndPlayThenPauseThenPlayNullSourceId() = - loadAndPlayThenPauseThenPlay(MediaProduct(ProductType.TRACK, "1", "TESTB", null)) - - @Test - fun loadAndPlayThenPauseThenPlayNullSourceTypeNullSourceId() = - loadAndPlayThenPauseThenPlay(MediaProduct(ProductType.TRACK, "1", null, null)) - @Suppress("LongMethod") - private fun loadAndPlayThenPauseThenPlay(mediaProduct: MediaProduct) = runTest { + @Test + fun loadAndPlayThenPauseThenPlay() = runTest { val gson = Gson() - responseDispatcher[ - "https://api.tidal.com/v1/tracks/1/playbackinfo?playbackmode=STREAM&assetpresentation=FULL&audioquality=LOW&immersiveaudio=true".toHttpUrl(), - ] = { - MockResponse().setBodyFromFile( - "api-responses/playbackinfo/tracks/playlogtest/get_1_bts.json", - ) - } - responseDispatcher["https://test.audio.tidal.com/1_bts.m4a".toHttpUrl()] = { - MockResponse().setBodyFromFile("raw/playlogtest/1_bts.m4a") - } player.playbackEngine.load(mediaProduct) player.playbackEngine.play()