Search in sources :

Example 1 with ITelemetryAggregatedObserver

use of com.microsoft.identity.common.internal.telemetry.observers.ITelemetryAggregatedObserver in project microsoft-authentication-library-common-for-android by AzureAD.

the class TelemetryTest method testAddAndRemoveObserverSuccess.

@Test
public void testAddAndRemoveObserverSuccess() {
    ITelemetryAggregatedObserver telemetryAggregatedObserver = new ITelemetryAggregatedObserver() {

        @Override
        public void onReceived(Map<String, String> telemetryData) {
        }
    };
    Telemetry.getInstance().addObserver(telemetryAggregatedObserver);
    Assert.assertEquals(1, Telemetry.getInstance().getObservers().size());
    Assert.assertTrue(Telemetry.getInstance().getObservers().contains(telemetryAggregatedObserver));
    Telemetry.getInstance().removeObserver(telemetryAggregatedObserver);
    Assert.assertEquals(0, Telemetry.getInstance().getObservers().size());
    Assert.assertFalse(Telemetry.getInstance().getObservers().contains(telemetryAggregatedObserver));
}
Also used : ITelemetryAggregatedObserver(com.microsoft.identity.common.internal.telemetry.observers.ITelemetryAggregatedObserver) Map(java.util.Map) Test(org.junit.Test)

Example 2 with ITelemetryAggregatedObserver

use of com.microsoft.identity.common.internal.telemetry.observers.ITelemetryAggregatedObserver in project microsoft-authentication-library-common-for-android by AzureAD.

the class TelemetryTest method testAddAndRemoveMultipleObserversSuccess.

@Test
public void testAddAndRemoveMultipleObserversSuccess() {
    ITelemetryAggregatedObserver telemetryAggregatedObserver = new ITelemetryAggregatedObserver() {

        @Override
        public void onReceived(Map<String, String> telemetryData) {
        }
    };
    ITelemetryDefaultObserver telemetryDefaultObserver = new ITelemetryDefaultObserver() {

        @Override
        public void onReceived(List<Map<String, String>> telemetryData) {
        }
    };
    ITelemetryObserver telemetryObserver = new ITelemetryObserver() {

        @Override
        public void onReceived(Object telemetryData) {
        }
    };
    Telemetry.getInstance().addObserver(telemetryAggregatedObserver);
    Telemetry.getInstance().addObserver(telemetryDefaultObserver);
    Telemetry.getInstance().addObserver(telemetryObserver);
    Assert.assertEquals(3, Telemetry.getInstance().getObservers().size());
    Assert.assertTrue(Telemetry.getInstance().getObservers().contains(telemetryAggregatedObserver));
    Assert.assertTrue(Telemetry.getInstance().getObservers().contains(telemetryDefaultObserver));
    Assert.assertTrue(Telemetry.getInstance().getObservers().contains(telemetryObserver));
    Telemetry.getInstance().removeObserver(telemetryDefaultObserver);
    Telemetry.getInstance().removeObserver(telemetryAggregatedObserver);
    Telemetry.getInstance().removeObserver(telemetryObserver);
    Assert.assertEquals(0, Telemetry.getInstance().getObservers().size());
}
Also used : ITelemetryDefaultObserver(com.microsoft.identity.common.internal.telemetry.observers.ITelemetryDefaultObserver) ITelemetryObserver(com.microsoft.identity.common.internal.telemetry.observers.ITelemetryObserver) ITelemetryAggregatedObserver(com.microsoft.identity.common.internal.telemetry.observers.ITelemetryAggregatedObserver) List(java.util.List) Map(java.util.Map) Test(org.junit.Test)

Example 3 with ITelemetryAggregatedObserver

use of com.microsoft.identity.common.internal.telemetry.observers.ITelemetryAggregatedObserver in project microsoft-authentication-library-common-for-android by AzureAD.

the class Telemetry method flush.

/**
 * Flush the telemetry data based on the correlation id to the observers.
 *
 * @param correlationId The correlation id should either passed by the client app through the API call
 *                      or generated by the API dispatcher.
 */
