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

chore: Delete key from customer center survey event #2204

Merged
merged 2 commits into from
Mar 3, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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 @@ -53,8 +53,6 @@ internal sealed class BackendEvent : Event {
val url: String?,
@SerialName("survey_option_id")
val surveyOptionID: String?,
@SerialName("survey_option_title_key")
val surveyOptionTitleKey: String?,
) : BackendEvent()

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,6 @@ internal fun CustomerCenterImpressionEvent.toBackendStoredEvent(
path = null,
url = null,
surveyOptionID = null,
surveyOptionTitleKey = null,
),
)
}
Expand Down Expand Up @@ -135,7 +134,6 @@ internal fun CustomerCenterSurveyOptionChosenEvent.toBackendStoredEvent(
path = data.path,
url = data.url,
surveyOptionID = data.surveyOptionID,
surveyOptionTitleKey = data.surveyOptionTitleKey,
),
)
}
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,6 @@ class CustomerCenterSurveyOptionChosenEvent(
val path: CustomerCenterConfigData.HelpPath.PathType,
val url: String?, // URL if CUSTOM_URL
val surveyOptionID: String,
val surveyOptionTitleKey: String,
val additionalContext: String? = null, // null for now until we support

// isSandbox not available in Android
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -52,8 +52,7 @@ internal class ProductionBackendEventsTest: BaseBackendIntegrationTest() {
locale = "en_US",
path = null,
url = null,
surveyOptionID = null,
surveyOptionTitleKey = null,
surveyOptionID = null
),
BackendEvent.CustomerCenter(
id = UUID.randomUUID().toString(),
Expand All @@ -67,7 +66,6 @@ internal class ProductionBackendEventsTest: BaseBackendIntegrationTest() {
path = CustomerCenterConfigData.HelpPath.PathType.CANCEL,
url = null,
surveyOptionID = "surveyOptionID",
surveyOptionTitleKey = "surveyOptionTitleKey",
locale = "en_US",
)
)
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package com.revenuecat.purchases.common.events

import android.annotation.SuppressLint
import android.content.Context
import androidx.test.ext.junit.runners.AndroidJUnit4
import com.revenuecat.purchases.ExperimentalPreviewRevenueCatPurchasesAPI
Expand Down Expand Up @@ -64,6 +65,7 @@ class EventsManagerTest {
)
)
private val paywallStoredEvent = PaywallStoredEvent(paywallEvent, userID)
private var postedRequest: EventsRequest? = null

private val testFolder = "temp_test_folder"

