Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

141 serializable metrics #156

Merged
merged 139 commits into from
Oct 29, 2024
Merged
Changes from 1 commit
Commits
Show all changes
139 commits
Select commit Hold shift + click to select a range
ba0fda4
Create reproduction-check.yml
dominikmaeckel Aug 13, 2024
1240cdb
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
2abec10
Comment out check for DRAFT state
dominikmaeckel Aug 13, 2024
aaf205c
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
2d0264a
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
f19db1c
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
c927e71
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
7922405
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
1d12ab9
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
f72cf75
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
41583fe
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
9222526
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
3301e43
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
565a9af
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
c447329
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
56c62de
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
0a2f737
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
24eecf6
Create reproduction-check-all.yml
dominikmaeckel Aug 13, 2024
c081512
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
a50741b
Update reproduction-check-all.yml
dominikmaeckel Aug 13, 2024
4df6029
Update reproduction-check.yml
dominikmaeckel Aug 13, 2024
c23be8e
Update reproduction-check-all.yml
dominikmaeckel Aug 13, 2024
882c126
Update reproduction-check-all.yml
dominikmaeckel Aug 13, 2024
fa09134
Add first draft of metric serialization
tillschallau Aug 14, 2024
89571b9
Merge remote-tracking branch 'refs/remotes/origin/main' into 141-seri…
tillschallau Aug 15, 2024
460e2ca
Add second draft of metric serialization
tillschallau Aug 15, 2024
896b420
Add saving and loading of serialized results
tillschallau Aug 15, 2024
b91d033
Add serialization of new SerializationResultComparison
tillschallau Aug 15, 2024
a20064e
Change return type from single SerializableResult to List of Serializ…
tillschallau Aug 15, 2024
846c434
Add helper functions and tests
tillschallau Aug 16, 2024
178afe3
Add tests for SerializationHelpers.kt
tillschallau Aug 16, 2024
fb8deac
Update getSerializedResultsFromFolder functions
tillschallau Aug 16, 2024
0c46441
Change Path to File
tillschallau Aug 19, 2024
59cc1f0
Fix all
tillschallau Aug 19, 2024
aa706e0
[WIP]
dominikmaeckel Aug 19, 2024
ae5630e
[WIP]
dominikmaeckel Aug 19, 2024
065cb02
Only execute result comparison and writing when there are Serializabl…
tillschallau Aug 19, 2024
ad3bcb0
Remove test main.kt
tillschallau Aug 19, 2024
2cf816c
Fix SegmentCountMetricSerializationTest
tillschallau Aug 19, 2024
b7d1ada
Remove unused functions, fix SerializationHelpersTest and add KDoc
tillschallau Aug 19, 2024
247d0b5
Add missing KDoc for Serializable
tillschallau Aug 19, 2024
11b5833
Fix SerializationHelpersTest
tillschallau Aug 19, 2024
361ef6a
Remove unused files
tillschallau Aug 19, 2024
4eb6a0c
Add missing KDoc and replace "/ground-truth" and "/latest-evaluation"…
tillschallau Aug 19, 2024
79d9885
Add missing KDoc and remove unused functions
tillschallau Aug 19, 2024
1eda67a
Add KDoc and rename placeholder variables
tillschallau Aug 19, 2024
62d0ba8
Rename SerializableResultExtensions.kt to SerializableResultSourceMap…
tillschallau Aug 19, 2024
d223359
Add KDoc to SerializableResult and move extrude some functions as ext…
tillschallau Aug 19, 2024
fb0b69d
SpotlessApply
tillschallau Aug 19, 2024
db225fb
Add KDoc to SerializableResultComparison and move getJsonString() fun…
tillschallau Aug 19, 2024
776bbc8
Add KDoc to SerializableIntResult
tillschallau Aug 19, 2024
cece559
Add KDoc to SerializableResultComparisonVerdict
tillschallau Aug 19, 2024
3dc4bc5
Add KDoc to SerializationResultTest
tillschallau Aug 19, 2024
281edbc
Add KDoc to SerializableIntResultTest
tillschallau Aug 19, 2024
743220c
Add KDoc to SerializationResultExtensionsTest and remove unused tests
tillschallau Aug 19, 2024
1668eed
Update KDoc for SegmentCountMetric
tillschallau Aug 19, 2024
91e6a9c
Remove SerialVersionUIDInSerializableClass detekt rule as we have our…
tillschallau Aug 19, 2024
71feb19
Merge branch 'main' into 141-serializable-metrics
dominikmaeckel Aug 20, 2024
c5c0242
[WIP]
dominikmaeckel Aug 20, 2024
65656b2
Moved comparison verdict to TSCEvaluation.
dominikmaeckel Aug 20, 2024
32e8edd
Synchronized result fields.
dominikmaeckel Aug 20, 2024
f0d6fd4
Update reproduction-check-all.yml
dominikmaeckel Aug 20, 2024
6bd53e9
Update reproduction-check-all.yml
dominikmaeckel Aug 20, 2024
e37b7c2
Update reproduction-check.yml
dominikmaeckel Aug 20, 2024
8b6eedc
Update reproduction-check.yml
dominikmaeckel Aug 20, 2024
b9c873d
Renamed extension files.
dominikmaeckel Aug 20, 2024
df23726
Renamed extension files.
dominikmaeckel Aug 20, 2024
16e1120
Merge branch '141-serializable-metrics' of github.com:tudo-aqua/stars…
dominikmaeckel Aug 20, 2024
81b6536
trigger pipeline
tillschallau Aug 20, 2024
5115033
Add artifact saving.
dominikmaeckel Aug 22, 2024
291cda1
Add artifact saving.
dominikmaeckel Aug 22, 2024
78b9ffa
Add artifact saving.
dominikmaeckel Aug 22, 2024
68fc53b
Upgraded Gh actions.
dominikmaeckel Aug 22, 2024
0073528
Merge branch 'main' into 141-serializable-metrics
dominikmaeckel Aug 23, 2024
9506063
Merged main.
dominikmaeckel Aug 23, 2024
183acb9
Moved helper functions to companion objects of corresponding types.
dominikmaeckel Aug 23, 2024
f09de41
Removed file existence check.
dominikmaeckel Aug 23, 2024
78e515a
Added configurable ground-truth.
dominikmaeckel Aug 23, 2024
d4b6552
Fixed gradle config for reproduction.
dominikmaeckel Aug 23, 2024
944adce
Fixed gradle config for reproduction.
dominikmaeckel Aug 23, 2024
bcb5a6d
Merged reporduction workflow
dominikmaeckel Aug 26, 2024
c5daed7
Add reproduction runner.
dominikmaeckel Sep 27, 2024
8a89b32
Update analyze-build-deploy.yml
dominikmaeckel Sep 27, 2024
0304d56
Update analyze-build-deploy.yml
dominikmaeckel Sep 27, 2024
a1b5b03
Merge branch 'main' into 141-serializable-metrics
dominikmaeckel Sep 27, 2024
8cc382e
Update analyze-build-deploy.yml
dominikmaeckel Sep 27, 2024
138e0e0
Update analyze-build-deploy.yml
dominikmaeckel Sep 27, 2024
ef832a6
Update analyze-build-deploy.yml
dominikmaeckel Sep 27, 2024
2ae3ddc
Update analyze-build-deploy.yml
dominikmaeckel Sep 27, 2024
da5768d
WIP
dominikmaeckel Sep 27, 2024
c14ab1b
WIP
dominikmaeckel Sep 27, 2024
94a136f
WIP
dominikmaeckel Sep 27, 2024
759fd3e
WIP
dominikmaeckel Sep 27, 2024
0356000
Readded old checks to workflow.
dominikmaeckel Sep 27, 2024
e2b919a
Prettified PreSegmentEvaluationHook.evaluate().
dominikmaeckel Oct 1, 2024
5033924
Fixed memory leak.
dominikmaeckel Oct 1, 2024
2d03cf9
Update analyze-build-deploy.yml
dominikmaeckel Oct 2, 2024
8e03c88
Fix wording
tillschallau Oct 7, 2024
d1ecc1c
Changed minTicks to 11.
dominikmaeckel Oct 8, 2024
d2436e1
Added serializability to TotalSegmentTickDifferencePerIdentifierMetric.
dominikmaeckel Oct 8, 2024
4027e9f
Serializable TSC result [WIP]
dominikmaeckel Oct 9, 2024
62e580e
Added TSC serialization.
dominikmaeckel Oct 10, 2024
8b92375
Fixed tests.
dominikmaeckel Oct 10, 2024
fad6bdc
Fixed KDoc.
dominikmaeckel Oct 10, 2024
c347152
Merge branch 'main' into 141-serializable-metrics
dominikmaeckel Oct 22, 2024
c5e2412
Removed unused generic.
dominikmaeckel Oct 22, 2024
234210c
Clarify return type for getSerializedResults() for all serializable m…
tillschallau Oct 22, 2024
7d47d85
Add missing changes to CHANGELOG.md
tillschallau Oct 22, 2024
a8db0ff
Update files
tillschallau Oct 23, 2024
bf6836e
Added explicit type parameters in test.
dominikmaeckel Oct 24, 2024
969a980
Upgraded kotlin compiler version.
dominikmaeckel Oct 24, 2024
19d0cfb
SpotlessApply
tillschallau Oct 24, 2024
edb061f
Simplify generic parameters
tillschallau Oct 24, 2024
0050732
Add tests for valid/invalid TSC instances serialization comparison
tillschallau Oct 24, 2024
91c1659
Make MissedTSCInstancesPerTSCMetric serializable
tillschallau Oct 24, 2024
53cc93e
Add missing documentation
tillschallau Oct 24, 2024
bb35123
Add missing documentation
tillschallau Oct 24, 2024
dc0d108
Add specific Serializable result for MissedTSCInstancesPerTSCMetric.kt
tillschallau Oct 24, 2024
528b467
Clarify "must not" change
tillschallau Oct 24, 2024
ec7b443
Add exhaustive TSC test helper
tillschallau Oct 24, 2024
37e8f1b
Add more tests for metrics
tillschallau Oct 24, 2024
c143d48
Let MissedPredicateCombinationsPerTSCMetric.kt implement Serializable…
tillschallau Oct 24, 2024
c191ee0
Fix wording in docstring
tillschallau Oct 24, 2024
30dfbb1
Add TSC to SerializablePredicateCombinationResult
tillschallau Oct 24, 2024
553ca9b
Add serialization of FailedMonitorsMetric
tillschallau Oct 24, 2024
53c6a45
Update docstring
tillschallau Oct 24, 2024
1306fd1
Add test for SerializableFailedMonitorResult
tillschallau Oct 24, 2024
db19f32
Add missing documentation
tillschallau Oct 24, 2024
a8b115c
Add loggerIdentifier field to Loggable interface
tillschallau Oct 25, 2024
018a5bb
Rename evaluationResult to evaluationResultCache in MissedPredicateCo…
tillschallau Oct 25, 2024
dc4a329
Add loggerIdentifier field to missing Loggable classes
tillschallau Oct 25, 2024
9247b00
Add delegated segment count for each segment
tillschallau Oct 25, 2024
02330b1
Remove extension from source filename which is passed as SegmentSource
tillschallau Oct 25, 2024
1baa145
Rename segmentIdentifier to segmentSource
tillschallau Oct 25, 2024
bb14e75
Fix missing missedPredicateCombinations
tillschallau Oct 25, 2024
18e5a1b
Fix failing tests
tillschallau Oct 25, 2024
e84524e
Fix failing tests
tillschallau Oct 25, 2024
156ce77
Add count to serializable results, where Lists are present as value
tillschallau Oct 25, 2024
e16b57e
Rename ``ground-truth`` to ``baseline``
tillschallau Oct 29, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Change return type from single SerializableResult to List of Serializ…
…ableResults
  • Loading branch information
