-
Notifications
You must be signed in to change notification settings - Fork 20
Expand file tree
/
Copy pathHandler.java
More file actions
66 lines (57 loc) · 2.46 KB
/
Handler.java
File metadata and controls
66 lines (57 loc) · 2.46 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package example;
import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.RequestHandler;
import com.fasterxml.jackson.databind.ObjectMapper;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.TimeUnit;
/**
* Lambda handler designed to test SnapStart timestamp adjustment.
*
* This handler uses OkHttp to make HTTP requests during invocation.
* OkHttp is auto-instrumented by dd-trace-java, creating spans.
* We verify that spans created during invocation have correct timestamps.
*/
public class Handler implements RequestHandler<Map<String, Object>, Map<String, Object>> {
private static final ObjectMapper objectMapper = new ObjectMapper();
// Initialize OkHttp client during class loading
private static final OkHttpClient httpClient = new OkHttpClient.Builder()
.connectTimeout(10, TimeUnit.SECONDS)
.readTimeout(10, TimeUnit.SECONDS)
.build();
@Override
public Map<String, Object> handleRequest(Map<String, Object> event, Context context) {
context.getLogger().log("SnapStart timing test handler invoked");
// Make HTTP request during invocation - this creates an OkHttp span
boolean invokeRequestSuccess = false;
int invokeStatusCode = 0;
try {
Request request = new Request.Builder()
.url("https://httpbin.org/get")
.build();
try (Response response = httpClient.newCall(request).execute()) {
invokeStatusCode = response.code();
invokeRequestSuccess = (invokeStatusCode == 200);
context.getLogger().log("HTTP request completed with status: " + invokeStatusCode);
}
} catch (Exception e) {
context.getLogger().log("HTTP request failed: " + e.getMessage());
}
Map<String, Object> body = new HashMap<>();
body.put("message", "Success");
body.put("requestId", context.getAwsRequestId());
body.put("invokeRequestSuccess", invokeRequestSuccess);
body.put("invokeStatusCode", invokeStatusCode);
Map<String, Object> response = new HashMap<>();
response.put("statusCode", 200);
try {
response.put("body", objectMapper.writeValueAsString(body));
} catch (Exception e) {
response.put("body", "{}");
}
return response;
}
}