use of com.microsoft.applicationinsights.smoketest.schemav2.Envelope in project ApplicationInsights-Java by microsoft.
the class SpringBootAutoTest method test.
@Test
@TargetUri("/test")
public void test() throws Exception {
List<Envelope> rdList = mockedIngestion.waitForItems("RequestData", 1);
List<Envelope> mdList = mockedIngestion.waitForMessageItemsInRequest(1);
Envelope rdEnvelope = rdList.get(0);
Envelope mdEnvelope = mdList.get(0);
RequestData rd = (RequestData) ((Data<?>) rdEnvelope.getData()).getBaseData();
MessageData md = (MessageData) ((Data<?>) mdEnvelope.getData()).getBaseData();
assertEquals("GET /test", rd.getName());
assertEquals("200", rd.getResponseCode());
assertEquals("z", rd.getProperties().get("tenant"));
assertEquals(1, rd.getProperties().size());
assertTrue(rd.getSuccess());
assertEquals("hello", md.getMessage());
assertEquals(SeverityLevel.Information, md.getSeverityLevel());
assertEquals("Logger", md.getProperties().get("SourceType"));
assertEquals("INFO", md.getProperties().get("LoggingLevel"));
assertEquals("smoketestapp", md.getProperties().get("LoggerName"));
assertNotNull(md.getProperties().get("ThreadName"));
assertEquals("z", rd.getProperties().get("tenant"));
assertEquals(5, md.getProperties().size());
}
use of com.microsoft.applicationinsights.smoketest.schemav2.Envelope in project ApplicationInsights-Java by microsoft.
the class StatsbeatSmokeTest method testStatsbeat.
@Test
@TargetUri(value = "/index.jsp")
public void testStatsbeat() throws Exception {
List<Envelope> metrics = mockedIngestion.waitForItems(getMetricPredicate("Feature"), 2, 70, TimeUnit.SECONDS);
MetricData data = (MetricData) ((Data<?>) metrics.get(0).getData()).getBaseData();
assertCommon(data);
assertNotNull(data.getProperties().get("feature"));
assertNotNull(data.getProperties().get("type"));
assertEquals("0", data.getProperties().get("type"));
assertEquals(9, data.getProperties().size());
MetricData instrumentationData = (MetricData) ((Data<?>) metrics.get(1).getData()).getBaseData();
assertCommon(instrumentationData);
assertNotNull(instrumentationData.getProperties().get("feature"));
assertNotNull(instrumentationData.getProperties().get("type"));
assertEquals("1", instrumentationData.getProperties().get("type"));
assertEquals(9, instrumentationData.getProperties().size());
List<Envelope> attachMetrics = mockedIngestion.waitForItems(getMetricPredicate("Attach"), 1, 70, TimeUnit.SECONDS);
MetricData attachData = (MetricData) ((Data<?>) attachMetrics.get(0).getData()).getBaseData();
assertCommon(attachData);
assertNotNull(attachData.getProperties().get("rpId"));
assertEquals(8, attachData.getProperties().size());
List<Envelope> requestSuccessCountMetrics = mockedIngestion.waitForItems(getMetricPredicate("Request Success Count"), 1, 70, TimeUnit.SECONDS);
MetricData requestSuccessCountData = (MetricData) ((Data<?>) requestSuccessCountMetrics.get(0).getData()).getBaseData();
assertCommon(requestSuccessCountData);
assertNotNull(requestSuccessCountData.getProperties().get("endpoint"));
assertNotNull(requestSuccessCountData.getProperties().get("host"));
assertEquals(9, requestSuccessCountData.getProperties().size());
List<Envelope> requestDurationMetrics = mockedIngestion.waitForItems(getMetricPredicate("Request Duration"), 1, 70, TimeUnit.SECONDS);
MetricData requestDurationData = (MetricData) ((Data<?>) requestDurationMetrics.get(0).getData()).getBaseData();
assertCommon(requestDurationData);
assertNotNull(requestSuccessCountData.getProperties().get("endpoint"));
assertNotNull(requestSuccessCountData.getProperties().get("host"));
assertEquals(9, requestDurationData.getProperties().size());
}
use of com.microsoft.applicationinsights.smoketest.schemav2.Envelope in project ApplicationInsights-Java by microsoft.
the class TraceLogBackTest method testTraceLogBackWithExeption.
@Test
@TargetUri("traceLogBackWithException")
public void testTraceLogBackWithExeption() throws Exception {
List<Envelope> rdList = mockedIngestion.waitForItems("RequestData", 1);
Envelope rdEnvelope = rdList.get(0);
String operationId = rdEnvelope.getTags().get("ai.operation.id");
List<Envelope> edList = mockedIngestion.waitForItemsInOperation("ExceptionData", 1, operationId);
assertEquals(0, mockedIngestion.getCountForType("EventData"));
Envelope edEnvelope = edList.get(0);
RequestData rd = (RequestData) ((Data<?>) rdEnvelope.getData()).getBaseData();
ExceptionData ed = (ExceptionData) ((Data<?>) edEnvelope.getData()).getBaseData();
assertEquals("Fake Exception", ed.getExceptions().get(0).getMessage());
assertEquals(SeverityLevel.Error, ed.getSeverityLevel());
assertEquals("This is an exception!", ed.getProperties().get("Logger Message"));
assertEquals("Logger", ed.getProperties().get("SourceType"));
assertEquals("ERROR", ed.getProperties().get("LoggingLevel"));
assertEquals("smoketestapp", ed.getProperties().get("LoggerName"));
assertNotNull(ed.getProperties().get("ThreadName"));
// TODO add MDC instrumentation for jboss logging
if (!currentImageName.contains("wildfly")) {
assertEquals("MDC value", ed.getProperties().get("MDC key"));
assertEquals(6, ed.getProperties().size());
} else {
assertEquals(5, ed.getProperties().size());
}
assertParentChild(rd, rdEnvelope, edEnvelope, "GET /TraceLogBackUsingAgent/traceLogBackWithException");
}
use of com.microsoft.applicationinsights.smoketest.schemav2.Envelope in project ApplicationInsights-Java by microsoft.
the class TraceJavaUtilLoggingTest method testTraceJavaUtilLogging.
@Test
@TargetUri("/traceJavaUtilLogging")
public void testTraceJavaUtilLogging() throws Exception {
List<Envelope> rdList = mockedIngestion.waitForItems("RequestData", 1);
List<Envelope> mdList = mockedIngestion.waitForMessageItemsInRequest(2);
Envelope rdEnvelope = rdList.get(0);
Envelope mdEnvelope1 = mdList.get(0);
Envelope mdEnvelope2 = mdList.get(1);
RequestData rd = (RequestData) ((Data<?>) rdEnvelope.getData()).getBaseData();
List<MessageData> logs = mockedIngestion.getMessageDataInRequest();
logs.sort(Comparator.comparing(MessageData::getSeverityLevel));
MessageData md1 = logs.get(0);
MessageData md2 = logs.get(1);
assertEquals("This is jul warning.", md1.getMessage());
assertEquals(SeverityLevel.Warning, md1.getSeverityLevel());
assertEquals("Logger", md1.getProperties().get("SourceType"));
assertEquals("WARNING", md1.getProperties().get("LoggingLevel"));
assertEquals("smoketestapp", md1.getProperties().get("LoggerName"));
assertNotNull(md1.getProperties().get("ThreadName"));
assertEquals(4, md1.getProperties().size());
assertEquals("This is jul severe.", md2.getMessage());
assertEquals(SeverityLevel.Error, md2.getSeverityLevel());
assertEquals("Logger", md2.getProperties().get("SourceType"));
assertEquals("SEVERE", md2.getProperties().get("LoggingLevel"));
assertEquals("smoketestapp", md1.getProperties().get("LoggerName"));
assertNotNull(md2.getProperties().get("ThreadName"));
assertEquals(4, md2.getProperties().size());
assertParentChild(rd, rdEnvelope, mdEnvelope1, "GET /TraceJavaUtilLoggingUsingAgent/traceJavaUtilLogging");
assertParentChild(rd, rdEnvelope, mdEnvelope2, "GET /TraceJavaUtilLoggingUsingAgent/traceJavaUtilLogging");
}
use of com.microsoft.applicationinsights.smoketest.schemav2.Envelope in project ApplicationInsights-Java by microsoft.
the class GrpcTest method doSimpleTest.
@Test
@TargetUri("/simple")
public void doSimpleTest() throws Exception {
List<Envelope> rdList = mockedIngestion.waitForItems("RequestData", 2);
Envelope rdEnvelope1 = getRequestEnvelope(rdList, "GET /simple");
Envelope rdEnvelope2 = getRequestEnvelope(rdList, "example.Greeter/SayHello");
String operationId = rdEnvelope1.getTags().get("ai.operation.id");
List<Envelope> rddList = mockedIngestion.waitForItemsInOperation("RemoteDependencyData", 1, operationId);
// auto-collected grpc events are suppressed by exporter because they are noisy
assertEquals(0, mockedIngestion.getCountForType("MessageData", operationId));
Envelope rddEnvelope = getDependencyEnvelope(rddList, "example.Greeter/SayHello");
RequestData rd1 = (RequestData) ((Data<?>) rdEnvelope1.getData()).getBaseData();
RemoteDependencyData rdd = (RemoteDependencyData) ((Data<?>) rddEnvelope.getData()).getBaseData();
// TODO this is not correct (or at least not ideal)
// see https://msazure.visualstudio.com/One/_workitems/edit/8687985
assertEquals("grpc", rdd.getTarget());
assertTrue(rd1.getProperties().isEmpty());
assertTrue(rd1.getSuccess());
assertTrue(rdd.getProperties().isEmpty());
assertTrue(rdd.getSuccess());
// TODO (trask): verify rd2
assertParentChild(rd1, rdEnvelope1, rddEnvelope, "GET /simple");
assertParentChild(rdd.getId(), rddEnvelope, rdEnvelope2, "GET /simple", "example.Greeter/SayHello", false);
}
Aggregations