Skip to content

Commit e088706

Browse files
committed
Deploying to docs from @ 9f6354f 🚀
1 parent 641ba93 commit e088706

17 files changed

Lines changed: 159 additions & 18 deletions

File tree

coverage/aws-durable-execution-sdk-java-examples/index.html

Lines changed: 1 addition & 1 deletion
Large diffs are not rendered by default.
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html xmlns="http://www.w3.org/1999/xhtml" lang="en"><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"/><link rel="stylesheet" href="../../jacoco-resources/report.css" type="text/css"/><link rel="shortcut icon" href="../../jacoco-resources/report.gif" type="image/gif"/><title>OtelXRayStepExample</title><script type="text/javascript" src="../../jacoco-resources/sort.js"></script></head><body onload="initialSort(['breadcrumb'])"><div class="breadcrumb" id="breadcrumb"><span class="info"><a href="../../jacoco-sessions.html" class="el_session">Sessions</a></span><a href="../../index.html" class="el_report">AWS Lambda Durable Execution SDK Coverage Report</a> &gt; <a href="../index.html" class="el_bundle">aws-durable-execution-sdk-java-examples</a> &gt; <a href="index.html" class="el_package">software.amazon.lambda.durable.examples.otel</a> &gt; <span class="el_class">OtelXRayStepExample</span></div><h1>OtelXRayStepExample</h1><table class="coverage" cellspacing="0" id="coveragetable"><thead><tr><td class="sortable" id="a" onclick="toggleSort(this)">Element</td><td class="down sortable bar" id="b" onclick="toggleSort(this)">Missed Instructions</td><td class="sortable ctr2" id="c" onclick="toggleSort(this)">Cov.</td><td class="sortable bar" id="d" onclick="toggleSort(this)">Missed Branches</td><td class="sortable ctr2" id="e" onclick="toggleSort(this)">Cov.</td><td class="sortable ctr1" id="f" onclick="toggleSort(this)">Missed</td><td class="sortable ctr2" id="g" onclick="toggleSort(this)">Cxty</td><td class="sortable ctr1" id="h" onclick="toggleSort(this)">Missed</td><td class="sortable ctr2" id="i" onclick="toggleSort(this)">Lines</td><td class="sortable ctr1" id="j" onclick="toggleSort(this)">Missed</td><td class="sortable ctr2" id="k" onclick="toggleSort(this)">Methods</td></tr></thead><tfoot><tr><td>Total</td><td class="bar">0 of 70</td><td class="ctr2">100%</td><td class="bar">0 of 0</td><td class="ctr2">n/a</td><td class="ctr1">0</td><td class="ctr2">5</td><td class="ctr1">0</td><td class="ctr2">10</td><td class="ctr1">0</td><td class="ctr2">5</td></tr></tfoot><tbody><tr><td id="a1"><a href="OtelXRayStepExample.java.html#L50" class="el_method">handleRequest(GreetingRequest, DurableContext)</a></td><td class="bar" id="b0"><img src="../../jacoco-resources/greenbar.gif" width="120" height="10" title="39" alt="39"/></td><td class="ctr2" id="c0">100%</td><td class="bar" id="d0"/><td class="ctr2" id="e0">n/a</td><td class="ctr1" id="f0">0</td><td class="ctr2" id="g0">1</td><td class="ctr1" id="h0">0</td><td class="ctr2" id="i0">5</td><td class="ctr1" id="j0">0</td><td class="ctr2" id="k0">1</td></tr><tr><td id="a0"><a href="OtelXRayStepExample.java.html#L40" class="el_method">createConfiguration()</a></td><td class="bar" id="b1"><img src="../../jacoco-resources/greenbar.gif" width="61" height="10" title="20" alt="20"/></td><td class="ctr2" id="c1">100%</td><td class="bar" id="d1"/><td class="ctr2" id="e1">n/a</td><td class="ctr1" id="f1">0</td><td class="ctr2" id="g1">1</td><td class="ctr1" id="h1">0</td><td class="ctr2" id="i1">4</td><td class="ctr1" id="j1">0</td><td class="ctr2" id="k1">1</td></tr><tr><td id="a3"><a href="OtelXRayStepExample.java.html#L54" class="el_method">lambda$handleRequest$1(String, StepContext)</a></td><td class="bar" id="b2"><img src="../../jacoco-resources/greenbar.gif" width="12" height="10" title="4" alt="4"/></td><td class="ctr2" id="c2">100%</td><td class="bar" id="d2"/><td class="ctr2" id="e2">n/a</td><td class="ctr1" id="f2">0</td><td class="ctr2" id="g2">1</td><td class="ctr1" id="h2">0</td><td class="ctr2" id="i2">1</td><td class="ctr1" id="j2">0</td><td class="ctr2" id="k2">1</td></tr><tr><td id="a2"><a href="OtelXRayStepExample.java.html#L52" class="el_method">lambda$handleRequest$0(GreetingRequest, StepContext)</a></td><td class="bar" id="b3"><img src="../../jacoco-resources/greenbar.gif" width="12" height="10" title="4" alt="4"/></td><td class="ctr2" id="c3">100%</td><td class="bar" id="d3"/><td class="ctr2" id="e3">n/a</td><td class="ctr1" id="f3">0</td><td class="ctr2" id="g3">1</td><td class="ctr1" id="h3">0</td><td class="ctr2" id="i3">1</td><td class="ctr1" id="j3">0</td><td class="ctr2" id="k3">1</td></tr><tr><td id="a4"><a href="OtelXRayStepExample.java.html#L35" class="el_method">OtelXRayStepExample()</a></td><td class="bar" id="b4"><img src="../../jacoco-resources/greenbar.gif" width="9" height="10" title="3" alt="3"/></td><td class="ctr2" id="c4">100%</td><td class="bar" id="d4"/><td class="ctr2" id="e4">n/a</td><td class="ctr1" id="f4">0</td><td class="ctr2" id="g4">1</td><td class="ctr1" id="h4">0</td><td class="ctr2" id="i4">1</td><td class="ctr1" id="j4">0</td><td class="ctr2" id="k4">1</td></tr></tbody></table><div class="footer"><span class="right">Created with <a href="http://www.jacoco.org/jacoco">JaCoCo</a> 0.8.15.202606040825</span></div></body></html>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,60 @@
1+
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html xmlns="http://www.w3.org/1999/xhtml" lang="en"><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"/><link rel="stylesheet" href="../../jacoco-resources/report.css" type="text/css"/><link rel="shortcut icon" href="../../jacoco-resources/report.gif" type="image/gif"/><title>OtelXRayStepExample.java</title><link rel="stylesheet" href="../../jacoco-resources/prettify.css" type="text/css"/><script type="text/javascript" src="../../jacoco-resources/prettify.js"></script></head><body onload="window['PR_TAB_WIDTH']=4;prettyPrint()"><div class="breadcrumb" id="breadcrumb"><span class="info"><a href="../../jacoco-sessions.html" class="el_session">Sessions</a></span><a href="../../index.html" class="el_report">AWS Lambda Durable Execution SDK Coverage Report</a> &gt; <a href="../index.html" class="el_bundle">aws-durable-execution-sdk-java-examples</a> &gt; <a href="index.source.html" class="el_package">software.amazon.lambda.durable.examples.otel</a> &gt; <span class="el_source">OtelXRayStepExample.java</span></div><h1>OtelXRayStepExample.java</h1><pre class="source lang-java linenums">// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
2+
// SPDX-License-Identifier: Apache-2.0
3+
package software.amazon.lambda.durable.examples.otel;
4+
5+
import io.opentelemetry.exporter.otlp.trace.OtlpGrpcSpanExporter;
6+
import io.opentelemetry.sdk.trace.SdkTracerProvider;
7+
import io.opentelemetry.sdk.trace.export.SimpleSpanProcessor;
8+
import software.amazon.lambda.durable.DurableConfig;
9+
import software.amazon.lambda.durable.DurableContext;
10+
import software.amazon.lambda.durable.DurableHandler;
11+
import software.amazon.lambda.durable.examples.types.GreetingRequest;
12+
import software.amazon.lambda.durable.otel.OpenTelemetryDurablePlugin;
13+
14+
/**
15+
* OTel + X-Ray example: simple steps in a single invocation.
16+
*
17+
* &lt;p&gt;Exports spans via OTLP to the ADOT Lambda Layer collector, which forwards them to X-Ray. Requires:
18+
*
19+
* &lt;ul&gt;
20+
* &lt;li&gt;{@code Tracing: Active} on the Lambda function
21+
* &lt;li&gt;ADOT Lambda Layer added to the function
22+
* &lt;li&gt;{@code AWS_LAMBDA_EXEC_WRAPPER=/opt/otel-handler} environment variable
23+
* &lt;/ul&gt;
24+
*
25+
* &lt;p&gt;Expected trace structure in X-Ray:
26+
*
27+
* &lt;pre&gt;
28+
* durable.invocation
29+
* ├── durable.step:create-greeting
30+
* │ └── durable.step:create-greeting [attempt 1]
31+
* └── durable.step:transform
32+
* └── durable.step:transform [attempt 1]
33+
* &lt;/pre&gt;
34+
*/
35+
<span class="fc" id="L35">public class OtelXRayStepExample extends DurableHandler&lt;GreetingRequest, String&gt; {</span>
36+
37+
@Override
38+
protected DurableConfig createConfiguration() {
39+
// OTLP exporter sends spans to the ADOT collector (localhost:4317 by default)
40+
<span class="fc" id="L40"> var otlpExporter = OtlpGrpcSpanExporter.getDefault();</span>
41+
42+
<span class="fc" id="L42"> var otelPlugin = new OpenTelemetryDurablePlugin(</span>
43+
<span class="fc" id="L43"> SdkTracerProvider.builder().addSpanProcessor(SimpleSpanProcessor.create(otlpExporter)));</span>
44+
45+
<span class="fc" id="L45"> return DurableConfig.builder().withPlugins(otelPlugin).build();</span>
46+
}
47+
48+
@Override
49+
public String handleRequest(GreetingRequest input, DurableContext context) {
50+
<span class="fc" id="L50"> context.getLogger().info(&quot;Starting OTel X-Ray step example for {}&quot;, input.getName());</span>
51+
52+
<span class="fc" id="L52"> var greeting = context.step(&quot;create-greeting&quot;, String.class, stepCtx -&gt; &quot;Hello, &quot; + input.getName());</span>
53+
54+
<span class="fc" id="L54"> var result = context.step(&quot;transform&quot;, String.class, stepCtx -&gt; greeting.toUpperCase() + &quot;!&quot;);</span>
55+
56+
<span class="fc" id="L56"> context.getLogger().info(&quot;OTel X-Ray step example complete: {}&quot;, result);</span>
57+
<span class="fc" id="L57"> return result;</span>
58+
}
59+
}
60+
</pre><div class="footer"><span class="right">Created with <a href="http://www.jacoco.org/jacoco">JaCoCo</a> 0.8.15.202606040825</span></div></body></html>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html xmlns="http://www.w3.org/1999/xhtml" lang="en"><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"/><link rel="stylesheet" href="../../jacoco-resources/report.css" type="text/css"/><link rel="shortcut icon" href="../../jacoco-resources/report.gif" type="image/gif"/><title>OtelXRayWaitExample</title><script type="text/javascript" src="../../jacoco-resources/sort.js"></script></head><body onload="initialSort(['breadcrumb'])"><div class="breadcrumb" id="breadcrumb"><span class="info"><a href="../../jacoco-sessions.html" class="el_session">Sessions</a></span><a href="../../index.html" class="el_report">AWS Lambda Durable Execution SDK Coverage Report</a> &gt; <a href="../index.html" class="el_bundle">aws-durable-execution-sdk-java-examples</a> &gt; <a href="index.html" class="el_package">software.amazon.lambda.durable.examples.otel</a> &gt; <span class="el_class">OtelXRayWaitExample</span></div><h1>OtelXRayWaitExample</h1><table class="coverage" cellspacing="0" id="coveragetable"><thead><tr><td class="sortable" id="a" onclick="toggleSort(this)">Element</td><td class="down sortable bar" id="b" onclick="toggleSort(this)">Missed Instructions</td><td class="sortable ctr2" id="c" onclick="toggleSort(this)">Cov.</td><td class="sortable bar" id="d" onclick="toggleSort(this)">Missed Branches</td><td class="sortable ctr2" id="e" onclick="toggleSort(this)">Cov.</td><td class="sortable ctr1" id="f" onclick="toggleSort(this)">Missed</td><td class="sortable ctr2" id="g" onclick="toggleSort(this)">Cxty</td><td class="sortable ctr1" id="h" onclick="toggleSort(this)">Missed</td><td class="sortable ctr2" id="i" onclick="toggleSort(this)">Lines</td><td class="sortable ctr1" id="j" onclick="toggleSort(this)">Missed</td><td class="sortable ctr2" id="k" onclick="toggleSort(this)">Methods</td></tr></thead><tfoot><tr><td>Total</td><td class="bar">0 of 75</td><td class="ctr2">100%</td><td class="bar">0 of 0</td><td class="ctr2">n/a</td><td class="ctr1">0</td><td class="ctr2">5</td><td class="ctr1">0</td><td class="ctr2">11</td><td class="ctr1">0</td><td class="ctr2">5</td></tr></tfoot><tbody><tr><td id="a1"><a href="OtelXRayWaitExample.java.html#L62" class="el_method">handleRequest(GreetingRequest, DurableContext)</a></td><td class="bar" id="b0"><img src="../../jacoco-resources/greenbar.gif" width="120" height="10" title="45" alt="45"/></td><td class="ctr2" id="c0">100%</td><td class="bar" id="d0"/><td class="ctr2" id="e0">n/a</td><td class="ctr1" id="f0">0</td><td class="ctr2" id="g0">1</td><td class="ctr1" id="h0">0</td><td class="ctr2" id="i0">6</td><td class="ctr1" id="j0">0</td><td class="ctr2" id="k0">1</td></tr><tr><td id="a0"><a href="OtelXRayWaitExample.java.html#L52" class="el_method">createConfiguration()</a></td><td class="bar" id="b1"><img src="../../jacoco-resources/greenbar.gif" width="53" height="10" title="20" alt="20"/></td><td class="ctr2" id="c1">100%</td><td class="bar" id="d1"/><td class="ctr2" id="e1">n/a</td><td class="ctr1" id="f1">0</td><td class="ctr2" id="g1">1</td><td class="ctr1" id="h1">0</td><td class="ctr2" id="i1">4</td><td class="ctr1" id="j1">0</td><td class="ctr2" id="k1">1</td></tr><tr><td id="a2"><a href="OtelXRayWaitExample.java.html#L64" class="el_method">lambda$handleRequest$0(GreetingRequest, StepContext)</a></td><td class="bar" id="b2"><img src="../../jacoco-resources/greenbar.gif" width="10" height="10" title="4" alt="4"/></td><td class="ctr2" id="c2">100%</td><td class="bar" id="d2"/><td class="ctr2" id="e2">n/a</td><td class="ctr1" id="f2">0</td><td class="ctr2" id="g2">1</td><td class="ctr1" id="h2">0</td><td class="ctr2" id="i2">1</td><td class="ctr1" id="j2">0</td><td class="ctr2" id="k2">1</td></tr><tr><td id="a4"><a href="OtelXRayWaitExample.java.html#L47" class="el_method">OtelXRayWaitExample()</a></td><td class="bar" id="b3"><img src="../../jacoco-resources/greenbar.gif" width="8" height="10" title="3" alt="3"/></td><td class="ctr2" id="c3">100%</td><td class="bar" id="d3"/><td class="ctr2" id="e3">n/a</td><td class="ctr1" id="f3">0</td><td class="ctr2" id="g3">1</td><td class="ctr1" id="h3">0</td><td class="ctr2" id="i3">1</td><td class="ctr1" id="j3">0</td><td class="ctr2" id="k3">1</td></tr><tr><td id="a3"><a href="OtelXRayWaitExample.java.html#L69" class="el_method">lambda$handleRequest$1(String, StepContext)</a></td><td class="bar" id="b4"><img src="../../jacoco-resources/greenbar.gif" width="8" height="10" title="3" alt="3"/></td><td class="ctr2" id="c4">100%</td><td class="bar" id="d4"/><td class="ctr2" id="e4">n/a</td><td class="ctr1" id="f4">0</td><td class="ctr2" id="g4">1</td><td class="ctr1" id="h4">0</td><td class="ctr2" id="i4">1</td><td class="ctr1" id="j4">0</td><td class="ctr2" id="k4">1</td></tr></tbody></table><div class="footer"><span class="right">Created with <a href="http://www.jacoco.org/jacoco">JaCoCo</a> 0.8.15.202606040825</span></div></body></html>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,75 @@
1+
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html xmlns="http://www.w3.org/1999/xhtml" lang="en"><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"/><link rel="stylesheet" href="../../jacoco-resources/report.css" type="text/css"/><link rel="shortcut icon" href="../../jacoco-resources/report.gif" type="image/gif"/><title>OtelXRayWaitExample.java</title><link rel="stylesheet" href="../../jacoco-resources/prettify.css" type="text/css"/><script type="text/javascript" src="../../jacoco-resources/prettify.js"></script></head><body onload="window['PR_TAB_WIDTH']=4;prettyPrint()"><div class="breadcrumb" id="breadcrumb"><span class="info"><a href="../../jacoco-sessions.html" class="el_session">Sessions</a></span><a href="../../index.html" class="el_report">AWS Lambda Durable Execution SDK Coverage Report</a> &gt; <a href="../index.html" class="el_bundle">aws-durable-execution-sdk-java-examples</a> &gt; <a href="index.source.html" class="el_package">software.amazon.lambda.durable.examples.otel</a> &gt; <span class="el_source">OtelXRayWaitExample.java</span></div><h1>OtelXRayWaitExample.java</h1><pre class="source lang-java linenums">// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
2+
// SPDX-License-Identifier: Apache-2.0
3+
package software.amazon.lambda.durable.examples.otel;
4+
5+
import io.opentelemetry.exporter.otlp.trace.OtlpGrpcSpanExporter;
6+
import io.opentelemetry.sdk.trace.SdkTracerProvider;
7+
import io.opentelemetry.sdk.trace.export.SimpleSpanProcessor;
8+
import java.time.Duration;
9+
import software.amazon.lambda.durable.DurableConfig;
10+
import software.amazon.lambda.durable.DurableContext;
11+
import software.amazon.lambda.durable.DurableHandler;
12+
import software.amazon.lambda.durable.examples.types.GreetingRequest;
13+
import software.amazon.lambda.durable.otel.OpenTelemetryDurablePlugin;
14+
15+
/**
16+
* OTel + X-Ray example: step → wait → step pattern that forces multiple Lambda invocations.
17+
*
18+
* &lt;p&gt;This handler exercises the critical multi-invocation tracing scenario:
19+
*
20+
* &lt;ol&gt;
21+
* &lt;li&gt;Invocation 1: &quot;before-wait&quot; step completes → wait suspends execution
22+
* &lt;li&gt;Invocation 2: replays &quot;before-wait&quot; (no-op) → wait completes → &quot;after-wait&quot; step runs
23+
* &lt;/ol&gt;
24+
*
25+
* &lt;p&gt;Exports spans via OTLP to the ADOT Lambda Layer collector. Requires:
26+
*
27+
* &lt;ul&gt;
28+
* &lt;li&gt;{@code Tracing: Active} on the Lambda function
29+
* &lt;li&gt;ADOT Lambda Layer added to the function
30+
* &lt;li&gt;{@code AWS_LAMBDA_EXEC_WRAPPER=/opt/otel-handler} environment variable
31+
* &lt;/ul&gt;
32+
*
33+
* &lt;p&gt;Expected trace structure in X-Ray (all under one trace ID — backend propagates same Root):
34+
*
35+
* &lt;pre&gt;
36+
* Trace (single trace ID across both invocations)
37+
* ├── durable.invocation (invocation 1)
38+
* │ ├── durable.step:before-wait
39+
* │ │ └── durable.step:before-wait [attempt 1]
40+
* │ └── durable.wait:pause (ended as PENDING)
41+
* └── durable.invocation (invocation 2)
42+
* ├── durable.wait:pause (completed)
43+
* └── durable.step:after-wait
44+
* └── durable.step:after-wait [attempt 1]
45+
* &lt;/pre&gt;
46+
*/
47+
<span class="fc" id="L47">public class OtelXRayWaitExample extends DurableHandler&lt;GreetingRequest, String&gt; {</span>
48+
49+
@Override
50+
protected DurableConfig createConfiguration() {
51+
// OTLP exporter sends spans to the ADOT collector (localhost:4317 by default)
52+
<span class="fc" id="L52"> var otlpExporter = OtlpGrpcSpanExporter.getDefault();</span>
53+
54+
<span class="fc" id="L54"> var otelPlugin = new OpenTelemetryDurablePlugin(</span>
55+
<span class="fc" id="L55"> SdkTracerProvider.builder().addSpanProcessor(SimpleSpanProcessor.create(otlpExporter)));</span>
56+
57+
<span class="fc" id="L57"> return DurableConfig.builder().withPlugins(otelPlugin).build();</span>
58+
}
59+
60+
@Override
61+
public String handleRequest(GreetingRequest input, DurableContext context) {
62+
<span class="fc" id="L62"> context.getLogger().info(&quot;Starting OTel X-Ray wait example for {}&quot;, input.getName());</span>
63+
64+
<span class="fc" id="L64"> var before = context.step(&quot;before-wait&quot;, String.class, stepCtx -&gt; &quot;Prepared: &quot; + input.getName());</span>
65+
66+
// This wait forces Lambda to suspend and re-invoke after the duration
67+
<span class="fc" id="L67"> context.wait(&quot;pause&quot;, Duration.ofSeconds(5));</span>
68+
69+
<span class="fc" id="L69"> var after = context.step(&quot;after-wait&quot;, String.class, stepCtx -&gt; before + &quot; | Resumed and completed&quot;);</span>
70+
71+
<span class="fc" id="L71"> context.getLogger().info(&quot;OTel X-Ray wait example complete: {}&quot;, after);</span>
72+
<span class="fc" id="L72"> return after;</span>
73+
}
74+
}
75+
</pre><div class="footer"><span class="right">Created with <a href="http://www.jacoco.org/jacoco">JaCoCo</a> 0.8.15.202606040825</span></div></body></html>

0 commit comments

Comments
 (0)