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

Technical Analytics: Milestone 2 - Add Ability To Log Feature Flags #5240

Merged
merged 119 commits into from
Jun 17, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
119 commits
Select commit Hold shift + click to select a range
3fee528
feat: Add a FeatureFlagConstants file to host feature flags
kkmurerwa Oct 18, 2023
9c09fbf
feat: Add constant names for easy retrieval of the feature flags from…
kkmurerwa Oct 18, 2023
b0d1572
feat: Add newly status flags to the Platform Parameter dependency mod…
kkmurerwa Oct 18, 2023
7e13530
feat: Add ability to insert sync statuses to the cache store
kkmurerwa Oct 20, 2023
6c06ea5
feat: Add ability to save flag statuses for every feature flag
kkmurerwa Oct 23, 2023
5e26d8e
Merge branch 'oppia:develop' into technical-analytics-milestone-1
kkmurerwa Oct 23, 2023
1f0fa64
fix: Fix linting and styling checks
kkmurerwa Oct 23, 2023
f4f5ff2
Merge branch 'develop' into technical-analytics-milestone-1
kkmurerwa Oct 24, 2023
795e90c
fix: Fix comments made on the previous review
kkmurerwa Oct 26, 2023
dd5c5b2
Merge branch 'develop' into technical-analytics-milestone-1
kkmurerwa Oct 26, 2023
da852b4
Merge branch 'develop' into technical-analytics-milestone-1
kkmurerwa Oct 29, 2023
9da1607
fix: Fix nit
kkmurerwa Oct 29, 2023
0c0cd75
Merge branch 'develop' into technical-analytics-milestone-1
kkmurerwa Oct 30, 2023
4dae83c
fix: Fix lint issues causing build failure
kkmurerwa Oct 30, 2023
81d968b
fix: Move test sync status flag booleans to the TestBooleanPlatformPa…
kkmurerwa Oct 30, 2023
d8f14bd
chore: Move all test constants from individual type-organized files t…
kkmurerwa Nov 1, 2023
7918da5
Merge branch 'develop' into technical-analytics-milestone-1
kkmurerwa Nov 1, 2023
7bcbdcf
fix: Fix failing text file checks
kkmurerwa Nov 1, 2023
ed2b7ac
Merge branch 'technical-analytics-milestone-1' of github.com:kkmurerw…
kkmurerwa Nov 1, 2023
5638b31
Merge branch 'develop' into technical-analytics-milestone-1
kkmurerwa Nov 1, 2023
a1846ce
Merge branch 'develop' into technical-analytics-milestone-1
kkmurerwa Nov 6, 2023
b49df60
feat: Add a isSynced variable in the platform parameter variable to s…
kkmurerwa Nov 7, 2023
7ee1fd8
fix: Fix failing EventBundleCreator tests
kkmurerwa Nov 7, 2023
b9f28ba
feat: Make Sync status an enum
kkmurerwa Nov 14, 2023
c0338b0
Merge branch 'develop' into technical-analytics-milestone-1
kkmurerwa Nov 14, 2023
501ae40
feat: Add feature flag names to all flags lacking one
kkmurerwa Nov 14, 2023
91c526d
Merge branch 'technical-analytics-milestone-1' of github.com:kkmurerw…
kkmurerwa Nov 14, 2023
551fd4a
fix: Fix failing check and linting issue
kkmurerwa Nov 15, 2023
e6d748f
Merge branch 'develop' into technical-analytics-milestone-1
kkmurerwa Nov 15, 2023
3b19e3f
merge: Merge from develop and fix conflicts
kkmurerwa Nov 17, 2023
df983b9
chore: Remove unused feature flag
kkmurerwa Nov 17, 2023
d3ca9d0
Merge branch 'develop' into technical-analytics-milestone-1
kkmurerwa Nov 21, 2023
a5dbf3a
feat: Add ability to log feature flag statuses
kkmurerwa Nov 21, 2023
e93ff75
feat: Add tests for the FeatureFlagLogger
kkmurerwa Nov 21, 2023
8ae088c
feat: add a feature flag test
kkmurerwa Nov 22, 2023
2b7aad4
fix: Fix bazel build issues
kkmurerwa Nov 22, 2023
fd81350
fix: Fix failing tests
kkmurerwa Nov 22, 2023
4de5981
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Nov 22, 2023
493d4c1
fix: Fix minor linting issues
kkmurerwa Nov 24, 2023
f8f0062
Merge branch 'technical-analytics-milestone-2' of github.com:kkmurerw…
kkmurerwa Nov 24, 2023
574fda3
feat: Merge from develop
kkmurerwa Nov 30, 2023
989a915
feat: Fix changes suggested in the self-review
kkmurerwa Nov 30, 2023
cc6f1d0
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Dec 3, 2023
f3fe5a0
fix: Make some of the suggested changes from preliminary review
kkmurerwa Dec 3, 2023
8825a38
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Dec 5, 2023
99295f6
feat: Modify the approach used to compile feature flags for logging
kkmurerwa Dec 5, 2023
a688839
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Dec 6, 2023
154bd42
feat: Make changes requested by Adhiambo
kkmurerwa Dec 6, 2023
4d830ac
Merge from develop
kkmurerwa Dec 6, 2023
42a56d3
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Dec 6, 2023
9e8754f
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Dec 8, 2023
2440c53
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Dec 16, 2023
79b3527
fix: Make latest requested changes
kkmurerwa Dec 18, 2023
c17dab5
feat: Made some changes to the feature flag tests
kkmurerwa Dec 20, 2023
758135a
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Dec 20, 2023
77a3d29
fix: Fix failing kdoc validation checks
kkmurerwa Dec 20, 2023
cbb3b28
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Dec 21, 2023
f40e9ca
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Dec 23, 2023
829f7df
merge: Merge changes from develop
kkmurerwa Jan 4, 2024
ed41b4a
merge: Fix lint issues from merging changes
kkmurerwa Jan 4, 2024
4ddda14
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Jan 11, 2024
31a26ea
feat: Make suggested changes
kkmurerwa Jan 11, 2024
d0d359e
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Jan 15, 2024
a6f915d
fix: Make changes and fixes requested after review
kkmurerwa Jan 17, 2024
4ed581c
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Jan 23, 2024
5151a2e
feat: Merge from develop
kkmurerwa Jan 26, 2024
178d8b5
feat: Move feature_flag_item_context from feature_flag_context
kkmurerwa Jan 26, 2024
9b1f82f
fix: Fix linting issues
kkmurerwa Jan 26, 2024
0515950
fix: Fix failing build and tests
kkmurerwa Jan 26, 2024
c63f5b5
feat: Change how FeatureFlagItemContextSubject tests are run
kkmurerwa Jan 26, 2024
4efc186
merge changes from develop
kkmurerwa Jan 29, 2024
e76f813
chore: Fix nits and make changes requested in latest review
kkmurerwa Jan 29, 2024
352e7d7
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Feb 1, 2024
b98dd13
fix: Make changes requested in review
kkmurerwa Feb 3, 2024
e25a47c
Merge from develop
kkmurerwa Feb 9, 2024
0ac776b
fix: Fix failing build from merge
kkmurerwa Feb 9, 2024
58ce67d
fix: Fix failing build from merge
kkmurerwa Feb 9, 2024
fcb05dd
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Feb 13, 2024
bf3605a
feat: Modify the feature flag context into a list of properties
kkmurerwa Feb 14, 2024
35e4467
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Feb 15, 2024
a935022
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Feb 20, 2024
5ce5241
feat: Add tests to check if all feature flags were logged and improve…
kkmurerwa Feb 26, 2024
e01e250
fix: Fix lint issues
kkmurerwa Feb 26, 2024
12da7d7
merge from develop
kkmurerwa Feb 26, 2024
ad4872b
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Feb 27, 2024
a3176a1
fix: Fix failing bazel test
kkmurerwa Feb 27, 2024
9485d78
chore: Add TODO comment for future reference
kkmurerwa Feb 29, 2024
033e92a
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Mar 6, 2024
34cade6
chore: rename sessionId to appSessionId
kkmurerwa Mar 6, 2024
5dead31
feat: Add application session id and add it to the feature flags logger
kkmurerwa Mar 6, 2024
af6a3b2
fix: Fix lint issues
kkmurerwa Mar 6, 2024
ad28181
fix: Fix failing tests
kkmurerwa Mar 6, 2024
4749c39
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Mar 13, 2024
3e87141
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Mar 25, 2024
e8503b7
feat: Add tests for the appSessionId and the user UUID
kkmurerwa Apr 1, 2024
6d20011
merge from develop
kkmurerwa Apr 14, 2024
46d5484
test: Add parameterized test for FeatureFlagsLoggerTest
kkmurerwa Apr 14, 2024
4f03d9a
fix: Fix failing parameterized tests and checks
kkmurerwa Apr 14, 2024
97dcc02
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Apr 23, 2024
5f1af8d
chore: Make changes made in last review.
kkmurerwa May 1, 2024
3fa23aa
chore: Add test to ensure app session id changes on each request.
kkmurerwa May 3, 2024
1a7cb3d
fix: Fix failing todos check.
kkmurerwa May 3, 2024
c140838
fix: Fix failing todos check.
kkmurerwa May 5, 2024
e4d6b57
feat: Make some of the changes.
kkmurerwa May 14, 2024
bd3f2de
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa May 14, 2024
c7184c7
fix: Remove unnecessary test.
kkmurerwa May 18, 2024
c248b65
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa May 26, 2024
c6b9c60
feat: Add test to check that appSessionId changes after app restart
kkmurerwa May 30, 2024
92af458
Merge branch 'technical-analytics-milestone-2' of github.com:kkmurerw…
kkmurerwa May 30, 2024
7eda529
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa May 30, 2024
82b1275
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa May 30, 2024
3765671
fix: Fix failing test on feature flag logger.
kkmurerwa May 30, 2024
df7a08c
fix: Fix failing test on feature flags logger.
kkmurerwa May 30, 2024
92113cc
Merge branch 'develop' into technical-analytics-milestone-2
kkmurerwa Jun 4, 2024
22509fa
test: Simplify the test for the second app open on AppSessionId gener…
kkmurerwa Jun 4, 2024
f02d466
Merge branch 'develop' into technical-analytics-milestone-2
BenHenning Jun 13, 2024
fa3122b
fix: Fix failing test on feature flags logger test
kkmurerwa Jun 15, 2024
34743c6
Merge branch 'technical-analytics-milestone-2' of github.com:kkmurerw…
kkmurerwa Jun 15, 2024
969ede4
fix: Fix failing test on FeatureFlagsLoggerTest.
kkmurerwa Jun 16, 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
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import javax.inject.Inject
import javax.inject.Singleton

