Java Code Examples for com.amazonaws.xray.entities.Subsegment#getCause()
The following examples show how to use
com.amazonaws.xray.entities.Subsegment#getCause() .
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source File: TracingInterceptorTest.java From aws-xray-sdk-java with Apache License 2.0 | 4 votes |
@Test public void test400Exception() throws Exception { SdkHttpClient mockClient = mockSdkHttpClient(generateLambdaInvokeResponse(400)); LambdaClient client = LambdaClient.builder() .httpClient(mockClient) .endpointOverride(URI.create("http://example.com")) .region(Region.of("us-west-42")) .credentialsProvider(StaticCredentialsProvider.create( AwsSessionCredentials.create("key", "secret", "session") )) .overrideConfiguration(ClientOverrideConfiguration.builder() .addExecutionInterceptor(new TracingInterceptor()) .build() ) .build(); Segment segment = AWSXRay.getCurrentSegment(); try { client.invoke(InvokeRequest.builder() .functionName("testFunctionName") .build() ); } catch (Exception e) { // ignore SDK errors } finally { Assert.assertEquals(1, segment.getSubsegments().size()); Subsegment subsegment = segment.getSubsegments().get(0); Map<String, Object> awsStats = subsegment.getAws(); @SuppressWarnings("unchecked") Map<String, Object> httpResponseStats = (Map<String, Object>) subsegment.getHttp().get("response"); Cause cause = subsegment.getCause(); Assert.assertEquals("Invoke", awsStats.get("operation")); Assert.assertEquals("testFunctionName", awsStats.get("function_name")); Assert.assertEquals("1111-2222-3333-4444", awsStats.get("request_id")); Assert.assertEquals("extended", awsStats.get("id_2")); Assert.assertEquals("us-west-42", awsStats.get("region")); Assert.assertEquals(0, awsStats.get("retries")); Assert.assertEquals(2L, httpResponseStats.get("content_length")); Assert.assertEquals(400, httpResponseStats.get("status")); Assert.assertEquals(false, subsegment.isInProgress()); Assert.assertEquals(true, subsegment.isError()); Assert.assertEquals(false, subsegment.isThrottle()); Assert.assertEquals(false, subsegment.isFault()); Assert.assertEquals(1, cause.getExceptions().size()); Assert.assertEquals(true, cause.getExceptions().get(0).isRemote()); } }
Example 2
Source File: TracingInterceptorTest.java From aws-xray-sdk-java with Apache License 2.0 | 4 votes |
@Test public void testAsync400Exception() { SdkAsyncHttpClient mockClient = mockSdkAsyncHttpClient(generateLambdaInvokeResponse(400)); LambdaAsyncClient client = LambdaAsyncClient.builder() .httpClient(mockClient) .endpointOverride(URI.create("http://example.com")) .region(Region.of("us-west-42")) .credentialsProvider(StaticCredentialsProvider.create( AwsSessionCredentials.create("key", "secret", "session") )) .overrideConfiguration(ClientOverrideConfiguration.builder() .addExecutionInterceptor(new TracingInterceptor()) .build() ) .build(); Segment segment = AWSXRay.getCurrentSegment(); try { client.invoke(InvokeRequest.builder() .functionName("testFunctionName") .build() ).get(); } catch (Exception e) { // ignore exceptions } finally { Assert.assertEquals(1, segment.getSubsegments().size()); Subsegment subsegment = segment.getSubsegments().get(0); Map<String, Object> awsStats = subsegment.getAws(); @SuppressWarnings("unchecked") Map<String, Object> httpResponseStats = (Map<String, Object>) subsegment.getHttp().get("response"); Cause cause = subsegment.getCause(); Assert.assertEquals("Invoke", awsStats.get("operation")); Assert.assertEquals("testFunctionName", awsStats.get("function_name")); Assert.assertEquals("1111-2222-3333-4444", awsStats.get("request_id")); Assert.assertEquals("extended", awsStats.get("id_2")); Assert.assertEquals("us-west-42", awsStats.get("region")); Assert.assertEquals(0, awsStats.get("retries")); Assert.assertEquals(2L, httpResponseStats.get("content_length")); Assert.assertEquals(400, httpResponseStats.get("status")); Assert.assertEquals(false, subsegment.isInProgress()); Assert.assertEquals(true, subsegment.isError()); Assert.assertEquals(false, subsegment.isThrottle()); Assert.assertEquals(false, subsegment.isFault()); Assert.assertEquals(1, cause.getExceptions().size()); Assert.assertEquals(true, cause.getExceptions().get(0).isRemote()); } }
Example 3
Source File: TracingInterceptorTest.java From aws-xray-sdk-java with Apache License 2.0 | 4 votes |
@Test public void testThrottledException() throws Exception { SdkHttpClient mockClient = mockSdkHttpClient(generateLambdaInvokeResponse(429)); LambdaClient client = LambdaClient.builder() .httpClient(mockClient) .endpointOverride(URI.create("http://example.com")) .region(Region.of("us-west-42")) .credentialsProvider(StaticCredentialsProvider.create( AwsSessionCredentials.create("key", "secret", "session") )) .overrideConfiguration(ClientOverrideConfiguration.builder() .addExecutionInterceptor(new TracingInterceptor()) .build() ) .build(); Segment segment = AWSXRay.getCurrentSegment(); try { client.invoke(InvokeRequest.builder() .functionName("testFunctionName") .build() ); } catch (Exception e) { // ignore SDK errors } finally { Assert.assertEquals(1, segment.getSubsegments().size()); Subsegment subsegment = segment.getSubsegments().get(0); Map<String, Object> awsStats = subsegment.getAws(); @SuppressWarnings("unchecked") Map<String, Object> httpResponseStats = (Map<String, Object>) subsegment.getHttp().get("response"); Cause cause = subsegment.getCause(); Assert.assertEquals("Invoke", awsStats.get("operation")); Assert.assertEquals("testFunctionName", awsStats.get("function_name")); Assert.assertEquals("1111-2222-3333-4444", awsStats.get("request_id")); Assert.assertEquals("extended", awsStats.get("id_2")); Assert.assertEquals("us-west-42", awsStats.get("region")); // throttled requests are retried Assert.assertEquals(3, awsStats.get("retries")); Assert.assertEquals(2L, httpResponseStats.get("content_length")); Assert.assertEquals(429, httpResponseStats.get("status")); Assert.assertEquals(true, subsegment.isError()); Assert.assertEquals(true, subsegment.isThrottle()); Assert.assertEquals(false, subsegment.isFault()); Assert.assertEquals(1, cause.getExceptions().size()); Assert.assertEquals(true, cause.getExceptions().get(0).isRemote()); } }
Example 4
Source File: TracingInterceptorTest.java From aws-xray-sdk-java with Apache License 2.0 | 4 votes |
@Test public void testAsyncThrottledException() { SdkAsyncHttpClient mockClient = mockSdkAsyncHttpClient(generateLambdaInvokeResponse(429)); LambdaAsyncClient client = LambdaAsyncClient.builder() .httpClient(mockClient) .endpointOverride(URI.create("http://example.com")) .region(Region.of("us-west-42")) .credentialsProvider(StaticCredentialsProvider.create( AwsSessionCredentials.create("key", "secret", "session") )) .overrideConfiguration(ClientOverrideConfiguration.builder() .addExecutionInterceptor(new TracingInterceptor()) .build() ) .build(); Segment segment = AWSXRay.getCurrentSegment(); try { client.invoke(InvokeRequest.builder() .functionName("testFunctionName") .build() ).get(); } catch (Exception e) { // ignore exceptions } finally { Assert.assertEquals(1, segment.getSubsegments().size()); Subsegment subsegment = segment.getSubsegments().get(0); Map<String, Object> awsStats = subsegment.getAws(); @SuppressWarnings("unchecked") Map<String, Object> httpResponseStats = (Map<String, Object>) subsegment.getHttp().get("response"); Cause cause = subsegment.getCause(); Assert.assertEquals("Invoke", awsStats.get("operation")); Assert.assertEquals("testFunctionName", awsStats.get("function_name")); Assert.assertEquals("1111-2222-3333-4444", awsStats.get("request_id")); Assert.assertEquals("extended", awsStats.get("id_2")); Assert.assertEquals("us-west-42", awsStats.get("region")); // throttled requests are retried Assert.assertEquals(3, awsStats.get("retries")); Assert.assertEquals(2L, httpResponseStats.get("content_length")); Assert.assertEquals(429, httpResponseStats.get("status")); Assert.assertEquals(true, subsegment.isError()); Assert.assertEquals(true, subsegment.isThrottle()); Assert.assertEquals(false, subsegment.isFault()); Assert.assertEquals(1, cause.getExceptions().size()); Assert.assertEquals(true, cause.getExceptions().get(0).isRemote()); } }
Example 5
Source File: TracingInterceptorTest.java From aws-xray-sdk-java with Apache License 2.0 | 4 votes |
@Test public void test500Exception() throws Exception { SdkHttpClient mockClient = mockSdkHttpClient(generateLambdaInvokeResponse(500)); LambdaClient client = LambdaClient.builder() .httpClient(mockClient) .endpointOverride(URI.create("http://example.com")) .region(Region.of("us-west-42")) .credentialsProvider(StaticCredentialsProvider.create( AwsSessionCredentials.create("key", "secret", "session") )) .overrideConfiguration(ClientOverrideConfiguration.builder() .addExecutionInterceptor(new TracingInterceptor()) .build() ) .build(); Segment segment = AWSXRay.getCurrentSegment(); try { client.invoke(InvokeRequest.builder() .functionName("testFunctionName") .build() ); } catch (Exception e) { // ignore SDK errors } finally { Assert.assertEquals(1, segment.getSubsegments().size()); Subsegment subsegment = segment.getSubsegments().get(0); Map<String, Object> awsStats = subsegment.getAws(); @SuppressWarnings("unchecked") Map<String, Object> httpResponseStats = (Map<String, Object>) subsegment.getHttp().get("response"); Cause cause = subsegment.getCause(); Assert.assertEquals("Invoke", awsStats.get("operation")); Assert.assertEquals("testFunctionName", awsStats.get("function_name")); Assert.assertEquals("1111-2222-3333-4444", awsStats.get("request_id")); Assert.assertEquals("extended", awsStats.get("id_2")); Assert.assertEquals("us-west-42", awsStats.get("region")); // 500 exceptions are retried Assert.assertEquals(3, awsStats.get("retries")); Assert.assertEquals(2L, httpResponseStats.get("content_length")); Assert.assertEquals(500, httpResponseStats.get("status")); Assert.assertEquals(false, subsegment.isError()); Assert.assertEquals(false, subsegment.isThrottle()); Assert.assertEquals(true, subsegment.isFault()); Assert.assertEquals(1, cause.getExceptions().size()); Assert.assertEquals(true, cause.getExceptions().get(0).isRemote()); } }
Example 6
Source File: TracingInterceptorTest.java From aws-xray-sdk-java with Apache License 2.0 | 4 votes |
@Test public void testAsync500Exception() { SdkAsyncHttpClient mockClient = mockSdkAsyncHttpClient(generateLambdaInvokeResponse(500)); LambdaAsyncClient client = LambdaAsyncClient.builder() .httpClient(mockClient) .endpointOverride(URI.create("http://example.com")) .region(Region.of("us-west-42")) .credentialsProvider(StaticCredentialsProvider.create( AwsSessionCredentials.create("key", "secret", "session") )) .overrideConfiguration(ClientOverrideConfiguration.builder() .addExecutionInterceptor(new TracingInterceptor()) .build() ) .build(); Segment segment = AWSXRay.getCurrentSegment(); try { client.invoke(InvokeRequest.builder() .functionName("testFunctionName") .build() ).get(); } catch (Exception e) { // ignore exceptions } finally { Assert.assertEquals(1, segment.getSubsegments().size()); Subsegment subsegment = segment.getSubsegments().get(0); Map<String, Object> awsStats = subsegment.getAws(); @SuppressWarnings("unchecked") Map<String, Object> httpResponseStats = (Map<String, Object>) subsegment.getHttp().get("response"); Cause cause = subsegment.getCause(); Assert.assertEquals("Invoke", awsStats.get("operation")); Assert.assertEquals("testFunctionName", awsStats.get("function_name")); Assert.assertEquals("1111-2222-3333-4444", awsStats.get("request_id")); Assert.assertEquals("extended", awsStats.get("id_2")); Assert.assertEquals("us-west-42", awsStats.get("region")); // 500 exceptions are retried Assert.assertEquals(3, awsStats.get("retries")); Assert.assertEquals(2L, httpResponseStats.get("content_length")); Assert.assertEquals(500, httpResponseStats.get("status")); Assert.assertEquals(false, subsegment.isError()); Assert.assertEquals(false, subsegment.isThrottle()); Assert.assertEquals(true, subsegment.isFault()); Assert.assertEquals(1, cause.getExceptions().size()); Assert.assertEquals(true, cause.getExceptions().get(0).isRemote()); } }