From 4614c97e14635c7861c39e1dfaa0908c4a04954f Mon Sep 17 00:00:00 2001 From: Mustafa Ozhan Date: Sat, 14 Oct 2023 12:51:44 +0200 Subject: [PATCH] [Oztechan/CCC#2860] Move common test values to Fakes in order to share --- .../core/persistence/PersistenceTest.kt | 69 +++++++++---------- .../client/core/persistence/fakes/Fakes.kt | 12 ++++ 2 files changed, 45 insertions(+), 36 deletions(-) create mode 100644 client/core/persistence/src/commonTest/kotlin/com/oztechan/ccc/client/core/persistence/fakes/Fakes.kt diff --git a/client/core/persistence/src/commonTest/kotlin/com/oztechan/ccc/client/core/persistence/PersistenceTest.kt b/client/core/persistence/src/commonTest/kotlin/com/oztechan/ccc/client/core/persistence/PersistenceTest.kt index 5c0d5978c3..ff330ef5e2 100644 --- a/client/core/persistence/src/commonTest/kotlin/com/oztechan/ccc/client/core/persistence/PersistenceTest.kt +++ b/client/core/persistence/src/commonTest/kotlin/com/oztechan/ccc/client/core/persistence/PersistenceTest.kt @@ -1,6 +1,12 @@ package com.oztechan.ccc.client.core.persistence import com.oztechan.ccc.client.core.persistence.error.UnsupportedPersistenceException +import com.oztechan.ccc.client.core.persistence.fakes.Fakes.KEY +import com.oztechan.ccc.client.core.persistence.fakes.Fakes.mockBoolean +import com.oztechan.ccc.client.core.persistence.fakes.Fakes.mockFloat +import com.oztechan.ccc.client.core.persistence.fakes.Fakes.mockInt +import com.oztechan.ccc.client.core.persistence.fakes.Fakes.mockLong +import com.oztechan.ccc.client.core.persistence.fakes.Fakes.mockString import com.russhwolf.settings.Settings import io.mockative.Mock import io.mockative.classOf @@ -8,7 +14,6 @@ import io.mockative.configure import io.mockative.every import io.mockative.mock import io.mockative.verify -import kotlin.random.Random import kotlin.test.Test import kotlin.test.assertEquals import kotlin.test.assertFailsWith @@ -23,62 +28,54 @@ internal class PersistenceTest { stubsUnitByDefault = true } - private val key = "key" - - private val mockFloat = Random.nextFloat() - private val mockBoolean = Random.nextBoolean() - private val mockInt = Random.nextInt() - private val mockString = Random.nextInt().toString() - private val mockLong = Random.nextLong() - @Test fun `getValue returns the same type`() { - every { settings.getFloat(key, mockFloat) } + every { settings.getFloat(KEY, mockFloat) } .returns(mockFloat) - every { settings.getBoolean(key, mockBoolean) } + every { settings.getBoolean(KEY, mockBoolean) } .returns(mockBoolean) - every { settings.getInt(key, mockInt) } + every { settings.getInt(KEY, mockInt) } .returns(mockInt) - every { settings.getString(key, mockString) } + every { settings.getString(KEY, mockString) } .returns(mockString) - every { settings.getLong(key, mockLong) } + every { settings.getLong(KEY, mockLong) } .returns(mockLong) - assertEquals(mockFloat, persistence.getValue(key, mockFloat)) - assertEquals(mockBoolean, persistence.getValue(key, mockBoolean)) - assertEquals(mockInt, persistence.getValue(key, mockInt)) - assertEquals(mockString, persistence.getValue(key, mockString)) - assertEquals(mockLong, persistence.getValue(key, mockLong)) + assertEquals(mockFloat, persistence.getValue(KEY, mockFloat)) + assertEquals(mockBoolean, persistence.getValue(KEY, mockBoolean)) + assertEquals(mockInt, persistence.getValue(KEY, mockInt)) + assertEquals(mockString, persistence.getValue(KEY, mockString)) + assertEquals(mockLong, persistence.getValue(KEY, mockLong)) - verify { settings.getFloat(key, mockFloat) } + verify { settings.getFloat(KEY, mockFloat) } .wasInvoked() - verify { settings.getBoolean(key, mockBoolean) } + verify { settings.getBoolean(KEY, mockBoolean) } .wasInvoked() - verify { settings.getInt(key, mockInt) } + verify { settings.getInt(KEY, mockInt) } .wasInvoked() - verify { settings.getString(key, mockString) } + verify { settings.getString(KEY, mockString) } .wasInvoked() - verify { settings.getLong(key, mockLong) } + verify { settings.getLong(KEY, mockLong) } .wasInvoked() } @Test fun `setValue sets the same type`() { - persistence.setValue(key, mockFloat) - persistence.setValue(key, mockBoolean) - persistence.setValue(key, mockInt) - persistence.setValue(key, mockString) - persistence.setValue(key, mockLong) + persistence.setValue(KEY, mockFloat) + persistence.setValue(KEY, mockBoolean) + persistence.setValue(KEY, mockInt) + persistence.setValue(KEY, mockString) + persistence.setValue(KEY, mockLong) - verify { settings.putFloat(key, mockFloat) } + verify { settings.putFloat(KEY, mockFloat) } .wasInvoked() - verify { settings.putBoolean(key, mockBoolean) } + verify { settings.putBoolean(KEY, mockBoolean) } .wasInvoked() - verify { settings.putInt(key, mockInt) } + verify { settings.putInt(KEY, mockInt) } .wasInvoked() - verify { settings.putString(key, mockString) } + verify { settings.putString(KEY, mockString) } .wasInvoked() - verify { settings.putLong(key, mockLong) } + verify { settings.putLong(KEY, mockLong) } .wasInvoked() } @@ -87,10 +84,10 @@ internal class PersistenceTest { val mockObject = object {} assertFailsWith(UnsupportedPersistenceException::class) { - persistence.setValue(key, mockObject) + persistence.setValue(KEY, mockObject) } assertFailsWith(UnsupportedPersistenceException::class) { - persistence.getValue(key, mockObject) + persistence.getValue(KEY, mockObject) } } } diff --git a/client/core/persistence/src/commonTest/kotlin/com/oztechan/ccc/client/core/persistence/fakes/Fakes.kt b/client/core/persistence/src/commonTest/kotlin/com/oztechan/ccc/client/core/persistence/fakes/Fakes.kt new file mode 100644 index 0000000000..dec0075d52 --- /dev/null +++ b/client/core/persistence/src/commonTest/kotlin/com/oztechan/ccc/client/core/persistence/fakes/Fakes.kt @@ -0,0 +1,12 @@ +package com.oztechan.ccc.client.core.persistence.fakes + +import kotlin.random.Random + +object Fakes { + const val KEY = "key" + val mockFloat = Random.nextFloat() + val mockBoolean = Random.nextBoolean() + val mockInt = Random.nextInt() + val mockString = Random.nextInt().toString() + val mockLong = Random.nextLong() +}