use of com.microsoft.appcenter.analytics.ingestion.models.one.CommonSchemaEventLog in project mobile-center-sdk-android by Microsoft.
the class AnalyticsTransmissionTargetTest method addTicketToLogBeforeStart.
@Test
public void addTicketToLogBeforeStart() {
/* Simulate not started. */
Analytics.unsetInstance();
when(AppCenter.isConfigured()).thenReturn(false);
/* No actions are prepared without authentication provider. */
CommonSchemaLog log = new CommonSchemaEventLog();
AnalyticsTransmissionTarget.getChannelListener().onPreparingLog(log, "test");
/* Add authentication provider before start. */
AuthenticationProvider.TokenProvider tokenProvider = mock(AuthenticationProvider.TokenProvider.class);
AuthenticationProvider authenticationProvider = spy(new AuthenticationProvider(AuthenticationProvider.Type.MSA_COMPACT, "key1", tokenProvider));
AnalyticsTransmissionTarget.addAuthenticationProvider(authenticationProvider);
assertEquals(authenticationProvider, AnalyticsTransmissionTarget.sAuthenticationProvider);
verify(authenticationProvider).acquireTokenAsync();
/* Start analytics. */
when(AppCenter.isConfigured()).thenReturn(true);
Analytics analytics = Analytics.getInstance();
AppCenterHandler handler = mock(AppCenterHandler.class);
ArgumentCaptor<Runnable> normalRunnable = ArgumentCaptor.forClass(Runnable.class);
ArgumentCaptor<Runnable> disabledRunnable = ArgumentCaptor.forClass(Runnable.class);
doNothing().when(handler).post(normalRunnable.capture(), disabledRunnable.capture());
analytics.onStarting(handler);
analytics.onStarted(mock(Context.class), mChannel, null, null, false);
/* No actions are prepared with no CommonSchemaLog. */
AnalyticsTransmissionTarget.getChannelListener().onPreparingLog(mock(Log.class), "test");
verify(authenticationProvider, never()).checkTokenExpiry();
/* Call prepare log. */
final ProtocolExtension protocol = new ProtocolExtension();
log.setExt(new Extensions() {
{
setProtocol(protocol);
}
});
AnalyticsTransmissionTarget.getChannelListener().onPreparingLog(log, "test");
/* Verify log. */
assertEquals(Collections.singletonList(authenticationProvider.getTicketKeyHash()), protocol.getTicketKeys());
/* And that we check expiry. */
verify(authenticationProvider).checkTokenExpiry();
}
use of com.microsoft.appcenter.analytics.ingestion.models.one.CommonSchemaEventLog in project mobile-center-sdk-android by Microsoft.
the class AnalyticsTransmissionTargetTest method updateAuthProviderAndLog.
@Test
public void updateAuthProviderAndLog() {
/* When we enqueue app center log from track event. */
final List<CommonSchemaLog> sentLogs = new ArrayList<>();
doAnswer(new Answer<Object>() {
@Override
public Object answer(InvocationOnMock invocation) {
ProtocolExtension protocol = new ProtocolExtension();
Extensions ext = new Extensions();
ext.setProtocol(protocol);
CommonSchemaLog log = new CommonSchemaEventLog();
log.setExt(ext);
sentLogs.add(log);
/* Call the listener after conversion of common schema for authentication decoration. */
AnalyticsTransmissionTarget.getChannelListener().onPreparingLog(log, "test");
return null;
}
}).when(mChannel).enqueue(any(Log.class), anyString(), anyInt());
/* Start analytics and simulate background thread handler (we hold the thread command and run it in the test). */
Analytics analytics = Analytics.getInstance();
AppCenterHandler handler = mock(AppCenterHandler.class);
ArgumentCaptor<Runnable> backgroundRunnable = ArgumentCaptor.forClass(Runnable.class);
doNothing().when(handler).post(backgroundRunnable.capture(), any(Runnable.class));
analytics.onStarting(handler);
analytics.onStarted(mock(Context.class), mChannel, null, "test", true);
/* Add first authentication provider. */
AuthenticationProvider.TokenProvider tokenProvider1 = mock(AuthenticationProvider.TokenProvider.class);
AuthenticationProvider authenticationProvider1 = spy(new AuthenticationProvider(AuthenticationProvider.Type.MSA_COMPACT, "key1", tokenProvider1));
AnalyticsTransmissionTarget.addAuthenticationProvider(authenticationProvider1);
/* Check provider updated in background thread only when AppCenter is configured/started. */
assertNull(AnalyticsTransmissionTarget.sAuthenticationProvider);
verify(authenticationProvider1, never()).acquireTokenAsync();
assertNotNull(backgroundRunnable.getValue());
/* Run background thread. */
backgroundRunnable.getValue().run();
/* Check update. */
assertEquals(authenticationProvider1, AnalyticsTransmissionTarget.sAuthenticationProvider);
verify(authenticationProvider1).acquireTokenAsync();
/* Track an event. */
Analytics.trackEvent("test1");
Runnable trackEvent1Command = backgroundRunnable.getValue();
/* Update authentication provider before the commands run and track a second event. */
AuthenticationProvider.TokenProvider tokenProvider2 = mock(AuthenticationProvider.TokenProvider.class);
AuthenticationProvider authenticationProvider2 = spy(new AuthenticationProvider(AuthenticationProvider.Type.MSA_COMPACT, "key2", tokenProvider2));
AnalyticsTransmissionTarget.addAuthenticationProvider(authenticationProvider2);
Runnable addAuthProvider2Command = backgroundRunnable.getValue();
Analytics.trackEvent("test2");
Runnable trackEvent2Command = backgroundRunnable.getValue();
/* Simulate background thread doing everything in a sequence. */
trackEvent1Command.run();
addAuthProvider2Command.run();
trackEvent2Command.run();
/* Verify first log has first ticket. */
assertEquals(Collections.singletonList(authenticationProvider1.getTicketKeyHash()), sentLogs.get(0).getExt().getProtocol().getTicketKeys());
/* And that we checked expiry. */
verify(authenticationProvider1).checkTokenExpiry();
/* Verify second log has the second ticket. */
assertEquals(Collections.singletonList(authenticationProvider2.getTicketKeyHash()), sentLogs.get(1).getExt().getProtocol().getTicketKeys());
/* And that we checked expiry. */
verify(authenticationProvider2).checkTokenExpiry();
}
use of com.microsoft.appcenter.analytics.ingestion.models.one.CommonSchemaEventLog in project mobile-center-sdk-android by Microsoft.
the class PropertyConfiguratorTest method setNonPrefixUserId.
@Test
public void setNonPrefixUserId() {
CommonSchemaLog log = new CommonSchemaEventLog();
log.setExt(new Extensions());
log.getExt().setUser(new UserExtension());
/* Get property configurator and set properties. */
PropertyConfigurator pc = Analytics.getTransmissionTarget("test").getPropertyConfigurator();
pc.setUserId("bob");
/* Simulate what the pipeline does to convert from App Center to Common Schema. */
log.addTransmissionTarget("test");
log.setTag(Analytics.getTransmissionTarget("test"));
pc.onPreparingLog(log, "groupName");
/* Check prefix was added. */
assertEquals("c:bob", log.getExt().getUser().getLocalId());
}
use of com.microsoft.appcenter.analytics.ingestion.models.one.CommonSchemaEventLog in project mobile-center-sdk-android by Microsoft.
the class PropertyConfiguratorTest method overridingPartAIsNotRetroactive.
@Test
public void overridingPartAIsNotRetroactive() {
/* Mock deviceId. */
mockStatic(Secure.class);
when(Secure.getString(any(ContentResolver.class), anyString())).thenReturn("mockDeviceId");
/* Start analytics and simulate background thread handler (we hold the thread command and run it in the test). */
Analytics analytics = Analytics.getInstance();
AppCenterHandler handler = mock(AppCenterHandler.class);
final LinkedList<Runnable> backgroundCommands = new LinkedList<>();
doAnswer(new Answer() {
@Override
public Object answer(InvocationOnMock invocation) {
backgroundCommands.add((Runnable) invocation.getArguments()[0]);
return null;
}
}).when(handler).post(notNull(Runnable.class), any(Runnable.class));
analytics.onStarting(handler);
analytics.onStarted(mock(Context.class), mChannel, null, null, true);
/* Create a target. */
AnalyticsTransmissionTarget target = Analytics.getTransmissionTarget("test");
/* Init target background code now. */
backgroundCommands.removeFirst().run();
/* Simulate a track event call with no property. */
CommonSchemaLog logBeforeSetProperty = new CommonSchemaEventLog();
logBeforeSetProperty.setExt(new Extensions());
logBeforeSetProperty.getExt().setApp(new AppExtension());
logBeforeSetProperty.getExt().setUser(new UserExtension());
logBeforeSetProperty.getExt().setDevice(new DeviceExtension());
/* Simulate what the pipeline does to convert from App Center to Common Schema. */
logBeforeSetProperty.addTransmissionTarget("test");
logBeforeSetProperty.setTag(target);
/* Set all common properties that should not be set retroactively before first log persisted. */
target.getPropertyConfigurator().setAppVersion("appVersion");
target.getPropertyConfigurator().setAppLocale("appLocale");
target.getPropertyConfigurator().setAppName("appName");
target.getPropertyConfigurator().setUserId("c:alice");
target.getPropertyConfigurator().collectDeviceId();
/* Run background commands in order: first prepare first log, then all the set property calls. */
target.getPropertyConfigurator().onPreparingLog(logBeforeSetProperty, "groupName");
for (Runnable command : backgroundCommands) {
command.run();
}
/* Simulate the second track event call. */
CommonSchemaLog logAfterSetProperty = new CommonSchemaEventLog();
logAfterSetProperty.setExt(new Extensions());
logAfterSetProperty.getExt().setApp(new AppExtension());
logAfterSetProperty.getExt().setUser(new UserExtension());
logAfterSetProperty.getExt().setDevice(new DeviceExtension());
/* Simulate what the pipeline does to convert from App Center to Common Schema. */
logAfterSetProperty.addTransmissionTarget("test");
logAfterSetProperty.setTag(target);
target.getPropertyConfigurator().onPreparingLog(logAfterSetProperty, "groupName");
/* Check first log has no property. */
assertNull(logBeforeSetProperty.getExt().getApp().getVer());
assertNull(logBeforeSetProperty.getExt().getApp().getLocale());
assertNull(logBeforeSetProperty.getExt().getApp().getName());
assertNull(logBeforeSetProperty.getExt().getUser().getLocalId());
assertNull(logBeforeSetProperty.getExt().getDevice().getLocalId());
/* Check second log has all of them. */
assertEquals("appVersion", logAfterSetProperty.getExt().getApp().getVer());
assertEquals("appLocale", logAfterSetProperty.getExt().getApp().getLocale());
assertEquals("appName", logAfterSetProperty.getExt().getApp().getName());
assertEquals("c:alice", logAfterSetProperty.getExt().getUser().getLocalId());
assertEquals("a:mockDeviceId", logAfterSetProperty.getExt().getDevice().getLocalId());
}
use of com.microsoft.appcenter.analytics.ingestion.models.one.CommonSchemaEventLog in project mobile-center-sdk-android by Microsoft.
the class EventLogFactory method toCommonSchemaLogs.
@Override
public Collection<CommonSchemaLog> toCommonSchemaLogs(Log log) {
Collection<CommonSchemaLog> commonSchemaLogs = new LinkedList<>();
for (String transmissionTarget : log.getTransmissionTargetTokens()) {
/* Part A common fields. */
CommonSchemaEventLog commonSchemaEventLog = new CommonSchemaEventLog();
/* Event name goes to Part A. */
EventLog eventLog = (EventLog) log;
PartAUtils.setName(commonSchemaEventLog, eventLog.getName());
/* Add common Part A fields. */
PartAUtils.addPartAFromLog(log, commonSchemaEventLog, transmissionTarget);
/* Part B, C and Part A metadata. */
CommonSchemaDataUtils.addCommonSchemaData(eventLog.getTypedProperties(), commonSchemaEventLog);
commonSchemaLogs.add(commonSchemaEventLog);
/* Copy tag. */
commonSchemaEventLog.setTag(log.getTag());
}
return commonSchemaLogs;
}
Aggregations