summaryrefslogtreecommitdiff
path: root/sw-ui/src/test/kotlin/org/luxons
diff options
context:
space:
mode:
authorJoffrey Bion <joffrey.bion@gmail.com>2023-07-06 00:16:45 +0200
committerJoffrey Bion <joffrey.bion@gmail.com>2023-07-06 00:30:55 +0200
commitcdaae5279e3f53c146df2500a8d7a1d4eae2f674 (patch)
tree55347f2839caaf4688f4f989e9568ffd7102db63 /sw-ui/src/test/kotlin/org/luxons
parentUpgrade Kotlin JS wrappers to 1.0.0-pre.585 (diff)
downloadseven-wonders-main.tar.gz
seven-wonders-main.tar.bz2
seven-wonders-main.zip
Convert sw-ui module to Kotlin Multiplatform gradle pluginmain
Diffstat (limited to 'sw-ui/src/test/kotlin/org/luxons')
-rw-r--r--sw-ui/src/test/kotlin/org/luxons/sevenwonders/ui/redux/sagas/SagasFrameworkTest.kt89
-rw-r--r--sw-ui/src/test/kotlin/org/luxons/sevenwonders/ui/utils/CoroutineUtilsTest.kt24
2 files changed, 0 insertions, 113 deletions
diff --git a/sw-ui/src/test/kotlin/org/luxons/sevenwonders/ui/redux/sagas/SagasFrameworkTest.kt b/sw-ui/src/test/kotlin/org/luxons/sevenwonders/ui/redux/sagas/SagasFrameworkTest.kt
deleted file mode 100644
index f810c8b9..00000000
--- a/sw-ui/src/test/kotlin/org/luxons/sevenwonders/ui/redux/sagas/SagasFrameworkTest.kt
+++ /dev/null
@@ -1,89 +0,0 @@
-package org.luxons.sevenwonders.ui.redux.sagas
-
-import kotlinx.coroutines.*
-import kotlinx.coroutines.test.*
-import redux.RAction
-import redux.Store
-import redux.WrapperAction
-import redux.applyMiddleware
-import redux.compose
-import redux.createStore
-import redux.rEnhancer
-import kotlin.test.Test
-import kotlin.test.assertEquals
-
-private data class State(val data: String)
-
-private data class UpdateData(val newData: String) : RAction
-private class DuplicateData : RAction
-private class SideEffectAction(val data: String) : RAction
-
-private fun reduce(state: State, action: RAction): State = when (action) {
- is UpdateData -> State(action.newData)
- is DuplicateData -> State(state.data + state.data)
- else -> state
-}
-
-private fun configureTestStore(initialState: State): TestRedux {
- val sagaMiddlewareFactory = SagaManager<State, RAction, WrapperAction>()
- val sagaMiddleware = sagaMiddlewareFactory.createMiddleware()
- val enhancers = compose(applyMiddleware(sagaMiddleware), rEnhancer())
- val store = createStore(::reduce, initialState, enhancers)
- return TestRedux(store, sagaMiddlewareFactory)
-}
-
-private data class TestRedux(
- val store: Store<State, RAction, WrapperAction>,
- val sagas: SagaManager<State, RAction, WrapperAction>,
-)
-
-@OptIn(ExperimentalCoroutinesApi::class) // for runTest
-class SagaContextTest {
-
- @Test
- fun dispatch_dispatchesToStore() = runTest {
- val redux = configureTestStore(State("initial"))
-
- redux.sagas.runSaga {
- dispatch(UpdateData("Bob"))
- }
-
- assertEquals(State("Bob"), redux.store.getState(), "state is not as expected")
- }
-
- @Test
- fun next_waitsForNextAction() = runTest {
- val redux = configureTestStore(State("initial"))
-
- val job = redux.sagas.launchSaga(this) {
- val action = next<SideEffectAction>()
- dispatch(UpdateData("effect-${action.data}"))
- }
- advanceUntilIdle() // make sure the saga is launched
-
- assertEquals(State("initial"), redux.store.getState())
-
- redux.store.dispatch(SideEffectAction("data"))
- job.join()
- assertEquals(State("effect-data"), redux.store.getState())
- }
-
- @Test
- fun onEach() = runTest {
- val redux = configureTestStore(State("initial"))
-
- val job = redux.sagas.launchSaga(this) {
- onEach<SideEffectAction> {
- dispatch(UpdateData("effect-${it.data}"))
- }
- }
- advanceUntilIdle() // make sure the saga is launched
-
- assertEquals(State("initial"), redux.store.getState())
-
- redux.store.dispatch(SideEffectAction("data"))
- yield()
- assertEquals(State("effect-data"), redux.store.getState())
- job.cancel()
- }
-}
diff --git a/sw-ui/src/test/kotlin/org/luxons/sevenwonders/ui/utils/CoroutineUtilsTest.kt b/sw-ui/src/test/kotlin/org/luxons/sevenwonders/ui/utils/CoroutineUtilsTest.kt
deleted file mode 100644
index ef8dfb62..00000000
--- a/sw-ui/src/test/kotlin/org/luxons/sevenwonders/ui/utils/CoroutineUtilsTest.kt
+++ /dev/null
@@ -1,24 +0,0 @@
-package org.luxons.sevenwonders.ui.utils
-
-import kotlinx.coroutines.*
-import kotlinx.coroutines.test.*
-import kotlin.test.Test
-import kotlin.test.assertEquals
-
-class CoroutineUtilsTest {
-
- @OptIn(ExperimentalCoroutinesApi::class) // for runTest
- @Test
- fun awaitFirstTest() = runTest {
- val s = awaitFirst(
- { delay(100); "1" },
- { delay(200); "2" },
- )
- assertEquals("1", s)
- val s2 = awaitFirst(
- { delay(150); "1" },
- { delay(50); "2" },
- )
- assertEquals("2", s2)
- }
-}
bgstack15