Skip to content
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
1 change: 1 addition & 0 deletions library/src/main/java/io/constructor/core/Constants.kt
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ class Constants {
const val PER_PAGE = "num_results_per_page"
const val FILTER_GROUP_ID = "filters[group_id]"
const val FILTER_FACET = "filters[%s]"
const val RESULT_ID = "result_id"
}

object QueryValues {
Expand Down
13 changes: 8 additions & 5 deletions library/src/main/java/io/constructor/core/ConstructorIo.kt
Original file line number Diff line number Diff line change
Expand Up @@ -129,11 +129,12 @@ object ConstructorIo {
/**
* Tracks autocomplete select events
*/
fun trackAutocompleteSelect(searchTerm: String, originalQuery: String, sectionName: String, group: Group? = null): Completable {
fun trackAutocompleteSelect(searchTerm: String, originalQuery: String, sectionName: String, group: Group? = null, resultID: String? = null): Completable {
preferenceHelper.getSessionId(sessionIncrementHandler)
val encodedParams: ArrayList<Pair<String, String>> = arrayListOf()
group?.groupId?.let { encodedParams.add(Constants.QueryConstants.GROUP_ID.urlEncode() to it) }
group?.displayName?.let { encodedParams.add(Constants.QueryConstants.GROUP_DISPLAY_NAME.urlEncode() to it.urlEncode()) }
resultID?.let { encodedParams.add(Constants.QueryConstants.RESULT_ID.urlEncode() to it.urlEncode()) }
val completable = dataManager.trackAutocompleteSelect(searchTerm, arrayOf(
Constants.QueryConstants.AUTOCOMPLETE_SECTION to sectionName,
Constants.QueryConstants.ORIGINAL_QUERY to originalQuery,
Expand Down Expand Up @@ -184,12 +185,14 @@ object ConstructorIo {
/**
* Tracks search result click events
*/
fun trackSearchResultClick(itemName: String, customerId: String, searchTerm: String = Constants.QueryConstants.TERM_UNKNOWN, sectionName: String? = null): Completable {
fun trackSearchResultClick(itemName: String, customerId: String, searchTerm: String = Constants.QueryConstants.TERM_UNKNOWN, sectionName: String? = null, resultID: String? = null): Completable {
preferenceHelper.getSessionId(sessionIncrementHandler)
val encodedParams: ArrayList<Pair<String, String>> = arrayListOf()
resultID?.let { encodedParams.add(Constants.QueryConstants.RESULT_ID.urlEncode() to it.urlEncode()) }
val sName = sectionName ?: preferenceHelper.defaultItemSection
return dataManager.trackSearchResultClick(itemName, customerId, searchTerm, arrayOf(
Constants.QueryConstants.AUTOCOMPLETE_SECTION to sName
))
), encodedParams.toTypedArray())

}

Expand All @@ -207,12 +210,12 @@ object ConstructorIo {
/**
* Tracks purchase events
*/
fun trackPurchase(clientIds: Array<String>, revenue: Double?, sectionName: String? = null): Completable {
fun trackPurchase(clientIds: Array<String>, revenue: Double?, orderID: String, sectionName: String? = null): Completable {
preferenceHelper.getSessionId(sessionIncrementHandler)
val sectionNameParam = sectionName ?: preferenceHelper.defaultItemSection
val revenueString = revenue?.let { "%.2f".format(revenue) }
val params = mutableListOf(Constants.QueryConstants.AUTOCOMPLETE_SECTION to sectionNameParam)
return dataManager.trackPurchase(clientIds.toList(), revenueString, params.toTypedArray())
return dataManager.trackPurchase(clientIds.toList(), revenueString, orderID, params.toTypedArray())
}

}
10 changes: 5 additions & 5 deletions library/src/main/java/io/constructor/data/DataManager.kt
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ constructor(private val constructorApi: ConstructorApi, private val moshi: Moshi
}.toObservable()
}

fun trackAutocompleteSelect(term: String, params: Array<Pair<String, String>> = arrayOf(), encodedParams: Array<Pair<String, String>> = arrayOf()): Completable {
fun trackAutocompleteSelect(term: String, params: Array<Pair<String, String>> = arrayOf(), encodedParams: Array<Pair<String, String>> = arrayOf()): Completable {
return constructorApi.trackAutocompleteSelect(term, params.toMap(), encodedParams.toMap())
}

Expand All @@ -69,8 +69,8 @@ constructor(private val constructorApi: ConstructorApi, private val moshi: Moshi
return constructorApi.trackConversion(term, itemName, customerId, revenue, params.toMap())
}

fun trackSearchResultClick(itemName: String, customerId: String, term: String, params: Array<Pair<String, String>> = arrayOf()): Completable {
return constructorApi.trackSearchResultClick(term, itemName, customerId, params.toMap())
fun trackSearchResultClick(itemName: String, customerId: String, term: String, params: Array<Pair<String, String>> = arrayOf(), encodedParams: Array<Pair<String, String>> = arrayOf()): Completable {
return constructorApi.trackSearchResultClick(term, itemName, customerId, params.toMap(), encodedParams.toMap())
}

fun trackSearchResultsLoaded(term: String, resultCount: Int, params: Array<Pair<String, String>>): Completable {
Expand All @@ -81,8 +81,8 @@ constructor(private val constructorApi: ConstructorApi, private val moshi: Moshi
return constructorApi.trackInputFocus(term, params.toMap())
}

fun trackPurchase(customerIds: List<String>, revenue: String? = null, params: Array<Pair<String, String>>): Completable {
return constructorApi.trackPurchase(customerIds, revenue, params.toMap())
fun trackPurchase(customerIds: List<String>, revenue: String? = null, orderID: String, params: Array<Pair<String, String>>): Completable {
return constructorApi.trackPurchase(customerIds, revenue, orderID, params.toMap())
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ interface ConstructorApi {
fun trackConversion(@Path("term") term: String, @Query("name") itemName: String, @Query("customer_id") customerId: String, @Query("revenue") revenue: String?, @QueryMap params: Map<String, String>): Completable

@GET(ApiPaths.URL_SEARCH_RESULT_CLICK_EVENT)
fun trackSearchResultClick(@Path("term") term: String, @Query("name") itemName: String, @Query("customer_id") customerId: String, @QueryMap params: Map<String, String>): Completable
fun trackSearchResultClick(@Path("term") term: String, @Query("name") itemName: String, @Query("customer_id") customerId: String, @QueryMap params: Map<String, String>, @QueryMap(encoded = true) encodedData: Map<String, String>): Completable

@GET(ApiPaths.URL_BEHAVIOR)
fun trackSearchResultsLoaded(@Query("term") term: String, @Query("num_results") resultCount: Int, @QueryMap params: Map<String, String>): Completable
Expand All @@ -37,6 +37,7 @@ interface ConstructorApi {
@GET(ApiPaths.URL_PURCHASE)
fun trackPurchase(@Query(Constants.QueryConstants.CUSTOMER_ID) customerIds: List<String>,
@Query("revenue") revenue: String?,
@Query("order_id") orderID: String,
@QueryMap params: Map<String, String>): Completable

@GET
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package io.constructor.core
import android.content.Context
import io.constructor.data.local.PreferencesHelper
import io.constructor.data.memory.ConfigMemoryHolder
import io.constructor.data.model.Group
import io.constructor.test.createTestDataManager
import io.constructor.util.RxSchedulersOverrideRule
import io.mockk.Runs
Expand All @@ -11,6 +12,7 @@ import io.mockk.just
import io.mockk.mockk
import okhttp3.mockwebserver.MockResponse
import okhttp3.mockwebserver.MockWebServer
import org.json.JSONObject
import org.junit.Before
import org.junit.Rule
import org.junit.Test
Expand Down Expand Up @@ -82,6 +84,17 @@ class ConstructorIoTest {
assert(request.path.startsWith(path))
}

@Test
fun trackAutocompleteSelectWithOptionalParams() {
val mockResponse = MockResponse().setResponseCode(204)
mockServer.enqueue(mockResponse)
val observer = ConstructorIo.trackAutocompleteSelect("titanic", "tit", "Search Suggestions", Group("recommended", "123123"), "2346784").test()
observer.assertComplete()
val request = mockServer.takeRequest()
val path = "/autocomplete/titanic/select?autocomplete_section=Search%20Suggestions&original_query=tit&tr=click&group%5Bgroup_id%5D=123123&group%5Bdisplay_name%5D=recommended&result_id=2346784&key=copper-key&i=wacko-the-guid&ui=player-three&s=67&c=cioand-1.3.0&_dt="
assert(request.path.startsWith(path))
}

@Test
fun trackSearchSubmit() {
val mockResponse = MockResponse().setResponseCode(204)
Expand Down Expand Up @@ -218,6 +231,17 @@ class ConstructorIoTest {
assert(request.path.startsWith(path))
}

@Test
fun trackSearchResultClickWithOptionalParams() {
val mockResponse = MockResponse().setResponseCode(204)
mockServer.enqueue(mockResponse)
val observer = ConstructorIo.trackSearchResultClick("titanic replica", "TIT-REP-1997", "titanic", "Products","3467632").test()
observer.assertComplete()
val request = mockServer.takeRequest()
val path = "/autocomplete/titanic/click_through?name=titanic%20replica&customer_id=TIT-REP-1997&autocomplete_section=Products&result_id=3467632&key=copper-key&i=wacko-the-guid&ui=player-three&s=67&c=cioand-1.3.0&_dt=";
assert(request.path.startsWith(path))
}

@Test
fun trackSearchResultLoaded() {
val mockResponse = MockResponse().setResponseCode(204)
Expand Down Expand Up @@ -290,21 +314,21 @@ class ConstructorIoTest {
fun trackPurchase() {
val mockResponse = MockResponse().setResponseCode(204)
mockServer.enqueue(mockResponse)
val observer = ConstructorIo.trackPurchase(arrayOf("TIT-REP-1997", "QE2-REP-1969"), 12.99, "Products").test()
val observer = ConstructorIo.trackPurchase(arrayOf("TIT-REP-1997", "QE2-REP-1969"), 12.99, "ORD-1312343").test()
observer.assertComplete()
val request = mockServer.takeRequest()
val path = "/autocomplete/TERM_UNKNOWN/purchase?customer_ids=TIT-REP-1997&customer_ids=QE2-REP-1969&revenue=12.99&autocomplete_section=Products&key=copper-key&i=wacko-the-guid&ui=player-three&s=67&c=cioand-1.3.0&_dt=";
val path = "/autocomplete/TERM_UNKNOWN/purchase?customer_ids=TIT-REP-1997&customer_ids=QE2-REP-1969&revenue=12.99&order_id=ORD-1312343&autocomplete_section=Products&key=copper-key&i=wacko-the-guid&ui=player-three&s=67&c=cioand-1.3.0&_dt=";
assert(request.path.startsWith(path))
}

@Test
fun trackPurchase500() {
val mockResponse = MockResponse().setResponseCode(500).setBody("Internal server error")
mockServer.enqueue(mockResponse)
val observer = ConstructorIo.trackPurchase(arrayOf("TIT-REP-1997", "QE2-REP-1969"), 12.99, "Products").test()
val observer = ConstructorIo.trackPurchase(arrayOf("TIT-REP-1997", "QE2-REP-1969"), 12.99, "ORD-1312343").test()
observer.assertError { true }
val request = mockServer.takeRequest()
val path = "/autocomplete/TERM_UNKNOWN/purchase?customer_ids=TIT-REP-1997&customer_ids=QE2-REP-1969&revenue=12.99&autocomplete_section=Products&key=copper-key&i=wacko-the-guid&ui=player-three&s=67&c=cioand-1.3.0&_dt=";
val path = "/autocomplete/TERM_UNKNOWN/purchase?customer_ids=TIT-REP-1997&customer_ids=QE2-REP-1969&revenue=12.99&order_id=ORD-1312343&autocomplete_section=Products&key=copper-key&i=wacko-the-guid&ui=player-three&s=67&c=cioand-1.3.0&_dt=";
assert(request.path.startsWith(path))
}

Expand All @@ -313,10 +337,21 @@ class ConstructorIoTest {
val mockResponse = MockResponse().setResponseCode(500).setBody("Internal server error")
mockResponse.throttleBody(0, 5, TimeUnit.SECONDS)
mockServer.enqueue(mockResponse)
val observer = ConstructorIo.trackPurchase(arrayOf("TIT-REP-1997", "QE2-REP-1969"), 12.99, "Products").test()
val observer = ConstructorIo.trackPurchase(arrayOf("TIT-REP-1997", "QE2-REP-1969"), 12.99,"ORD-1312343").test()
observer.assertError(SocketTimeoutException::class.java)
val request = mockServer.takeRequest()
val path = "/autocomplete/TERM_UNKNOWN/purchase?customer_ids=TIT-REP-1997&customer_ids=QE2-REP-1969&revenue=12.99&autocomplete_section=Products&key=copper-key&i=wacko-the-guid&ui=player-three&s=67&c=cioand-1.3.0&_dt=";
val path = "/autocomplete/TERM_UNKNOWN/purchase?customer_ids=TIT-REP-1997&customer_ids=QE2-REP-1969&revenue=12.99&order_id=ORD-1312343&autocomplete_section=Products&key=copper-key&i=wacko-the-guid&ui=player-three&s=67&c=cioand-1.3.0&_dt=";
assert(request.path.startsWith(path))
}

@Test
fun trackPurchaseWithOptionalParams() {
val mockResponse = MockResponse().setResponseCode(204)
mockServer.enqueue(mockResponse)
val observer = ConstructorIo.trackPurchase(arrayOf("TIT-REP-1997", "QE2-REP-1969"), 12.99, "ORD-1312343", "Recommendations").test()
observer.assertComplete()
val request = mockServer.takeRequest()
val path = "/autocomplete/TERM_UNKNOWN/purchase?customer_ids=TIT-REP-1997&customer_ids=QE2-REP-1969&revenue=12.99&order_id=ORD-1312343&autocomplete_section=Recommendations&key=copper-key&i=wacko-the-guid&ui=player-three&s=67&c=cioand-1.3.0&_dt=";
assert(request.path.startsWith(path))
}
}
}