use of com.adobe.target.delivery.v1.model.TelemetryEntry in project target-java-sdk by adobe.
the class TelemetryService method addTelemetry.
public void addTelemetry(Double artifactDownloadTime) {
TelemetryEntry telemetryEntry = new TelemetryEntry();
telemetryEntry.setExecution(artifactDownloadTime);
telemetryEntry.setRequestId("ArtifactDownload");
telemetryEntry.setTimestamp(System.currentTimeMillis());
storedTelemetries.add(telemetryEntry);
}
use of com.adobe.target.delivery.v1.model.TelemetryEntry in project target-java-sdk by adobe.
the class TelemetryService method getTelemetry.
public Telemetry getTelemetry() {
List<TelemetryEntry> telemetryEntryList = new ArrayList<>();
TelemetryEntry telemetryEntry;
while ((telemetryEntry = storedTelemetries.poll()) != null) {
telemetryEntryList.add(telemetryEntry);
}
return new Telemetry().entries(telemetryEntryList);
}
use of com.adobe.target.delivery.v1.model.TelemetryEntry in project target-java-sdk by adobe.
the class TelemetryService method addTelemetry.
public void addTelemetry(TargetDeliveryRequest deliveryRequest, TimingTool timer, TargetDeliveryResponse targetDeliveryResponse, double parsingTime, long responseSize) {
TelemetryEntry telemetryEntry = createTelemetryEntry(deliveryRequest, targetDeliveryResponse, timer.timeEnd(TIMING_EXECUTE_REQUEST));
if (telemetryEntry == null) {
return;
}
telemetryEntry.setParsing(parsingTime);
TelemetryRequest telemetryRequest = new TelemetryRequest();
telemetryRequest.setResponseSize(responseSize);
telemetryEntry.setRequest(telemetryRequest);
storedTelemetries.add(telemetryEntry);
}
use of com.adobe.target.delivery.v1.model.TelemetryEntry in project target-java-sdk by adobe.
the class TelemetryServiceTest method testAddTelemetryForServerSide.
/**
* Checking all telemetryEntry features which gets added for server side decisioning
*
* @throws NoSuchFieldException
*/
@Test
void testAddTelemetryForServerSide() throws NoSuchFieldException {
setup(true, DecisioningMethod.SERVER_SIDE, "testAddTelemetryForServerSide");
TimingTool timer = new TimingTool();
timer.timeStart(TIMING_EXECUTE_REQUEST);
Context context = getContext();
PrefetchRequest prefetchRequest = getPrefetchViewsRequest();
ExecuteRequest executeRequest = getMboxExecuteRequest();
String nonDefaultToken = "non-default-token";
TargetDeliveryRequest targetDeliveryRequest = TargetDeliveryRequest.builder().context(context).prefetch(prefetchRequest).execute(executeRequest).property(new Property().token(nonDefaultToken)).decisioningMethod(DecisioningMethod.SERVER_SIDE).build();
DeliveryResponse deliveryResponse = new DeliveryResponse();
deliveryResponse.setClient("SUMMIT_TEST2021");
deliveryResponse.setEdgeHost("mboxedge35.tt.omtrdc.net");
TargetDeliveryResponse targetDeliveryResponse = new TargetDeliveryResponse(targetDeliveryRequest, deliveryResponse, 200, "test call");
targetDeliveryResponse.getResponse().setRequestId("testID");
targetDeliveryResponse.getResponse().setTelemetryServerToken("testServerToken2022");
telemetryServiceSpy.addTelemetry(targetDeliveryRequest, timer, targetDeliveryResponse);
TelemetryEntry telemetryEntry = telemetryServiceSpy.getTelemetry().getEntries().get(0);
assertNotNull(telemetryEntry);
assertEquals(3, telemetryEntry.getFeatures().getExecuteMboxCount());
assertEquals(1, telemetryEntry.getFeatures().getPrefetchViewCount());
assertEquals(true, telemetryEntry.getFeatures().getExecutePageLoad());
assertEquals(true, telemetryEntry.getFeatures().getPrefetchPageLoad());
assertEquals(3, telemetryEntry.getFeatures().getPrefetchMboxCount());
assertEquals("testID", telemetryEntry.getRequestId());
assertEquals("testServerToken2022", telemetryEntry.getTelemetryServerToken());
assertEquals(ExecutionMode.EDGE, telemetryEntry.getMode());
assertEquals(DecisioningMethod.SERVER_SIDE.toString(), telemetryEntry.getFeatures().getDecisioningMethod());
}
use of com.adobe.target.delivery.v1.model.TelemetryEntry in project target-java-sdk by adobe.
the class TelemetryServiceTest method testExecutionModeForHybridWithNotAllLocal.
/**
* Test to verify telemetryEntry has correct executionMode For hybrid & status 200 we should have
* mode as local
*
* @throws NoSuchFieldException
*/
@Test
void testExecutionModeForHybridWithNotAllLocal() throws NoSuchFieldException {
setup(true, DecisioningMethod.HYBRID, "testExecutionModeHybridWithNotALlLocal");
TimingTool timer = new TimingTool();
timer.timeStart(TIMING_EXECUTE_REQUEST);
Context context = getContext();
PrefetchRequest prefetchRequest = getPrefetchViewsRequest();
ExecuteRequest executeRequest = getMboxExecuteRequest();
String nonDefaultToken = "non-default-token";
TargetDeliveryRequest targetDeliveryRequest = TargetDeliveryRequest.builder().context(context).prefetch(prefetchRequest).execute(executeRequest).property(new Property().token(nonDefaultToken)).decisioningMethod(DecisioningMethod.HYBRID).build();
DeliveryResponse deliveryResponse = new DeliveryResponse();
deliveryResponse.setClient("SUMMIT_TEST2021");
deliveryResponse.setEdgeHost("mboxedge35.tt.omtrdc.net");
TargetDeliveryResponse targetDeliveryResponse = new TargetDeliveryResponse(targetDeliveryRequest, deliveryResponse, 200, "test call");
targetDeliveryResponse.getResponse().setRequestId("testID");
telemetryServiceSpy.addTelemetry(targetDeliveryRequest, timer, targetDeliveryResponse);
TelemetryEntry telemetryEntry = telemetryServiceSpy.getTelemetry().getEntries().get(1);
assert telemetryEntry != null;
assertEquals(ExecutionMode.EDGE, telemetryEntry.getMode());
}
Aggregations