Skip to content

Commit

Permalink
Remove SdkApi and merge functionality into EmbraceInternalInterface
Browse files Browse the repository at this point in the history
  • Loading branch information
bidetofevil committed Oct 24, 2023
1 parent 16a61f8 commit 924a37b
Show file tree
Hide file tree
Showing 12 changed files with 54 additions and 98 deletions.
4 changes: 1 addition & 3 deletions embrace-android-sdk/api/embrace-android-sdk.api
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,6 @@ public final class io/embrace/android/embracesdk/Embrace : io/embrace/android/em
public fun getInternalInterface ()Lio/embrace/android/embracesdk/internal/EmbraceInternalInterface;
public fun getLastRunEndState ()Lio/embrace/android/embracesdk/Embrace$LastRunEndState;
public fun getReactNativeInternalInterface ()Lio/embrace/android/embracesdk/ReactNativeInternalInterface;
public fun getSdkApi ()Lio/embrace/android/embracesdk/internal/SdkApi;
public fun getSessionProperties ()Ljava/util/Map;
public fun getTraceIdHeader ()Ljava/lang/String;
public fun getUnityInternalInterface ()Lio/embrace/android/embracesdk/UnityInternalInterface;
Expand Down Expand Up @@ -178,9 +177,8 @@ public final class io/embrace/android/embracesdk/WebViewClientSwazzledHooks {
public abstract interface annotation class io/embrace/android/embracesdk/annotation/StartupActivity : java/lang/annotation/Annotation {
}

public abstract interface class io/embrace/android/embracesdk/internal/SdkApi {
public abstract fun getSdkCurrentTime ()J
public abstract interface class io/embrace/android/embracesdk/internal/EmbraceInternalInterface {
public abstract fun getSdkCurrentTime ()J
public abstract fun isNetworkSpanForwardingEnabled ()Z
public abstract fun logComposeTap (Landroid/util/Pair;Ljava/lang/String;)V
public abstract fun logError (Ljava/lang/String;Ljava/util/Map;Ljava/lang/String;Z)V
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,7 @@ internal class EmbraceInternalInterfaceTest {
assertFalse(shouldCaptureNetworkBody("", ""))
setProcessStartedByNotification()
assertFalse(isNetworkSpanForwardingEnabled())
getSdkCurrentTime()
}
}

Expand Down Expand Up @@ -241,6 +242,16 @@ internal class EmbraceInternalInterfaceTest {
}
}

@Test
fun `test sdk time`() {
with(testRule) {
embrace.start(harness.fakeCoreModule.context)
assertEquals(harness.fakeClock.now(), embrace.internalInterface.getSdkCurrentTime())
harness.fakeClock.tick()
assertEquals(harness.fakeClock.now(), embrace.internalInterface.getSdkCurrentTime())
}
}

companion object {
private const val URL = "https://embrace.io"
private const val START_TIME = 1692201601L
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@

import io.embrace.android.embracesdk.config.ConfigService;
import io.embrace.android.embracesdk.internal.EmbraceInternalInterface;
import io.embrace.android.embracesdk.internal.SdkApi;
import io.embrace.android.embracesdk.logging.InternalEmbraceLogger;
import io.embrace.android.embracesdk.logging.InternalStaticEmbraceLogger;
import io.embrace.android.embracesdk.network.EmbraceNetworkRequest;
Expand Down Expand Up @@ -738,12 +737,6 @@ public int getValue() {
}
}

@NonNull
@InternalApi
public SdkApi getSdkApi() {
return impl.getSdkApi();
}

/**
* Enum representing the end state of the last run of the application.
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -65,8 +65,6 @@
import io.embrace.android.embracesdk.internal.EmbraceInternalInterface;
import io.embrace.android.embracesdk.internal.EmbraceInternalInterfaceKt;
import io.embrace.android.embracesdk.internal.MessageType;
import io.embrace.android.embracesdk.internal.SdkApi;
import io.embrace.android.embracesdk.internal.SdkApiKt;
import io.embrace.android.embracesdk.internal.TraceparentGenerator;
import io.embrace.android.embracesdk.internal.crash.LastRunCrashVerifier;
import io.embrace.android.embracesdk.internal.spans.EmbraceSpansService;
Expand Down Expand Up @@ -225,9 +223,6 @@ final class EmbraceImpl {
@Nullable
private FlutterInternalInterface flutterInternalInterface;

@Nullable
private SdkApi sdkApi;

@Nullable
private PushNotificationCaptureService pushNotificationService;

Expand Down Expand Up @@ -1747,14 +1742,4 @@ private void loadCrashVerifier(CrashModule crashModule, WorkerThreadModule worke
workerThreadModule.backgroundExecutor(ExecutorName.BACKGROUND_REGISTRATION)
);
}

@InternalApi
@NonNull
public SdkApi getSdkApi() {
if (isStarted() && sdkApi != null) {
return sdkApi;
} else {
return SdkApiKt.getDefault();
}
}
}
Original file line number Diff line number Diff line change
@@ -1,14 +1,16 @@
package io.embrace.android.embracesdk

import android.util.Pair
import io.embrace.android.embracesdk.injection.InitModule
import io.embrace.android.embracesdk.internal.EmbraceInternalInterface
import io.embrace.android.embracesdk.network.EmbraceNetworkRequest
import io.embrace.android.embracesdk.network.http.HttpMethod
import io.embrace.android.embracesdk.network.http.NetworkCaptureData
import io.embrace.android.embracesdk.payload.TapBreadcrumb

internal class EmbraceInternalInterfaceImpl(
private val embraceImpl: EmbraceImpl
private val embraceImpl: EmbraceImpl,
private val initModule: InitModule
) : EmbraceInternalInterface {

override fun logInfo(message: String, properties: Map<String, Any>?) {
Expand Down Expand Up @@ -173,4 +175,6 @@ internal class EmbraceInternalInterfaceImpl(
override fun isNetworkSpanForwardingEnabled(): Boolean {
return embraceImpl.configService?.networkSpanForwardingBehavior?.isNetworkSpanForwardingEnabled() ?: false
}

override fun getSdkCurrentTime(): Long = initModule.clock.now()
}
Original file line number Diff line number Diff line change
Expand Up @@ -7,15 +7,12 @@ import io.embrace.android.embracesdk.injection.EssentialServiceModule
import io.embrace.android.embracesdk.injection.InitModule
import io.embrace.android.embracesdk.injection.singleton
import io.embrace.android.embracesdk.internal.EmbraceInternalInterface
import io.embrace.android.embracesdk.internal.SdkApi
import io.embrace.android.embracesdk.internal.SdkApiImpl

internal interface InternalInterfaceModule {
val embraceInternalInterface: EmbraceInternalInterface
val reactNativeInternalInterface: ReactNativeInternalInterface
val unityInternalInterface: UnityInternalInterface
val flutterInternalInterface: FlutterInternalInterface
val sdkApi: SdkApi
}

internal class InternalInterfaceModuleImpl(
Expand All @@ -28,7 +25,7 @@ internal class InternalInterfaceModuleImpl(
) : InternalInterfaceModule {

override val embraceInternalInterface: EmbraceInternalInterface by singleton {
EmbraceInternalInterfaceImpl(embrace)
EmbraceInternalInterfaceImpl(embrace, initModule)
}

override val reactNativeInternalInterface: ReactNativeInternalInterface by singleton {
Expand Down Expand Up @@ -60,8 +57,4 @@ internal class InternalInterfaceModuleImpl(
coreModule.logger
)
}

override val sdkApi: SdkApi by singleton {
SdkApiImpl(initModule.clock)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -126,6 +126,12 @@ public interface EmbraceInternalInterface {
* Whether the Network Span Forwarding feature is enabled
*/
public fun isNetworkSpanForwardingEnabled(): Boolean

/**
* Return internal time the SDK is using in milliseconds. It is equivalent to [System.currentTimeMillis] assuming the system clock did
* not change after the SDK has started.
*/
public fun getSdkCurrentTime(): Long
}