tillschallau committed Aug 15, 2024
commit a20064ef714c161e5e3336c23f2b7dcd0b259056
Original file line number Diff line number Diff line change
@@ -87,7 +87,7 @@
* @param writePlotDataCSV (Default: ``false``) Whether to write CSV files after the analysis.
* @throws IllegalArgumentException When there are no [MetricProvider]s registered.
*/
fun runEvaluation(

Check warning

Code scanning / detekt

KDoc comments should match the actual function or class signature Warning

Documentation of runEvaluation is outdated
writePlots: Boolean = true,
writePlotDataCSV: Boolean = false,
writeSerializedResults: Boolean = true
@@ -195,17 +195,19 @@
val pathToPreviousRun = getLatestSerializationResultPath()
if (pathToPreviousRun != null) {
metricProviders.filterIsInstance<Serializable>().forEach {
val resultComparison = it.compareResults(pathToPreviousRun)
saveAsJSONFile(resultComparison, false)
val resultComparisons = it.compareResults(pathToPreviousRun)
resultComparisons.forEach { resultComparison ->
saveAsJSONFile(resultComparison, false)
}
}
}

// Check that there is a ground truth run with recorded results
val pathToGroundTruthRun = getGroundTruthSerializationResultPath()
if (pathToGroundTruthRun != null) {
metricProviders.filterIsInstance<Serializable>().forEach {
val resultComparison = it.compareResults(pathToGroundTruthRun)
saveAsJSONFile(resultComparison, true)
val resultComparisons = it.compareResults(pathToGroundTruthRun)
resultComparisons.forEach { resultComparison -> saveAsJSONFile(resultComparison, true) }
}
}
}
Original file line number Diff line number Diff line change
@@ -71,6 +71,6 @@ class SegmentCountMetric<
logInfo("Analyzed $segmentCount Segments.")
}

