-
Notifications
You must be signed in to change notification settings - Fork 332
Expand file tree
/
Copy pathRmiTest.groovy
More file actions
270 lines (232 loc) · 6.43 KB
/
RmiTest.groovy
File metadata and controls
270 lines (232 loc) · 6.43 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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
import datadog.trace.agent.test.naming.VersionedNamingTestBase
import datadog.trace.agent.test.utils.PortUtils
import datadog.trace.api.DDSpanTypes
import datadog.trace.bootstrap.instrumentation.api.Tags
import datadog.trace.test.util.Flaky
import rmi.app.Greeter
import rmi.app.Server
import rmi.app.ServerLegacy
import java.rmi.registry.LocateRegistry
import java.rmi.server.UnicastRemoteObject
import static datadog.trace.agent.test.asserts.ListWriterAssert.assertTraces
import static datadog.trace.agent.test.utils.TraceUtils.basicSpan
import static datadog.trace.agent.test.utils.TraceUtils.runUnderTrace
import spock.lang.Ignore
abstract class RmiTest extends VersionedNamingTestBase {
def registryPort = PortUtils.randomOpenPort()
def serverRegistry = LocateRegistry.createRegistry(registryPort)
def clientRegistry = LocateRegistry.getRegistry("localhost", registryPort)
@Override
final String service() {
return null
}
@Override
final String operation() {
return null
}
protected abstract String clientOperation()
protected abstract String serverOperation()
def cleanup() {
UnicastRemoteObject.unexportObject(serverRegistry, true)
}
def "Client call creates spans"() {
setup:
def server = new Server()
serverRegistry.rebind(Server.RMI_ID, server)
when:
def response = runUnderTrace("parent") {
def client = (Greeter) clientRegistry.lookup(Server.RMI_ID)
return client.hello("you")
}
then:
response.contains("Hello you")
assertTraces(2) {
trace(2) {
basicSpan(it, "parent")
span {
resourceName "Greeter.hello"
operationName clientOperation()
childOf span(0)
spanType DDSpanTypes.RPC
measured true
tags {
"$Tags.SPAN_KIND" Tags.SPAN_KIND_CLIENT
"$Tags.RPC_SERVICE" "rmi.app.Greeter"
"$Tags.COMPONENT" "rmi-client"
peerServiceFrom(Tags.RPC_SERVICE)
defaultTags()
}
}
}
trace(2) {
span {
resourceName "Server.hello"
operationName serverOperation()
spanType DDSpanTypes.RPC
measured true
tags {
"$Tags.SPAN_KIND" Tags.SPAN_KIND_SERVER
"$Tags.COMPONENT" "rmi-server"
defaultTags(true)
}
}
span {
resourceName "Server.someMethod"
operationName serverOperation()
spanType DDSpanTypes.RPC
measured true
tags {
"$Tags.SPAN_KIND" Tags.SPAN_KIND_SERVER
"$Tags.COMPONENT" "rmi-server"
defaultTags()
}
}
}
}
cleanup:
serverRegistry.unbind("Server")
}
def "Calling server builtin methods doesn't create server spans"() {
setup:
def server = new Server()
serverRegistry.rebind(Server.RMI_ID, server)
when:
server.equals(new Server())
server.getRef()
server.hashCode()
server.toString()
server.getClass()
then:
assertTraces(TEST_WRITER, 0) {}
cleanup:
serverRegistry.unbind("Server")
}
def "Service throws exception and its propagated to spans"() {
setup:
def server = new Server()
serverRegistry.rebind(Server.RMI_ID, server)
when:
runUnderTrace("parent") {
def client = (Greeter) clientRegistry.lookup(Server.RMI_ID)
client.exceptional()
}
then:
def thrownException = thrown(RuntimeException)
assertTraces(2) {
trace(2) {
basicSpan(it, "parent", null, thrownException)
span {
resourceName "Greeter.exceptional"
operationName clientOperation()
childOf span(0)
errored true
spanType DDSpanTypes.RPC
measured true
tags {
"$Tags.SPAN_KIND" Tags.SPAN_KIND_CLIENT
"$Tags.RPC_SERVICE" "rmi.app.Greeter"
"$Tags.COMPONENT" "rmi-client"
errorTags(RuntimeException, String)
peerServiceFrom(Tags.RPC_SERVICE)
defaultTags()
}
}
}
trace(1) {
span {
resourceName "Server.exceptional"
operationName serverOperation()
errored true
spanType DDSpanTypes.RPC
measured true
tags {
"$Tags.SPAN_KIND" Tags.SPAN_KIND_SERVER
"$Tags.COMPONENT" "rmi-server"
errorTags(RuntimeException, String)
defaultTags(true)
}
}
}
}
cleanup:
serverRegistry.unbind("Server")
}
@Flaky("Fails sometimes with NegativeArraySizeException in TimelinePrinter https://github.com/DataDog/dd-trace-java/issues/3869")
def "Client call using ServerLegacy_stub creates spans"() {
setup:
def server = new ServerLegacy()
serverRegistry.rebind(ServerLegacy.RMI_ID, server)
when:
def response = runUnderTrace("parent") {
def client = (Greeter) clientRegistry.lookup(ServerLegacy.RMI_ID)
return client.hello("you")
}
then:
response.contains("Hello you")
assertTraces(2) {
trace(2) {
basicSpan(it, "parent")
span {
resourceName "Greeter.hello"
operationName clientOperation()
spanType DDSpanTypes.RPC
childOf span(0)
measured true
tags {
"$Tags.SPAN_KIND" Tags.SPAN_KIND_CLIENT
"$Tags.COMPONENT" "rmi-client"
"$Tags.RPC_SERVICE" "rmi.app.Greeter"
peerServiceFrom(Tags.RPC_SERVICE)
defaultTags()
}
}
}
trace(1) {
span {
childOf trace(0)[1]
resourceName "ServerLegacy.hello"
operationName serverOperation()
spanType DDSpanTypes.RPC
measured true
tags {
"$Tags.COMPONENT" "rmi-server"
"$Tags.SPAN_KIND" Tags.SPAN_KIND_SERVER
defaultTags(true)
}
}
}
}
cleanup:
serverRegistry.unbind(ServerLegacy.RMI_ID)
}
}
@Ignore
class RmiV0Test extends RmiTest {
@Override
int version() {
return 0
}
@Override
String serverOperation() {
return "rmi.request"
}
@Override
String clientOperation() {
return "rmi.invoke"
}
}
@Ignore
class RmiV1ForkedTest extends RmiTest {
@Override
int version() {
return 1
}
@Override
String serverOperation() {
return "rmi.server.request"
}
@Override
String clientOperation() {
return "rmi.client.request"
}
}