diff --git a/save-backend/src/main/kotlin/com/saveourtool/save/backend/service/TestExecutionService.kt b/save-backend/src/main/kotlin/com/saveourtool/save/backend/service/TestExecutionService.kt index d566b7a2fa..2be79cb1a0 100644 --- a/save-backend/src/main/kotlin/com/saveourtool/save/backend/service/TestExecutionService.kt +++ b/save-backend/src/main/kotlin/com/saveourtool/save/backend/service/TestExecutionService.kt @@ -6,6 +6,7 @@ import com.saveourtool.save.backend.repository.ExecutionRepository import com.saveourtool.save.backend.repository.TestExecutionRepository import com.saveourtool.save.backend.repository.TestRepository import com.saveourtool.save.backend.utils.secondsToLocalDateTime +import com.saveourtool.save.core.result.CountWarnings import com.saveourtool.save.domain.TestResultLocation import com.saveourtool.save.domain.TestResultStatus import com.saveourtool.save.entities.Execution @@ -166,10 +167,11 @@ class TestExecutionService(private val testExecutionRepository: TestExecutionRep "LongMethod", "MAGIC_NUMBER", "MagicNumber", + "PARAMETER_NAME_IN_OUTER_LAMBDA", ) @Transactional fun saveTestResult(testExecutionsDtos: List): List { - log.debug("Saving ${testExecutionsDtos.size} test results from agent ${testExecutionsDtos.first().agentContainerId}") + log.debug { "Saving ${testExecutionsDtos.size} test results from agent ${testExecutionsDtos.first().agentContainerId}" } // we take agent id only from first element, because all test executions have same execution val agentContainerId = requireNotNull(testExecutionsDtos.first().agentContainerId) { "Attempt to save test results without assigned agent. testExecutionDtos=$testExecutionsDtos" @@ -211,10 +213,12 @@ class TestExecutionService(private val testExecutionRepository: TestExecutionRep it.expected = testExecDto.expected it.unexpected = testExecDto.unexpected - counters.unmatchedChecks += testExecDto.unmatched ?: 0L - counters.matchedChecks += testExecDto.matched ?: 0L - counters.expectedChecks += testExecDto.expected ?: 0L - counters.unexpectedChecks += testExecDto.unexpected ?: 0L + with(counters) { + unmatchedChecks += testExecDto.unmatched.orZeroIfNotApplicable() + matchedChecks += testExecDto.matched.orZeroIfNotApplicable() + expectedChecks += testExecDto.expected.orZeroIfNotApplicable() + unexpectedChecks += testExecDto.unexpected.orZeroIfNotApplicable() + } testExecutionRepository.save(it) }, @@ -228,9 +232,10 @@ class TestExecutionService(private val testExecutionRepository: TestExecutionRep transactionTemplate.execute { val execution = executionRepository.findById(executionId).get() execution.apply { - log.debug("Updating counters in execution id=$executionId: running=$runningTests-${counters.total()}, " + - "passed=$passedTests+${counters.passed}, failed=$failedTests+${counters.failed}, skipped=$skippedTests+${counters.skipped}" - ) + log.debug { + "Updating counters in execution id=$executionId: running=$runningTests-${counters.total()}, " + + "passed=$passedTests+${counters.passed}, failed=$failedTests+${counters.failed}, skipped=$skippedTests+${counters.skipped}" + } runningTests -= counters.total() passedTests += counters.passed failedTests += counters.failed @@ -351,6 +356,8 @@ class TestExecutionService(private val testExecutionRepository: TestExecutionRep } } + private fun Long?.orZeroIfNotApplicable() = this?.takeUnless { CountWarnings.isNotApplicable(it.toInt()) } ?: 0 + @Suppress( "KDOC_NO_CONSTRUCTOR_PROPERTY", "MISSING_KDOC_ON_FUNCTION", diff --git a/save-frontend/src/main/kotlin/com/saveourtool/save/frontend/components/basic/ExecutionLabels.kt b/save-frontend/src/main/kotlin/com/saveourtool/save/frontend/components/basic/ExecutionLabels.kt index f75288434e..17432f95b3 100644 --- a/save-frontend/src/main/kotlin/com/saveourtool/save/frontend/components/basic/ExecutionLabels.kt +++ b/save-frontend/src/main/kotlin/com/saveourtool/save/frontend/components/basic/ExecutionLabels.kt @@ -7,7 +7,6 @@ package com.saveourtool.save.frontend.components.basic -import com.saveourtool.save.core.result.CountWarnings import com.saveourtool.save.execution.ExecutionDto import com.saveourtool.save.execution.ExecutionStatus import com.saveourtool.save.frontend.externals.fontawesome.faRedo @@ -101,25 +100,15 @@ internal class ExecutionStatisticsValues(executionDto: ExecutionDto?) { ?: "0" this.precisionRate = executionDto ?.let { - if (isAllApplicable(it.matchedChecks, it.unexpectedChecks)) { - "${it.getPrecisionRate()}" - } else { - "N/A" - } + "${it.getPrecisionRate()}" } ?: "0" this.recallRate = executionDto ?.let { - if (isAllApplicable(it.matchedChecks, it.unmatchedChecks)) { - "${it.getRecallRate()}" - } else { - "N/A" - } + "${it.getRecallRate()}" } ?: "0" } - - private fun isAllApplicable(vararg values: Long): Boolean = values.all { !CountWarnings.isNotApplicable(it.toInt()) } } /**