override fun getSerializableResult(): SerializableIntResult =
SerializableIntResult(value = segmentCount, source = "SegmentCountMetric")
override fun getSerializableResults(): List<SerializableIntResult> =
listOf(SerializableIntResult(value = segmentCount, source = "SegmentCountMetric"))
}
Original file line number Diff line number Diff line change
@@ -24,30 +24,36 @@
import tools.aqua.stars.core.metric.utils.getSerializedResultFromFileSystem
import tools.aqua.stars.core.metric.utils.saveAsJSONFile

interface Serializable {

Check warning

Code scanning / detekt

Public classes, interfaces and objects require documentation. Warning

Serializable is missing required documentation.
fun getSerializableResult(): SerializableResult
fun getSerializableResults(): List<SerializableResult>

Check warning

Code scanning / detekt

Public functions require documentation. Warning

The function getSerializableResults is missing documentation.

fun compareTo(otherResult: SerializableResult): SerializableResultComparison {

Check warning

Code scanning / detekt

Public functions require documentation. Warning

The function compareTo is missing documentation.
val serializedResult = getSerializableResult()
if (serializedResult.javaClass.name != otherResult.javaClass.name) {
throw RuntimeException("These results cannot be compared")
val serializedResults = getSerializableResults()
serializedResults.forEach { serializedResult ->
if (serializedResult.javaClass.name != otherResult.javaClass.name) {
return@forEach
}
if (serializedResult.source != otherResult.source ||
serializedResult.identifier != otherResult.identifier) {
return@forEach
}
return SerializableResultComparison(
areEqual = serializedResult == otherResult,
identifier = serializedResult.identifier ?: DEFAULT_SERIALIZED_RESULT_IDENTIFIER,
source = serializedResult.source,
oldValue = otherResult.value.toString(),
newValue = serializedResult.value.toString())
}
return SerializableResultComparison(
areEqual = serializedResult == otherResult,
identifier = serializedResult.identifier ?: DEFAULT_SERIALIZED_RESULT_IDENTIFIER,
source = serializedResult.source,
oldValue = otherResult.value.toString(),
newValue = serializedResult.value.toString())
throw IllegalArgumentException("There were no results that were comparable.")
}

fun writeSerializedResults() {

Check warning

Code scanning / detekt

Public functions require documentation. Warning

The function writeSerializedResults is missing documentation.
saveAsJSONFile(getSerializableResult())
getSerializableResults().forEach { saveAsJSONFile(it) }
}

fun compareResults(resultFolderPath: Path): SerializableResultComparison {
val deserializedResult =
getSerializedResultFromFileSystem(resultFolderPath, getSerializableResult())

return compareTo(deserializedResult)
}
fun compareResults(resultFolderPath: Path): List<SerializableResultComparison> =

Check warning

Code scanning / detekt

Public functions require documentation. Warning

The function compareResults is missing documentation.
getSerializableResults().map {
val deserializedResult = getSerializedResultFromFileSystem(resultFolderPath, it)
compareTo(deserializedResult)
}
}
Original file line number Diff line number Diff line change
@@ -19,18 +19,16 @@

import kotlin.test.Test
import kotlin.test.assertEquals
import kotlin.test.assertNotEquals
import tools.aqua.stars.core.*
import tools.aqua.stars.core.metric.metrics.evaluation.SegmentCountMetric
import tools.aqua.stars.core.metric.utils.getGroundTruthSerializationResultPath
import tools.aqua.stars.core.metric.utils.getLatestSerializationResultPath
import tools.aqua.stars.core.metric.utils.getSerializedResultFromFileSystem
import tools.aqua.stars.core.metric.utils.saveAsJSONFile

class SerializableIntResultTest {

Check warning

Code scanning / detekt

Public classes, interfaces and objects require documentation. Warning test

SerializableIntResultTest is missing required documentation.
Fixed Show fixed Hide fixed

@Test
fun `Test simple serialization`() {

Check warning

Code scanning / detekt

Public functions require documentation. Warning test

The function Test simple serialization is missing documentation.
val simpleSegment1 = SimpleSegment()

val segmentCountMetric =
@@ -43,56 +41,47 @@

assertEquals(segmentCountMetric.evaluate(simpleSegment1), 1)
assertEquals(segmentCountMetric.evaluate(simpleSegment1), 2)
val serializedResult = segmentCountMetric.getSerializableResult()
val serializedResultJsonString = serializedResult.getJsonString()
segmentCountMetric.writeSerializedResults()

assertEquals(
segmentCountMetric.getSerializableResult(),
SerializableResult.getJsonContentFromString(serializedResultJsonString))

saveAsJSONFile(serializedResult)
var latestResultsPath = getLatestSerializationResultPath()
var groundTruthPath = getGroundTruthSerializationResultPath()
var s = ""

if (latestResultsPath != null) {
val deserializedResult =
getSerializedResultFromFileSystem(latestResultsPath, serializedResult)
val compared = segmentCountMetric.compareTo(deserializedResult)
saveAsJSONFile(compared, false)
// Check that there is a previous run with recorded results
val pathToPreviousRun = getLatestSerializationResultPath()
if (pathToPreviousRun != null) {
val resultComparisons = segmentCountMetric.compareResults(pathToPreviousRun)
resultComparisons.forEach { resultComparison -> saveAsJSONFile(resultComparison, false) }
}

if (groundTruthPath != null) {
val deserializedResult = getSerializedResultFromFileSystem(groundTruthPath, serializedResult)
val compared = segmentCountMetric.compareTo(deserializedResult)
saveAsJSONFile(compared, true)
// Check that there is a ground truth run with recorded results
val pathToGroundTruthRun = getGroundTruthSerializationResultPath()
if (pathToGroundTruthRun != null) {
val resultComparisons = segmentCountMetric.compareResults(pathToGroundTruthRun)
resultComparisons.forEach { resultComparison -> saveAsJSONFile(resultComparison, true) }
}
}

@Test
fun `Test changed result value`() {
val simpleSegment1 = SimpleSegment()

val segmentCountMetric =
SegmentCountMetric<
SimpleEntity,
SimpleTickData,
SimpleSegment,
SimpleTickDataUnit,
SimpleTickDataDifference>()

assertEquals(segmentCountMetric.evaluate(simpleSegment1), 1)
val serializedResultGroundTruthJsonString =
segmentCountMetric.getSerializableResult().getJsonString()
val deserializedResultGroundTruth =
SerializableResult.getJsonContentFromString(serializedResultGroundTruthJsonString)

assertEquals(segmentCountMetric.evaluate(simpleSegment1), 2)
val serializedResultCompareJsonString =
segmentCountMetric.getSerializableResult().getJsonString()
val deserializedResultCompare =
SerializableResult.getJsonContentFromString(serializedResultCompareJsonString)

assertNotEquals(deserializedResultGroundTruth, deserializedResultCompare)
}
// @Test
// fun `Test changed result value`() {
// val simpleSegment1 = SimpleSegment()
//
// val segmentCountMetric =
// SegmentCountMetric<
// SimpleEntity,
// SimpleTickData,
// SimpleSegment,
// SimpleTickDataUnit,
// SimpleTickDataDifference>()
//
// assertEquals(segmentCountMetric.evaluate(simpleSegment1), 1)
// val serializedResultGroundTruthJsonString =
// segmentCountMetric.getSerializableResults().getJsonString()
// val deserializedResultGroundTruth =
// SerializableResult.getJsonContentFromString(serializedResultGroundTruthJsonString)
//
// assertEquals(segmentCountMetric.evaluate(simpleSegment1), 2)
// val serializedResultCompareJsonString =
// segmentCountMetric.getSerializableResults().getJsonString()
// val deserializedResultCompare =
// SerializableResult.getJsonContentFromString(serializedResultCompareJsonString)
//
// assertNotEquals(deserializedResultGroundTruth, deserializedResultCompare)
// }
}
Original file line number Diff line number Diff line change
@@ -22,62 +22,65 @@
import org.junit.jupiter.api.assertDoesNotThrow
import tools.aqua.stars.core.metric.providers.Serializable

class SerializableListResultTest {

Check warning

Code scanning / detekt

Public classes, interfaces and objects require documentation. Warning test

SerializableListResultTest is missing required documentation.

// region Test of simple serializable list
@Test
fun `Test serialization of explicitly typed list of type 'Int' with values`() {

Check warning

Code scanning / detekt

Public functions require documentation. Warning test

The function Test serialization of explicitly typed list of type 'Int' with values is missing documentation.

Check warning

Code scanning / detekt

Function names should follow the naming convention set in the configuration. Warning test

Function names should match the pattern: ([a-z][a-zA-Z0-9]*)|(`[a-zA-Z0-9 ,.-(){}#]+`)
val simpleObject = IntListClass(listOf(2, 3))
val simpleObjectResult = simpleObject.getSerializableResult()
val simpleObjectResult = simpleObject.getSerializableResults()

assertEquals(2, simpleObject.stateList.size)
assertDoesNotThrow { simpleObjectResult.getJsonString() }
assertDoesNotThrow { simpleObject.writeSerializedResults() }

val serializedResult = simpleObjectResult.getJsonString()
val deserializedResult = SerializableResult.getJsonContentFromString(serializedResult)
val serializedResult = simpleObjectResult.map { it.getJsonString() }
val deserializedResult =
serializedResult.map { SerializableResult.getJsonContentFromString(it) }

assertEquals(simpleObjectResult, deserializedResult)
}

@Test
fun `Test serialization of explicitly typed list of type 'Int' with no values`() {

Check warning

Code scanning / detekt

Public functions require documentation. Warning test

The function Test serialization of explicitly typed list of type 'Int' with no values is missing documentation.

Check warning

Code scanning / detekt

Function names should follow the naming convention set in the configuration. Warning test

Function names should match the pattern: ([a-z][a-zA-Z0-9]*)|(`[a-zA-Z0-9 ,.-(){}#]+`)
val simpleObject = IntListClass(emptyList())
val simpleObjectResult = simpleObject.getSerializableResult()
val simpleObjectResult = simpleObject.getSerializableResults()

assertEquals(0, simpleObject.stateList.size)
assertDoesNotThrow { simpleObjectResult.getJsonString() }
assertDoesNotThrow { simpleObject.writeSerializedResults() }

val serializedResult = simpleObjectResult.getJsonString()
val deserializedResult = SerializableResult.getJsonContentFromString(serializedResult)
val serializedResult = simpleObjectResult.map { it.getJsonString() }
val deserializedResult =
serializedResult.map { SerializableResult.getJsonContentFromString(it) }

assertEquals(simpleObjectResult, deserializedResult)
}

private inner class IntListClass(val stateList: List<Int>) : Serializable {

Check warning

Code scanning / detekt

A class which implements the Serializable interface does not define a correct serialVersionUID field. The serialVersionUID field should be a private constant long value inside a companion object. Warning test

The class IntListClass implements the Serializable interface and should thus define a serialVersionUID.
override fun getSerializableResult(): SerializableIntListResult =
SerializableIntListResult(stateList, source = "IntListClass")
override fun getSerializableResults(): List<SerializableIntListResult> =
listOf(SerializableIntListResult(stateList, source = "IntListClass"))
}

// endregion

// region Test of simple nested kotlin datastructures in serializable list
@Test
fun `Test serialization of list of pairs of two Int values`() {

Check warning

Code scanning / detekt

Public functions require documentation. Warning test

The function Test serialization of list of pairs of two Int values is missing documentation.
val simpleObject = IntPairClass(listOf(2 to 3, 3 to 4))
val simpleObjectResult = simpleObject.getSerializableResult()
val simpleObjectResult = simpleObject.getSerializableResults()

assertEquals(2, simpleObject.stateList.size)
assertDoesNotThrow { simpleObjectResult.getJsonString() }
assertDoesNotThrow { simpleObject.writeSerializedResults() }

val serializedResult = simpleObjectResult.getJsonString()
val deserializedResult = SerializableResult.getJsonContentFromString(serializedResult)
val serializedResult = simpleObjectResult.map { it.getJsonString() }
val deserializedResult =
serializedResult.map { SerializableResult.getJsonContentFromString(it) }

assertEquals(simpleObjectResult, deserializedResult)
}

private inner class IntPairClass(val stateList: List<Pair<Int, Int>>) : Serializable {

Check warning

Code scanning / detekt

A class which implements the Serializable interface does not define a correct serialVersionUID field. The serialVersionUID field should be a private constant long value inside a companion object. Warning test

The class IntPairClass implements the Serializable interface and should thus define a serialVersionUID.
override fun getSerializableResult(): SerializableIntPairListResult =
SerializableIntPairListResult(stateList, source = "IntPairClass")
override fun getSerializableResults(): List<SerializableIntPairListResult> =
listOf(SerializableIntPairListResult(stateList, source = "IntPairClass"))
}

// endregion
Loading