Expand Down Expand Up @@ -103,6 +105,7 @@ class EventsManagerTest {
identityManager,
paywallEventsDispatcher,
postEvents = { request, onSuccess, onError ->
postedRequest = request
backend.postEvents(
paywallEventRequest = request,
onSuccessHandler = onSuccess,
Expand Down Expand Up @@ -155,7 +158,7 @@ class EventsManagerTest {
"""{"type":"customer_center","event":{"id":"298207f4-87af-4b57-a581-eb27bcc6e009","revision_id":1,"type":"customer_center_impression","app_user_id":"testAppUserId","app_session_id":"${appSessionID}","timestamp":1699270688884,"dark_mode":true,"locale":"es_ES","display_mode":"full_screen"}}""".trimIndent() + "\n"
)

var surveyEvent = CustomerCenterSurveyOptionChosenEvent(
val surveyEvent = CustomerCenterSurveyOptionChosenEvent(
creationData = CustomerCenterSurveyOptionChosenEvent.CreationData(
id = UUID.fromString("298207f4-87af-4b57-a581-eb27bcc6e009"),
date = Date(1699270688884)
Expand All @@ -166,15 +169,14 @@ class EventsManagerTest {
locale = "es_ES",
path = CustomerCenterConfigData.HelpPath.PathType.CANCEL,
url = "PATH2",
surveyOptionID = "surveyOptionID",
surveyOptionTitleKey = "surveyOptionTitleKey"
surveyOptionID = "surveyOptionID"
)
)
eventsManager.track(surveyEvent)
checkFileContents(
"""{"type":"customer_center","event":{"id":"298207f4-87af-4b57-a581-eb27bcc6e009","revision_id":1,"type":"customer_center_impression","app_user_id":"testAppUserId","app_session_id":"${appSessionID}","timestamp":1699270688884,"dark_mode":true,"locale":"es_ES","display_mode":"full_screen"}}""".trimIndent()
+ "\n"
+ """{"type":"customer_center","event":{"id":"298207f4-87af-4b57-a581-eb27bcc6e009","revision_id":1,"type":"customer_center_survey_option_chosen","app_user_id":"testAppUserId","app_session_id":"${appSessionID}","timestamp":1699270688884,"dark_mode":true,"locale":"es_ES","display_mode":"full_screen","path":"CANCEL","url":"PATH2","survey_option_id":"surveyOptionID","survey_option_title_key":"surveyOptionTitleKey"}}""".trimIndent()
+ """{"type":"customer_center","event":{"id":"298207f4-87af-4b57-a581-eb27bcc6e009","revision_id":1,"type":"customer_center_survey_option_chosen","app_user_id":"testAppUserId","app_session_id":"${appSessionID}","timestamp":1699270688884,"dark_mode":true,"locale":"es_ES","display_mode":"full_screen","path":"CANCEL","url":"PATH2","survey_option_id":"surveyOptionID"}}""".trimIndent()
+ "\n"
)
}
Expand All @@ -199,7 +201,7 @@ class EventsManagerTest {
)
.toBackendEvent() as BackendEvent.CustomerCenter
)
).mapNotNull { it.toBackendEvent() }
).map { it.toBackendEvent() }
)
verify(exactly = 1) {
backend.postEvents(
Expand Down Expand Up @@ -325,6 +327,17 @@ class EventsManagerTest {
expectNumberOfEventsSynced(48)
}

@SuppressLint("CheckResult")
@Test
fun `flushEvents with events stored with removed keys from model, successfully flushes them`() {
mockBackendResponse(success = true)
eventsManager.track(paywallEvent)
appendToFile(
"""{"type":"customer_center","event":{"id":"298207f4-87af-4b57-a581-eb27bcc6e009","revision_id":1,"type":"customer_center_survey_option_chosen","app_user_id":"testAppUserId","app_session_id":"${appSessionID}","timestamp":1699270688884,"dark_mode":true,"locale":"es_ES","display_mode":"full_screen","path":"CANCEL","url":"PATH2","survey_option_id":"surveyOptionID","survey_option_title_key":"surveyOptionTitleKey"}}""".trimIndent()
)
eventsManager.flushEvents()
assertThat(postedRequest?.events?.count() == 2)
}

private fun checkFileNumberOfEvents(expectedNumberOfEvents: Int) {
val file = File(testFolder, EventsManager.EVENTS_FILE_PATH_NEW)
Expand Down Expand Up @@ -352,7 +365,7 @@ class EventsManagerTest {

private fun expectNumberOfEventsSynced(eventsSynced: Int) {
val expectedRequest = EventsRequest(
List(eventsSynced) { BackendStoredEvent.Paywalls(paywallStoredEvent.toBackendEvent()) }.mapNotNull { it.toBackendEvent() }
List(eventsSynced) { BackendStoredEvent.Paywalls(paywallStoredEvent.toBackendEvent()) }.map { it.toBackendEvent() }
)
verify(exactly = 1) {
backend.postEvents(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -154,7 +154,6 @@ internal class CustomerCenterViewModelImpl(
path = path.type,
url = path.url,
surveyOptionID = it.id,
surveyOptionTitleKey = it.title,
)

if (product != null && it.promotionalOffer != null) {
Expand Down Expand Up @@ -580,7 +579,6 @@ internal class CustomerCenterViewModelImpl(
path: CustomerCenterConfigData.HelpPath.PathType,
url: String?,
surveyOptionID: String,
surveyOptionTitleKey: String,
) {
val locale = _lastLocaleList.value.get(0) ?: Locale.getDefault()
val event = CustomerCenterSurveyOptionChosenEvent(
Expand All @@ -591,7 +589,6 @@ internal class CustomerCenterViewModelImpl(
path = path,
url = url,
surveyOptionID = surveyOptionID,
surveyOptionTitleKey = surveyOptionTitleKey,
),
)
purchases.track(event)
Expand Down