private const val SESSION_ID_DATA_PROVIDER_ID = "LoggingIdentifierController.session_id"
private const val APP_SESSION_ID_DATA_PROVIDER_ID = "LoggingIdentifierController.app_session_id"
private const val INSTALLATION_ID_DATA_PROVIDER_ID = "LoggingIdentifierController.installation_id"

/** Controller that handles logging identifiers related operations. */
Expand All @@ -34,14 +35,22 @@ class LoggingIdentifierController @Inject constructor(
private val installationRandomSeed = baseRandom.nextLong()
private val sessionRandomSeed = baseRandom.nextLong()
private val learnerRandomSeed = baseRandom.nextLong()
private val appSessionRandomSeed = baseRandom.nextLong()
private val installationIdRandom by lazy { Random(installationRandomSeed) }
private val sessionIdRandom by lazy { Random(sessionRandomSeed) }
private val learnerIdRandom by lazy { Random(learnerRandomSeed) }
private val appSessionIdRandom by lazy { Random(appSessionRandomSeed) }

private val sessionId by lazy { MutableStateFlow(computeSessionId()) }
private val appSessionId by lazy { MutableStateFlow(computeAppSessionId()) }
private val sessionIdDataProvider by lazy {
dataProviders.run { sessionId.convertToAutomaticDataProvider(SESSION_ID_DATA_PROVIDER_ID) }
}
private val appSessionIdDataProvider by lazy {
dataProviders.run {
appSessionId.convertToAutomaticDataProvider(APP_SESSION_ID_DATA_PROVIDER_ID)
}
}
private val installationIdStore by lazy {
persistentCacheStoreFactory.create(
cacheName = "device_context_database", DeviceContextDatabase.getDefaultInstance()
Expand Down Expand Up @@ -101,6 +110,14 @@ class LoggingIdentifierController @Inject constructor(
*/
fun getSessionId(): DataProvider<String> = sessionIdDataProvider

/**
* Returns an in-memory data provider pointing to a class variable of [appSessionId].
*
* This ID is unique to each app session. A session starts when the app is opened and ends when
* the app is destroyed by the Android system.
*/
fun getAppSessionId(): DataProvider<String> = appSessionIdDataProvider
BenHenning marked this conversation as resolved.
Show resolved Hide resolved

/**
* Returns the [StateFlow] backing the current session ID indicated by [getSessionId].
*
Expand All @@ -110,6 +127,15 @@ class LoggingIdentifierController @Inject constructor(
*/
fun getSessionIdFlow(): StateFlow<String> = sessionId

/**
* Returns the [StateFlow] backing the current app session ID indicated by [getAppSessionId].
*
* Where the [DataProvider] returned by [getAppSessionId] can be composed by domain controllers or
* observed by the UI layer, the [StateFlow] returned by this method can be observed in background
* contexts.
*/
fun getAppSessionIdFlow(): StateFlow<String> = appSessionId

/**
* Regenerates [sessionId] and notifies the data provider.
*
Expand All @@ -123,6 +149,8 @@ class LoggingIdentifierController @Inject constructor(

private fun computeSessionId(): String = sessionIdRandom.randomUuid().toString()

private fun computeAppSessionId(): String = appSessionIdRandom.randomUuid().toString()

private fun computeInstallationId(): String {
return machineLocale.run {
MessageDigest.getInstance("SHA-1")
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ class ApplicationLifecycleObserver @Inject constructor(
private val profileManagementController: ProfileManagementController,
private val oppiaLogger: OppiaLogger,
private val performanceMetricsLogger: PerformanceMetricsLogger,
private val featureFlagsLogger: FeatureFlagsLogger,
private val performanceMetricsController: PerformanceMetricsController,
private val cpuPerformanceSnapshotter: CpuPerformanceSnapshotter,
@LearnerAnalyticsInactivityLimitMillis private val inactivityLimitMillis: Long,
Expand Down Expand Up @@ -84,6 +85,7 @@ class ApplicationLifecycleObserver @Inject constructor(
ProcessLifecycleOwner.get().lifecycle.addObserver(this)
application.registerActivityLifecycleCallbacks(this)
logApplicationStartupMetrics()
logAllFeatureFlags()
BenHenning marked this conversation as resolved.
Show resolved Hide resolved
cpuPerformanceSnapshotter.initialiseSnapshotter()
}

Expand Down Expand Up @@ -172,6 +174,22 @@ class ApplicationLifecycleObserver @Inject constructor(
}
}

private fun logAllFeatureFlags() {
CoroutineScope(backgroundDispatcher).launch {
// TODO(#5341): Replace appSessionId generation to the modified Twitter snowflake algorithm.
val appSessionId = loggingIdentifierController.getAppSessionIdFlow().value
featureFlagsLogger.logAllFeatureFlags(appSessionId)
}.invokeOnCompletion { failure ->
if (failure != null) {
oppiaLogger.e(
"ActivityLifecycleObserver",
"Encountered error while logging feature flags.",
failure
)
}
}
}

private fun logAppInForegroundTime() {
CoroutineScope(backgroundDispatcher).launch {
val sessionId = loggingIdentifierController.getSessionIdFlow().value
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,7 @@ kt_android_library(
deps = [
":application_lifecycle_listener",
":cpu_performance_snapshotter",
":feature_flags_logger",
":learner_analytics_inactivity_limit_millis",
":performance_metrics_controller",
"//domain/src/main/java/org/oppia/android/domain/oppialogger:logging_identifier_controller",
Expand Down Expand Up @@ -191,6 +192,20 @@ kt_android_library(
visibility = ["//:oppia_api_visibility"],
)

kt_android_library(
name = "feature_flags_logger",
srcs = [
"FeatureFlagsLogger.kt",
],
visibility = ["//:oppia_api_visibility"],
deps = [
"//:dagger",
"//domain/src/main/java/org/oppia/android/domain/oppialogger:oppia_logger",
"//domain/src/main/java/org/oppia/android/domain/oppialogger/analytics:controller",
"//third_party:javax_inject_javax_inject",
],
)

kt_android_library(
name = "data_controller",
srcs = [
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,142 @@
package org.oppia.android.domain.oppialogger.analytics

import org.oppia.android.app.model.EventLog
import org.oppia.android.app.model.EventLog.FeatureFlagItemContext
import org.oppia.android.app.model.EventLog.FeatureFlagListContext
import org.oppia.android.util.platformparameter.APP_AND_OS_DEPRECATION
import org.oppia.android.util.platformparameter.DOWNLOADS_SUPPORT
import org.oppia.android.util.platformparameter.EDIT_ACCOUNTS_OPTIONS_UI
import org.oppia.android.util.platformparameter.ENABLE_NPS_SURVEY
import org.oppia.android.util.platformparameter.ENABLE_ONBOARDING_FLOW_V2
import org.oppia.android.util.platformparameter.ENABLE_PERFORMANCE_METRICS_COLLECTION
import org.oppia.android.util.platformparameter.EXTRA_TOPIC_TABS_UI
import org.oppia.android.util.platformparameter.EnableAppAndOsDeprecation
import org.oppia.android.util.platformparameter.EnableDownloadsSupport
import org.oppia.android.util.platformparameter.EnableEditAccountsOptionsUi
import org.oppia.android.util.platformparameter.EnableExtraTopicTabsUi
import org.oppia.android.util.platformparameter.EnableFastLanguageSwitchingInLesson
import org.oppia.android.util.platformparameter.EnableInteractionConfigChangeStateRetention
import org.oppia.android.util.platformparameter.EnableLearnerStudyAnalytics
import org.oppia.android.util.platformparameter.EnableLoggingLearnerStudyIds
import org.oppia.android.util.platformparameter.EnableNpsSurvey
import org.oppia.android.util.platformparameter.EnableOnboardingFlowV2
import org.oppia.android.util.platformparameter.EnablePerformanceMetricsCollection
import org.oppia.android.util.platformparameter.EnableSpotlightUi
import org.oppia.android.util.platformparameter.FAST_LANGUAGE_SWITCHING_IN_LESSON
import org.oppia.android.util.platformparameter.INTERACTION_CONFIG_CHANGE_STATE_RETENTION
import org.oppia.android.util.platformparameter.LEARNER_STUDY_ANALYTICS
import org.oppia.android.util.platformparameter.LOGGING_LEARNER_STUDY_IDS
import org.oppia.android.util.platformparameter.PlatformParameterValue
import org.oppia.android.util.platformparameter.SPOTLIGHT_UI
import javax.inject.Inject
import javax.inject.Singleton

/**
* Convenience logger for feature flags.
*
* This logger is meant to be used for feature flag-related logging on every app launch. It is
* primarily used within the ApplicationLifecycleObserver to log the status of feature flags in a
* given app session.
*/
@Singleton
class FeatureFlagsLogger @Inject constructor(
BenHenning marked this conversation as resolved.
Show resolved Hide resolved
private val analyticsController: AnalyticsController,
@EnableDownloadsSupport
private val enableDownloadsSupport: PlatformParameterValue<Boolean>,
@EnableExtraTopicTabsUi
private val enableExtraTopicTabsUi: PlatformParameterValue<Boolean>,
@EnableLearnerStudyAnalytics
private val enableLearnerStudyAnalytics: PlatformParameterValue<Boolean>,
@EnableFastLanguageSwitchingInLesson
private val enableFastLanguageSwitchingInLesson: PlatformParameterValue<Boolean>,
@EnableLoggingLearnerStudyIds
private val enableLoggingLearnerStudyIds: PlatformParameterValue<Boolean>,
@EnableEditAccountsOptionsUi
private val enableEditAccountsOptionsUi: PlatformParameterValue<Boolean>,
@EnablePerformanceMetricsCollection
private val enablePerformanceMetricsCollection: PlatformParameterValue<Boolean>,
@EnableSpotlightUi
private val enableSpotlightUi: PlatformParameterValue<Boolean>,
@EnableInteractionConfigChangeStateRetention
private val enableInteractionConfigChangeStateRetention: PlatformParameterValue<Boolean>,
@EnableAppAndOsDeprecation
private val enableAppAndOsDeprecation: PlatformParameterValue<Boolean>,
@EnableNpsSurvey
private val enableNpsSurvey: PlatformParameterValue<Boolean>,
@EnableOnboardingFlowV2
private val enableOnboardingFlowV2: PlatformParameterValue<Boolean>
) {
/**
* A variable containing a list of all the feature flags in the app.
*
* @return a list of key-value pairs of [String] and [PlatformParameterValue]
*/
private var featureFlagItemMap: Map<String, PlatformParameterValue<Boolean>> = mapOf(
DOWNLOADS_SUPPORT to enableDownloadsSupport,
EXTRA_TOPIC_TABS_UI to enableExtraTopicTabsUi,
LEARNER_STUDY_ANALYTICS to enableLearnerStudyAnalytics,
FAST_LANGUAGE_SWITCHING_IN_LESSON to enableFastLanguageSwitchingInLesson,
LOGGING_LEARNER_STUDY_IDS to enableLoggingLearnerStudyIds,
EDIT_ACCOUNTS_OPTIONS_UI to enableEditAccountsOptionsUi,
ENABLE_PERFORMANCE_METRICS_COLLECTION to enablePerformanceMetricsCollection,
SPOTLIGHT_UI to enableSpotlightUi,
INTERACTION_CONFIG_CHANGE_STATE_RETENTION to enableInteractionConfigChangeStateRetention,
APP_AND_OS_DEPRECATION to enableAppAndOsDeprecation,
ENABLE_NPS_SURVEY to enableNpsSurvey,
ENABLE_ONBOARDING_FLOW_V2 to enableOnboardingFlowV2
)

/**
* This method can be used to override the featureFlagItemMap and sets its value to the given map.
*
* @param featureFlagItemMap denotes the map of feature flag names to their corresponding
* [PlatformParameterValue]s
*/
fun setFeatureFlagItemMap(featureFlagItemMap: Map<String, PlatformParameterValue<Boolean>>) {
this.featureFlagItemMap = featureFlagItemMap
}

/**
* This method logs the name, enabled status and sync status of all feature flags to Firebase.
*
* @param appSessionId denotes the id of the current appInForeground session
*/
fun logAllFeatureFlags(appSessionId: String) {
val featureFlagItemList = mutableListOf<FeatureFlagItemContext>()
for (flag in featureFlagItemMap) {
featureFlagItemList.add(
createFeatureFlagItemContext(flag)
)
}

// TODO(#5341): Set the UUID value for this context
val featureFlagContext = FeatureFlagListContext.newBuilder()
.setAppSessionId(appSessionId)
BenHenning marked this conversation as resolved.
Show resolved Hide resolved
.addAllFeatureFlags(featureFlagItemList)
.build()

analyticsController.logLowPriorityEvent(
EventLog.Context.newBuilder()
.setFeatureFlagListContext(featureFlagContext)
.build(),
profileId = null
)
}

/**
* Creates an [EventLog] context for the feature flags to be logged.
*
* @param flagDetails denotes the key-value pair of the feature flag name and its corresponding
* [PlatformParameterValue]
* @return an [EventLog.Context] for the feature flags to be logged
*/
private fun createFeatureFlagItemContext(
flagDetails: Map.Entry<String, PlatformParameterValue<Boolean>>,
): FeatureFlagItemContext {
return FeatureFlagItemContext.newBuilder()
.setFlagName(flagDetails.key)
.setFlagEnabledState(flagDetails.value.value)
.setFlagSyncStatus(flagDetails.value.syncStatus)
.build()
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -309,6 +309,58 @@ class LoggingIdentifierControllerTest {
assertThat(sessionIdFlow.value).isEqualTo("59aea8d4-af4b-3249-b889-dfeba06d0495")
}

@Test
fun testGetAppSessionId_initialState_returnsRandomId() {
BenHenning marked this conversation as resolved.
Show resolved Hide resolved
val appSessionIdProvider = loggingIdentifierController.getAppSessionId()

val appSessionId = monitorFactory.waitForNextSuccessfulResult(appSessionIdProvider)
assertThat(appSessionId).isEqualTo("2a11efe0-70f8-3a40-8d94-4fc3a2bd4f14")
}

@Test
fun testGetAppSessionId_secondCall_returnsSameRandomId() {
monitorFactory.ensureDataProviderExecutes(loggingIdentifierController.getAppSessionId())

val sessionIdProvider = loggingIdentifierController.getAppSessionId()

// The second call should return the same ID (since the ID doesn't automatically change).
val appSessionId = monitorFactory.waitForNextSuccessfulResult(sessionIdProvider)
assertThat(appSessionId).isEqualTo("2a11efe0-70f8-3a40-8d94-4fc3a2bd4f14")
}

@Test
fun testGetAppSessionIdFlow_initialState_returnsFlowWithRandomId() {
val appSessionIdFlow = loggingIdentifierController.getAppSessionIdFlow()

val appSessionId = appSessionIdFlow.waitForLatestValue()
assertThat(appSessionId).isEqualTo("2a11efe0-70f8-3a40-8d94-4fc3a2bd4f14")
}

@Test
fun testGetAppSessionIdFlow_secondCall_returnsFlowWithSameRandomId() {
loggingIdentifierController.getSessionIdFlow().waitForLatestValue()

val appSessionIdFlow = loggingIdentifierController.getAppSessionIdFlow()

// The second call should return the same ID (since the ID doesn't automatically change).
val appSessionId = appSessionIdFlow.waitForLatestValue()
assertThat(appSessionId).isEqualTo("2a11efe0-70f8-3a40-8d94-4fc3a2bd4f14")
}

@Test
fun testGetAppSessionId_onSecondAppOpen_returnsDifferentRandomId() {
monitorFactory.ensureDataProviderExecutes(loggingIdentifierController.getAppSessionId())

// Simulate a second app open.
TestLoggingIdentifierModule.applicationIdSeed = SECOND_APP_OPEN_APPLICATION_ID
setUpNewTestApplicationComponent()

// The app session ID should be different on the second app open.
val appSessionIdProvider = loggingIdentifierController.getAppSessionId()
val appSessionId = monitorFactory.waitForNextSuccessfulResult(appSessionIdProvider)
assertThat(appSessionId).isEqualTo("c9d50545-33dc-3231-a1db-6a2672498c74")
}

private fun <T : MessageLite> writeFileCache(cacheName: String, value: T) {
getCacheFile(cacheName).writeBytes(value.toByteArray())
}
Expand Down
Loading
Loading