internal val defaultImpl = object : EmbraceInternalInterface {
Expand Down Expand Up @@ -185,4 +191,6 @@ internal val defaultImpl = object : EmbraceInternalInterface {
override fun setProcessStartedByNotification() { }

override fun isNetworkSpanForwardingEnabled(): Boolean = false

override fun getSdkCurrentTime(): Long = System.currentTimeMillis()
}

This file was deleted.

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,10 @@ package io.embrace.android.embracesdk

import android.net.Uri
import android.webkit.URLUtil
import io.embrace.android.embracesdk.fakes.FakeClock
import io.embrace.android.embracesdk.fakes.injection.FakeInitModule
import io.embrace.android.embracesdk.injection.InitModule
import io.embrace.android.embracesdk.internal.defaultImpl
import io.embrace.android.embracesdk.network.EmbraceNetworkRequest
import io.embrace.android.embracesdk.network.http.HttpMethod
import io.mockk.every
Expand All @@ -11,18 +15,23 @@ import io.mockk.slot
import io.mockk.verify
import org.junit.Assert.assertEquals
import org.junit.Assert.assertNull
import org.junit.Assert.assertTrue
import org.junit.Before
import org.junit.Test

internal class EmbraceInternalInterfaceImplTest {

private lateinit var impl: EmbraceInternalInterfaceImpl
private lateinit var embrace: EmbraceImpl
private lateinit var fakeClock: FakeClock
private lateinit var initModule: InitModule

@Before
fun setUp() {
embrace = mockk(relaxed = true)
impl = EmbraceInternalInterfaceImpl(embrace)
fakeClock = FakeClock(currentTime = beforeObjectInitTime)
initModule = FakeInitModule(clock = fakeClock)
impl = EmbraceInternalInterfaceImpl(embrace, initModule)
}

@Test
Expand Down Expand Up @@ -176,4 +185,22 @@ internal class EmbraceInternalInterfaceImplTest {

assertEquals(url, captor.captured.url)
}

@Test
fun `check usage of SDK time`() {
assertEquals(beforeObjectInitTime, impl.getSdkCurrentTime())
assertTrue(impl.getSdkCurrentTime() < System.currentTimeMillis())
fakeClock.tick(10L)
assertEquals(fakeClock.now(), impl.getSdkCurrentTime())
}

@Test
fun `check default implementation`() {
assertTrue(beforeObjectInitTime < defaultImpl.getSdkCurrentTime())
assertTrue(defaultImpl.getSdkCurrentTime() <= System.currentTimeMillis())
}

companion object {
val beforeObjectInitTime = System.currentTimeMillis() - 1
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,5 @@ internal class InternalInterfaceModuleImplTest {
assertNotNull(module.unityInternalInterface)
assertNotNull(module.reactNativeInternalInterface)
assertNotNull(module.embraceInternalInterface)
assertNotNull(module.sdkApi)
}
}

This file was deleted.

0 comments on commit 924a37b

Please sign in to comment.