Skip to content

Commit

Permalink
Merge pull request #1693 from DataDog/nogorodnikov/rum-2104/memory-an…
Browse files Browse the repository at this point in the history
…d-cpu-info-is-not-sent

RUM-2104: Fix the issue of missing cpu/memory info with RUM view events
  • Loading branch information
0xnm authored Nov 10, 2023
2 parents b6112d9 + 022c8f7 commit 8671830
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ package com.datadog.android.rum.internal.vitals
import com.datadog.android.api.feature.Feature
import com.datadog.android.api.feature.FeatureSdkCore
import com.datadog.android.core.internal.utils.scheduleSafe
import com.datadog.android.rum.internal.domain.RumContext
import com.datadog.android.rum.internal.domain.scope.RumViewScope
import java.util.concurrent.ScheduledExecutorService
import java.util.concurrent.TimeUnit
Expand All @@ -22,8 +23,9 @@ internal class VitalReaderRunnable(
) : Runnable {

override fun run() {
val rumContext = sdkCore.getFeatureContext(Feature.RUM_FEATURE_NAME)
val rumViewType = rumContext["view_type"] as? RumViewScope.RumViewType
val rumContext =
RumContext.fromFeatureContext(sdkCore.getFeatureContext(Feature.RUM_FEATURE_NAME))
val rumViewType = rumContext.viewType
if (rumViewType == RumViewScope.RumViewType.FOREGROUND) {
val data = reader.readVitalData()
if (data != null) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,11 @@ package com.datadog.android.rum.internal.vitals
import com.datadog.android.api.InternalLogger
import com.datadog.android.api.feature.Feature
import com.datadog.android.api.feature.FeatureSdkCore
import com.datadog.android.rum.internal.domain.RumContext
import com.datadog.android.rum.internal.domain.scope.RumViewScope
import com.datadog.android.rum.utils.forge.Configurator
import com.datadog.android.rum.utils.verifyLog
import fr.xgouchet.elmyr.Forge
import fr.xgouchet.elmyr.annotation.DoubleForgery
import fr.xgouchet.elmyr.junit5.ForgeConfiguration
import fr.xgouchet.elmyr.junit5.ForgeExtension
Expand Down Expand Up @@ -46,7 +48,7 @@ import java.util.concurrent.TimeUnit
@ForgeConfiguration(Configurator::class)
internal class VitalReaderRunnableTest {

lateinit var testedRunnable: VitalReaderRunnable
private lateinit var testedRunnable: VitalReaderRunnable

@Mock
lateinit var mockReader: VitalReader
Expand All @@ -67,10 +69,9 @@ internal class VitalReaderRunnableTest {
var fakeValue: Double = 0.0

@BeforeEach
fun `set up`() {
val rumContext = mapOf<String, Any?>(
"view_type" to RumViewScope.RumViewType.FOREGROUND
)
fun `set up`(forge: Forge) {
val rumContext = forge.getForgery<RumContext>()
.copy(viewType = RumViewScope.RumViewType.FOREGROUND).toMap()
whenever(mockSdkCore.getFeatureContext(Feature.RUM_FEATURE_NAME)) doReturn rumContext
whenever(mockSdkCore.internalLogger) doReturn mockInternalLogger
testedRunnable = VitalReaderRunnable(
Expand Down Expand Up @@ -104,12 +105,12 @@ internal class VitalReaderRunnableTest {
mode = EnumSource.Mode.EXCLUDE
)
fun `𝕄 not read data, not notify observer but schedule 𝕎 run { viewType != FOREGROUND }()`(
viewType: RumViewScope.RumViewType
viewType: RumViewScope.RumViewType,
forge: Forge
) {
// Given
val rumContext = mapOf<String, Any?>(
"view_type" to viewType
)
val rumContext = forge.getForgery<RumContext>()
.copy(viewType = viewType).toMap()
whenever(mockSdkCore.getFeatureContext(Feature.RUM_FEATURE_NAME)) doReturn rumContext

// When
Expand Down

0 comments on commit 8671830

Please sign in to comment.