public void flush(@NonNull final String correlationId) {
    if (!mIsTelemetryEnabled) {
        return;
    }
    if (null == mObservers) {
        Logger.warn(TAG, "No telemetry observer set.");
        return;
    }
    if (StringUtil.isEmpty(correlationId)) {
        Logger.warn(TAG, "No correlation id set.");
        return;
    }
    // check the configuration
    if (!mDefaultConfiguration.isDebugEnabled() && mIsDebugging) {
        return;
    }
    List<Map<String, String>> finalRawMap = new CopyOnWriteArrayList<>();
    for (Iterator<Map<String, String>> iterator = mTelemetryRawDataMap.iterator(); iterator.hasNext(); ) {
        Map<String, String> event = iterator.next();
        if (correlationId.equalsIgnoreCase(event.get(Key.CORRELATION_ID))) {
            finalRawMap.add(applyPiiOiiRule(event));
            iterator.remove();
        }
    }
    // Add the telemetry context to the telemetry data
    finalRawMap.add(applyPiiOiiRule(mTelemetryContext.getProperties()));
    for (@SuppressWarnings(WarningType.rawtype_warning) ITelemetryObserver observer : mObservers) {
        if (observer instanceof ITelemetryAggregatedObserver) {
            new TelemetryAggregationAdapter((ITelemetryAggregatedObserver) observer).process(finalRawMap);
        } else if (observer instanceof ITelemetryDefaultObserver) {
            new TelemetryDefaultAdapter((ITelemetryDefaultObserver) observer).process(finalRawMap);
        } else {
            Logger.warn(TAG, "Unknown observer type: " + observer.getClass());
        }
    }
}
Also used : TelemetryAggregationAdapter(com.microsoft.identity.common.internal.telemetry.adapter.TelemetryAggregationAdapter) ITelemetryObserver(com.microsoft.identity.common.internal.telemetry.observers.ITelemetryObserver) ITelemetryDefaultObserver(com.microsoft.identity.common.internal.telemetry.observers.ITelemetryDefaultObserver) TelemetryDefaultAdapter(com.microsoft.identity.common.internal.telemetry.adapter.TelemetryDefaultAdapter) ITelemetryAggregatedObserver(com.microsoft.identity.common.internal.telemetry.observers.ITelemetryAggregatedObserver) HashMap(java.util.HashMap) Map(java.util.Map) CopyOnWriteArrayList(java.util.concurrent.CopyOnWriteArrayList)

Example 4 with ITelemetryAggregatedObserver

use of com.microsoft.identity.common.internal.telemetry.observers.ITelemetryAggregatedObserver in project microsoft-authentication-library-common-for-android by AzureAD.

the class TelemetryTest method testITelemetryAggregatedObserver.

@Test
public void testITelemetryAggregatedObserver() {
    Telemetry.getInstance().addObserver(new ITelemetryAggregatedObserver() {

        @Override
        public void onReceived(Map<String, String> telemetryData) {
            final String apiId = telemetryData.get(TelemetryEventStrings.Key.API_ID);
            Assert.assertEquals("100", apiId);
        }
    });
    Telemetry.emit(new ApiStartEvent().putApiId("100"));
    Telemetry.getInstance().flush();
}
Also used : ApiStartEvent(com.microsoft.identity.common.internal.telemetry.events.ApiStartEvent) ITelemetryAggregatedObserver(com.microsoft.identity.common.internal.telemetry.observers.ITelemetryAggregatedObserver) Test(org.junit.Test)

Aggregations

ITelemetryAggregatedObserver (com.microsoft.identity.common.internal.telemetry.observers.ITelemetryAggregatedObserver)4 Map (java.util.Map)3 Test (org.junit.Test)3 ITelemetryDefaultObserver (com.microsoft.identity.common.internal.telemetry.observers.ITelemetryDefaultObserver)2 ITelemetryObserver (com.microsoft.identity.common.internal.telemetry.observers.ITelemetryObserver)2 TelemetryAggregationAdapter (com.microsoft.identity.common.internal.telemetry.adapter.TelemetryAggregationAdapter)1 TelemetryDefaultAdapter (com.microsoft.identity.common.internal.telemetry.adapter.TelemetryDefaultAdapter)1 ApiStartEvent (com.microsoft.identity.common.internal.telemetry.events.ApiStartEvent)1 HashMap (java.util.HashMap)1 List (java.util.List)1 CopyOnWriteArrayList (java.util.concurrent.CopyOnWriteArrayList)1