Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
月轩居士
SkyWalking
提交
b820a396
S
SkyWalking
项目概览
月轩居士
/
SkyWalking
与 Fork 源项目一致
Fork自
apache / SkyWalking
通知
4
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
SkyWalking
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
b820a396
编写于
8月 18, 2017
作者:
A
ascrutae
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
support trace annotation
上级
998c04e0
变更
16
隐藏空白更改
内联
并排
Showing
16 changed file
with
420 addition
and
5 deletion
+420
-5
apm-application-toolkit/apm-toolkit-trace/pom.xml
apm-application-toolkit/apm-toolkit-trace/pom.xml
+45
-0
apm-application-toolkit/apm-toolkit-trace/src/main/java/org/skywalking/apm/toolkit/trace/ActiveSpan.java
...ain/java/org/skywalking/apm/toolkit/trace/ActiveSpan.java
+16
-0
apm-application-toolkit/apm-toolkit-trace/src/main/java/org/skywalking/apm/toolkit/trace/Trace.java
...src/main/java/org/skywalking/apm/toolkit/trace/Trace.java
+22
-0
apm-application-toolkit/pom.xml
apm-application-toolkit/pom.xml
+1
-0
apm-sniffer/apm-agent-core/src/main/java/org/skywalking/apm/agent/core/plugin/match/MethodAnnotationMatch.java
...ng/apm/agent/core/plugin/match/MethodAnnotationMatch.java
+2
-1
apm-sniffer/apm-agent/pom.xml
apm-sniffer/apm-agent/pom.xml
+6
-0
apm-sniffer/apm-test-tools/src/main/java/org/skywalking/apm/agent/test/helper/SpanHelper.java
...java/org/skywalking/apm/agent/test/helper/SpanHelper.java
+16
-4
apm-sniffer/apm-test-tools/src/main/java/org/skywalking/apm/agent/test/tools/SpanAssert.java
.../java/org/skywalking/apm/agent/test/tools/SpanAssert.java
+4
-0
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/pom.xml
...m-toolkit-activation/apm-toolkit-trace-activation/pom.xml
+22
-0
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/src/main/java/org/skywalking/apm/toolkit/activation/trace/ActiveSpanTagActivation.java
...apm/toolkit/activation/trace/ActiveSpanTagActivation.java
+50
-0
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/src/main/java/org/skywalking/apm/toolkit/activation/trace/ActiveSpanTagInterceptor.java
...pm/toolkit/activation/trace/ActiveSpanTagInterceptor.java
+26
-0
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/src/main/java/org/skywalking/apm/toolkit/activation/trace/TraceAnnotationActivation.java
...m/toolkit/activation/trace/TraceAnnotationActivation.java
+50
-0
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/src/main/java/org/skywalking/apm/toolkit/activation/trace/TraceAnnotationMethodInterceptor.java
...it/activation/trace/TraceAnnotationMethodInterceptor.java
+54
-0
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/src/main/resources/skywalking-plugin.def
...trace-activation/src/main/resources/skywalking-plugin.def
+2
-0
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/src/test/java/org/skywalking/apm/toolkit/activation/trace/TraceAnnotationTest.java
...ing/apm/toolkit/activation/trace/TraceAnnotationTest.java
+103
-0
apm-sniffer/apm-toolkit-activation/pom.xml
apm-sniffer/apm-toolkit-activation/pom.xml
+1
-0
未找到文件。
apm-application-toolkit/apm-toolkit-trace/pom.xml
0 → 100644
浏览文件 @
b820a396
<project
xmlns=
"http://maven.apache.org/POM/4.0.0"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<parent>
<artifactId>
apm-application-toolkit
</artifactId>
<groupId>
org.skywalking
</groupId>
<version>
3.2-2017
</version>
</parent>
<modelVersion>
4.0.0
</modelVersion>
<artifactId>
apm-toolkit-trace
</artifactId>
<packaging>
jar
</packaging>
<url>
http://maven.apache.org
</url>
<build>
<plugins>
<plugin>
<!-- 源码插件 -->
<groupId>
org.apache.maven.plugins
</groupId>
<artifactId>
maven-source-plugin
</artifactId>
<!-- 发布时自动将源码同时发布的配置 -->
<executions>
<execution>
<id>
attach-sources
</id>
<goals>
<goal>
jar
</goal>
</goals>
</execution>
</executions>
<version>
2.4
</version>
</plugin>
</plugins>
</build>
<distributionManagement>
<repository>
<id>
bintray-wu-sheng-sky-walking-repository
</id>
<name>
wu-sheng-sky-walking-repository
</name>
<url>
https://api.bintray.com/maven/wu-sheng/skywalking/org.skywalking.apm-toolkit-trace/;publish=1
</url>
</repository>
</distributionManagement>
</project>
apm-application-toolkit/apm-toolkit-trace/src/main/java/org/skywalking/apm/toolkit/trace/ActiveSpan.java
0 → 100644
浏览文件 @
b820a396
package
org.skywalking.apm.toolkit.trace
;
/**
* provide custom api that set tag for current active span.
*
* @author zhangxin
*/
public
class
ActiveSpan
{
/**
* @param key tag key
* @param value tag value
*/
public
static
void
tag
(
String
key
,
String
value
)
{
}
}
apm-application-toolkit/apm-toolkit-trace/src/main/java/org/skywalking/apm/toolkit/trace/Trace.java
0 → 100644
浏览文件 @
b820a396
package
org.skywalking.apm.toolkit.trace
;
import
java.lang.annotation.ElementType
;
import
java.lang.annotation.Retention
;
import
java.lang.annotation.RetentionPolicy
;
import
java.lang.annotation.Target
;
/**
* The agent create local span if the method that annotation with {@link Trace}. The value of span operation name will
* fetch by {@link #operationName()}. if the value of {@link #operationName()} is blank string. the operation name will
* be set the class name + method name.
*
* @author zhangxin
*/
@Target
(
ElementType
.
METHOD
)
@Retention
(
RetentionPolicy
.
RUNTIME
)
public
@interface
Trace
{
/**
* @return operation name, the default value is blank string.
*/
String
operationName
()
default
""
;
}
apm-application-toolkit/pom.xml
浏览文件 @
b820a396
...
...
@@ -19,5 +19,6 @@
<module>
apm-toolkit-logback-1.x
</module>
<module>
apm-toolkit-trace-context
</module>
<module>
apm-toolkit-opentracing
</module>
<module>
apm-toolkit-trace
</module>
</modules>
</project>
apm-sniffer/apm-agent-core/src/main/java/org/skywalking/apm/agent/core/plugin/match/MethodAnnotationMatch.java
浏览文件 @
b820a396
package
org.skywalking.apm.agent.core.plugin.match
;
import
java.util.ArrayList
;
import
java.util.Arrays
;
import
java.util.List
;
import
net.bytebuddy.description.annotation.AnnotationDescription
;
...
...
@@ -47,7 +48,7 @@ public class MethodAnnotationMatch implements IndirectMatch {
@Override
public
boolean
isMatch
(
TypeDescription
typeDescription
)
{
for
(
MethodDescription
.
InDefinedShape
methodDescription
:
typeDescription
.
getDeclaredMethods
())
{
List
<
String
>
annotationList
=
Arrays
.
asList
(
annotations
);
List
<
String
>
annotationList
=
new
ArrayList
<
String
>(
Arrays
.
asList
(
annotations
)
);
AnnotationList
declaredAnnotations
=
methodDescription
.
getDeclaredAnnotations
();
for
(
AnnotationDescription
annotation
:
declaredAnnotations
)
{
...
...
apm-sniffer/apm-agent/pom.xml
浏览文件 @
b820a396
...
...
@@ -126,6 +126,12 @@
<version>
${project.version}
</version>
</dependency>
<dependency>
<groupId>
org.skywalking
</groupId>
<artifactId>
apm-toolkit-trace-activation
</artifactId>
<version>
${project.version}
</version>
</dependency>
</dependencies>
<build>
<finalName>
skywalking-agent
</finalName>
...
...
apm-sniffer/apm-test-tools/src/main/java/org/skywalking/apm/agent/test/helper/SpanHelper.java
浏览文件 @
b820a396
...
...
@@ -24,10 +24,16 @@ public class SpanHelper {
public
static
List
<
LogDataEntity
>
getLogs
(
AbstractSpan
tracingSpan
)
{
try
{
return
FieldGetter
.
get2LevelParentFieldValue
(
tracingSpan
,
"logs"
);
List
<
LogDataEntity
>
logs
=
FieldGetter
.
get2LevelParentFieldValue
(
tracingSpan
,
"logs"
);
if
(
logs
!=
null
)
{
return
logs
;
}
}
catch
(
Exception
e
)
{
try
{
return
FieldGetter
.
getParentFieldValue
(
tracingSpan
,
"logs"
);
List
<
LogDataEntity
>
logs
=
FieldGetter
.
getParentFieldValue
(
tracingSpan
,
"logs"
);
if
(
logs
!=
null
)
{
return
logs
;
}
}
catch
(
Exception
e1
)
{
}
...
...
@@ -38,10 +44,16 @@ public class SpanHelper {
public
static
List
<
KeyValuePair
>
getTags
(
AbstractSpan
tracingSpan
)
{
try
{
return
FieldGetter
.
get2LevelParentFieldValue
(
tracingSpan
,
"tags"
);
List
<
KeyValuePair
>
tags
=
FieldGetter
.
get2LevelParentFieldValue
(
tracingSpan
,
"tags"
);
if
(
tags
!=
null
)
{
return
tags
;
}
}
catch
(
Exception
e
)
{
try
{
return
FieldGetter
.
getParentFieldValue
(
tracingSpan
,
"tags"
);
List
<
KeyValuePair
>
tags
=
FieldGetter
.
getParentFieldValue
(
tracingSpan
,
"tags"
);
if
(
tags
!=
null
)
{
return
tags
;
}
}
catch
(
Exception
e1
)
{
}
...
...
apm-sniffer/apm-test-tools/src/main/java/org/skywalking/apm/agent/test/tools/SpanAssert.java
浏览文件 @
b820a396
...
...
@@ -17,6 +17,10 @@ public class SpanAssert {
assertThat
(
SpanHelper
.
getLogs
(
span
).
size
(),
is
(
exceptedSize
));
}
public
static
void
assertTagSize
(
AbstractSpan
span
,
int
exceptedSize
)
{
assertThat
(
SpanHelper
.
getTags
(
span
).
size
(),
is
(
exceptedSize
));
}
public
static
void
assertException
(
LogDataEntity
logDataEntity
,
Class
<?
extends
Throwable
>
throwableClass
,
String
message
)
{
Assert
.
assertThat
(
logDataEntity
.
getLogs
().
size
(),
is
(
4
));
...
...
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/pom.xml
0 → 100644
浏览文件 @
b820a396
<?xml version="1.0" encoding="UTF-8"?>
<project
xmlns=
"http://maven.apache.org/POM/4.0.0"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<parent>
<artifactId>
apm-toolkit-activation
</artifactId>
<groupId>
org.skywalking
</groupId>
<version>
3.2-2017
</version>
</parent>
<modelVersion>
4.0.0
</modelVersion>
<artifactId>
apm-toolkit-trace-activation
</artifactId>
<dependencies>
<dependency>
<groupId>
org.skywalking
</groupId>
<artifactId>
apm-toolkit-trace
</artifactId>
<version>
${project.version}
</version>
<scope>
provided
</scope>
</dependency>
</dependencies>
</project>
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/src/main/java/org/skywalking/apm/toolkit/activation/trace/ActiveSpanTagActivation.java
0 → 100644
浏览文件 @
b820a396
package
org.skywalking.apm.toolkit.activation.trace
;
import
net.bytebuddy.description.method.MethodDescription
;
import
net.bytebuddy.matcher.ElementMatcher
;
import
org.skywalking.apm.agent.core.plugin.interceptor.ConstructorInterceptPoint
;
import
org.skywalking.apm.agent.core.plugin.interceptor.StaticMethodsInterceptPoint
;
import
org.skywalking.apm.agent.core.plugin.interceptor.enhance.ClassStaticMethodsEnhancePluginDefine
;
import
org.skywalking.apm.agent.core.plugin.match.ClassMatch
;
import
static
net
.
bytebuddy
.
matcher
.
ElementMatchers
.
named
;
import
static
org
.
skywalking
.
apm
.
agent
.
core
.
plugin
.
match
.
NameMatch
.
byName
;
/**
* {@link TraceAnnotationActivation} enhance the <code>tag</code> method of <code>org.skywalking.apm.toolkit.trace.ActiveSpan</code>
* by <code>org.skywalking.apm.toolkit.activation.trace.ActiveSpanTagInterceptor</code>.
*
* @author zhangxin
*/
public
class
ActiveSpanTagActivation
extends
ClassStaticMethodsEnhancePluginDefine
{
public
static
final
String
ENHANCE_CLASS
=
"org.skywalking.apm.toolkit.trace.ActiveSpan"
;
public
static
final
String
INTERCEPTOR_CLASS
=
"org.skywalking.apm.toolkit.activation.trace.ActiveSpanTagInterceptor"
;
public
static
final
String
INTERCEPTOR_METHOD_NAME
=
"tag"
;
@Override
protected
ConstructorInterceptPoint
[]
getConstructorsInterceptPoints
()
{
return
new
ConstructorInterceptPoint
[
0
];
}
@Override
protected
StaticMethodsInterceptPoint
[]
getStaticMethodsInterceptPoints
()
{
return
new
StaticMethodsInterceptPoint
[]
{
new
StaticMethodsInterceptPoint
()
{
@Override
public
ElementMatcher
<
MethodDescription
>
getMethodsMatcher
()
{
return
named
(
INTERCEPTOR_METHOD_NAME
);
}
@Override
public
String
getMethodsInterceptor
()
{
return
INTERCEPTOR_CLASS
;
}
@Override
public
boolean
isOverrideArgs
()
{
return
false
;
}
}
};
}
@Override
protected
ClassMatch
enhanceClass
()
{
return
byName
(
ENHANCE_CLASS
);
}
}
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/src/main/java/org/skywalking/apm/toolkit/activation/trace/ActiveSpanTagInterceptor.java
0 → 100644
浏览文件 @
b820a396
package
org.skywalking.apm.toolkit.activation.trace
;
import
java.lang.reflect.Method
;
import
org.skywalking.apm.agent.core.context.ContextManager
;
import
org.skywalking.apm.agent.core.context.trace.AbstractSpan
;
import
org.skywalking.apm.agent.core.plugin.interceptor.enhance.MethodInterceptResult
;
import
org.skywalking.apm.agent.core.plugin.interceptor.enhance.StaticMethodsAroundInterceptor
;
public
class
ActiveSpanTagInterceptor
implements
StaticMethodsAroundInterceptor
{
@Override
public
void
beforeMethod
(
Class
clazz
,
Method
method
,
Object
[]
allArguments
,
Class
<?>[]
parameterTypes
,
MethodInterceptResult
result
)
{
AbstractSpan
activeSpan
=
ContextManager
.
activeSpan
();
activeSpan
.
tag
(
String
.
valueOf
(
allArguments
[
0
]),
String
.
valueOf
(
allArguments
[
1
]));
}
@Override
public
Object
afterMethod
(
Class
clazz
,
Method
method
,
Object
[]
allArguments
,
Class
<?>[]
parameterTypes
,
Object
ret
)
{
return
ret
;
}
@Override
public
void
handleMethodException
(
Class
clazz
,
Method
method
,
Object
[]
allArguments
,
Class
<?>[]
parameterTypes
,
Throwable
t
)
{
}
}
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/src/main/java/org/skywalking/apm/toolkit/activation/trace/TraceAnnotationActivation.java
0 → 100644
浏览文件 @
b820a396
package
org.skywalking.apm.toolkit.activation.trace
;
import
net.bytebuddy.description.method.MethodDescription
;
import
net.bytebuddy.matcher.ElementMatcher
;
import
org.skywalking.apm.agent.core.plugin.interceptor.ConstructorInterceptPoint
;
import
org.skywalking.apm.agent.core.plugin.interceptor.InstanceMethodsInterceptPoint
;
import
org.skywalking.apm.agent.core.plugin.interceptor.enhance.ClassInstanceMethodsEnhancePluginDefine
;
import
org.skywalking.apm.agent.core.plugin.match.ClassMatch
;
import
static
net
.
bytebuddy
.
matcher
.
ElementMatchers
.
isAnnotatedWith
;
import
static
net
.
bytebuddy
.
matcher
.
ElementMatchers
.
named
;
import
static
org
.
skywalking
.
apm
.
agent
.
core
.
plugin
.
match
.
MethodAnnotationMatch
.
byMethodAnnotationMatch
;
/**
* {@link TraceAnnotationActivation} enhance all method that annotated with <code>org.skywalking.apm.toolkit.trace.annotation.Trace</code>
* by <code>org.skywalking.apm.toolkit.activation.trace.TraceAnnotationMethodInterceptor</code>.
*
* @author zhangxin
*/
public
class
TraceAnnotationActivation
extends
ClassInstanceMethodsEnhancePluginDefine
{
public
static
final
String
TRACE_ANNOTATION_METHOD_INTERCEPTOR
=
"org.skywalking.apm.toolkit.activation.trace.TraceAnnotationMethodInterceptor"
;
public
static
final
String
TRACE_ANNOTATION
=
"org.skywalking.apm.toolkit.trace.annotation.Trace"
;
@Override
protected
ConstructorInterceptPoint
[]
getConstructorsInterceptPoints
()
{
return
new
ConstructorInterceptPoint
[
0
];
}
@Override
protected
InstanceMethodsInterceptPoint
[]
getInstanceMethodsInterceptPoints
()
{
return
new
InstanceMethodsInterceptPoint
[]
{
new
InstanceMethodsInterceptPoint
()
{
@Override
public
ElementMatcher
<
MethodDescription
>
getMethodsMatcher
()
{
return
isAnnotatedWith
(
named
(
TRACE_ANNOTATION
));
}
@Override
public
String
getMethodsInterceptor
()
{
return
TRACE_ANNOTATION_METHOD_INTERCEPTOR
;
}
@Override
public
boolean
isOverrideArgs
()
{
return
false
;
}
}
};
}
@Override
protected
ClassMatch
enhanceClass
()
{
return
byMethodAnnotationMatch
(
new
String
[]
{
TRACE_ANNOTATION
});
}
}
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/src/main/java/org/skywalking/apm/toolkit/activation/trace/TraceAnnotationMethodInterceptor.java
0 → 100644
浏览文件 @
b820a396
package
org.skywalking.apm.toolkit.activation.trace
;
import
java.lang.reflect.Method
;
import
org.skywalking.apm.agent.core.context.ContextManager
;
import
org.skywalking.apm.agent.core.plugin.interceptor.enhance.EnhancedInstance
;
import
org.skywalking.apm.agent.core.plugin.interceptor.enhance.InstanceMethodsAroundInterceptor
;
import
org.skywalking.apm.agent.core.plugin.interceptor.enhance.MethodInterceptResult
;
import
org.skywalking.apm.toolkit.trace.Trace
;
/**
* {@link TraceAnnotationMethodInterceptor} create a local span and set the operation name which fetch from
* <code>org.skywalking.apm.toolkit.trace.annotation.Trace.operationName</code>. if the fetch value is blank string, and
* the operation name will be the method name.
*
* @author zhangxin
*/
public
class
TraceAnnotationMethodInterceptor
implements
InstanceMethodsAroundInterceptor
{
@Override
public
void
beforeMethod
(
EnhancedInstance
objInst
,
Method
method
,
Object
[]
allArguments
,
Class
<?>[]
argumentsTypes
,
MethodInterceptResult
result
)
throws
Throwable
{
Trace
trace
=
method
.
getAnnotation
(
Trace
.
class
);
String
operationName
=
trace
.
operationName
();
if
(
operationName
.
length
()
==
0
)
{
operationName
=
generateOperationName
(
method
);
}
ContextManager
.
createLocalSpan
(
operationName
);
}
private
String
generateOperationName
(
Method
method
)
{
StringBuilder
operationName
=
new
StringBuilder
(
method
.
getDeclaringClass
().
getName
()
+
"."
+
method
.
getName
()
+
"("
);
Class
<?>[]
parameterTypes
=
method
.
getParameterTypes
();
for
(
int
i
=
0
;
i
<
parameterTypes
.
length
;
i
++)
{
operationName
.
append
(
parameterTypes
[
i
].
getName
());
if
(
i
<
(
parameterTypes
.
length
-
1
))
{
operationName
.
append
(
","
);
}
}
operationName
.
append
(
")"
);
return
operationName
.
toString
();
}
@Override
public
Object
afterMethod
(
EnhancedInstance
objInst
,
Method
method
,
Object
[]
allArguments
,
Class
<?>[]
argumentsTypes
,
Object
ret
)
throws
Throwable
{
ContextManager
.
stopSpan
();
return
ret
;
}
@Override
public
void
handleMethodException
(
EnhancedInstance
objInst
,
Method
method
,
Object
[]
allArguments
,
Class
<?>[]
argumentsTypes
,
Throwable
t
)
{
ContextManager
.
activeSpan
().
errorOccurred
().
log
(
t
);
}
}
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/src/main/resources/skywalking-plugin.def
0 → 100644
浏览文件 @
b820a396
trace-annotation=org.skywalking.apm.toolkit.activation.trace.ActiveSpanTagActivation
trace-annotation=org.skywalking.apm.toolkit.activation.trace.TraceAnnotationActivation
apm-sniffer/apm-toolkit-activation/apm-toolkit-trace-activation/src/test/java/org/skywalking/apm/toolkit/activation/trace/TraceAnnotationTest.java
0 → 100644
浏览文件 @
b820a396
package
org.skywalking.apm.toolkit.activation.trace
;
import
java.lang.reflect.Method
;
import
java.util.List
;
import
org.junit.Before
;
import
org.junit.Rule
;
import
org.junit.Test
;
import
org.junit.runner.RunWith
;
import
org.mockito.Mock
;
import
org.powermock.modules.junit4.PowerMockRunner
;
import
org.powermock.modules.junit4.PowerMockRunnerDelegate
;
import
org.skywalking.apm.agent.core.context.trace.AbstractTracingSpan
;
import
org.skywalking.apm.agent.core.context.trace.TraceSegment
;
import
org.skywalking.apm.agent.core.context.util.KeyValuePair
;
import
org.skywalking.apm.agent.core.plugin.interceptor.enhance.EnhancedInstance
;
import
org.skywalking.apm.agent.test.helper.SegmentHelper
;
import
org.skywalking.apm.agent.test.helper.SpanHelper
;
import
org.skywalking.apm.agent.test.tools.AgentServiceRule
;
import
org.skywalking.apm.agent.test.tools.SegmentStorage
;
import
org.skywalking.apm.agent.test.tools.SegmentStoragePoint
;
import
org.skywalking.apm.agent.test.tools.TracingSegmentRunner
;
import
org.skywalking.apm.toolkit.trace.Trace
;
import
static
org
.
hamcrest
.
CoreMatchers
.
is
;
import
static
org
.
hamcrest
.
MatcherAssert
.
assertThat
;
import
static
org
.
skywalking
.
apm
.
agent
.
test
.
tools
.
SpanAssert
.
assertLogSize
;
import
static
org
.
skywalking
.
apm
.
agent
.
test
.
tools
.
SpanAssert
.
assertTagSize
;
@RunWith
(
PowerMockRunner
.
class
)
@PowerMockRunnerDelegate
(
TracingSegmentRunner
.
class
)
public
class
TraceAnnotationTest
{
@SegmentStoragePoint
private
SegmentStorage
storage
;
@Rule
public
AgentServiceRule
serviceRule
=
new
AgentServiceRule
();
@Mock
private
EnhancedInstance
enhancedInstance
;
private
TraceAnnotationMethodInterceptor
methodInterceptor
;
private
ActiveSpanTagInterceptor
tagInterceptor
;
private
Object
[]
tagParameters
;
private
Class
[]
tagParameterTypes
;
@Before
public
void
setUp
()
throws
Exception
{
methodInterceptor
=
new
TraceAnnotationMethodInterceptor
();
tagInterceptor
=
new
ActiveSpanTagInterceptor
();
tagParameters
=
new
Object
[]
{
"testTagKey"
,
"testTagValue"
};
tagParameterTypes
=
new
Class
[]
{
String
.
class
,
String
.
class
};
}
@Test
public
void
testTraceWithOperationName
()
throws
Throwable
{
Method
withOperationNameMethod
=
TestAnnotationMethodClass
.
class
.
getDeclaredMethod
(
"testMethodWithOperationName"
);
methodInterceptor
.
beforeMethod
(
enhancedInstance
,
withOperationNameMethod
,
null
,
null
,
null
);
tagInterceptor
.
beforeMethod
(
TestAnnotationMethodClass
.
class
,
withOperationNameMethod
,
tagParameters
,
tagParameterTypes
,
null
);
tagInterceptor
.
afterMethod
(
TestAnnotationMethodClass
.
class
,
withOperationNameMethod
,
tagParameters
,
tagParameterTypes
,
null
);
methodInterceptor
.
afterMethod
(
enhancedInstance
,
withOperationNameMethod
,
null
,
null
,
null
);
assertThat
(
storage
.
getTraceSegments
().
size
(),
is
(
1
));
TraceSegment
traceSegment
=
storage
.
getTraceSegments
().
get
(
0
);
List
<
AbstractTracingSpan
>
spans
=
SegmentHelper
.
getSpans
(
traceSegment
);
assertThat
(
spans
.
size
(),
is
(
1
));
AbstractTracingSpan
tracingSpan
=
spans
.
get
(
0
);
assertThat
(
tracingSpan
.
getOperationName
(),
is
(
"testMethod"
));
assertLogSize
(
tracingSpan
,
0
);
assertTagSize
(
tracingSpan
,
1
);
List
<
KeyValuePair
>
tags
=
SpanHelper
.
getTags
(
tracingSpan
);
assertThat
(
tags
.
get
(
0
).
getKey
(),
is
(
"testTagKey"
));
assertThat
(
tags
.
get
(
0
).
getValue
(),
is
(
"testTagValue"
));
}
@Test
public
void
testTrace
()
throws
Throwable
{
Method
withOperationNameMethod
=
TestAnnotationMethodClass
.
class
.
getDeclaredMethod
(
"testMethodWithDefaultValue"
);
methodInterceptor
.
beforeMethod
(
enhancedInstance
,
withOperationNameMethod
,
null
,
null
,
null
);
methodInterceptor
.
afterMethod
(
enhancedInstance
,
withOperationNameMethod
,
null
,
null
,
null
);
assertThat
(
storage
.
getTraceSegments
().
size
(),
is
(
1
));
TraceSegment
traceSegment
=
storage
.
getTraceSegments
().
get
(
0
);
List
<
AbstractTracingSpan
>
spans
=
SegmentHelper
.
getSpans
(
traceSegment
);
assertThat
(
spans
.
size
(),
is
(
1
));
AbstractTracingSpan
tracingSpan
=
spans
.
get
(
0
);
assertThat
(
tracingSpan
.
getOperationName
(),
is
(
TestAnnotationMethodClass
.
class
.
getName
()
+
"."
+
withOperationNameMethod
.
getName
()
+
"()"
));
assertLogSize
(
tracingSpan
,
0
);
assertTagSize
(
tracingSpan
,
0
);
}
private
class
TestAnnotationMethodClass
{
@Trace
(
operationName
=
"testMethod"
)
public
void
testMethodWithOperationName
()
{
}
@Trace
public
void
testMethodWithDefaultValue
()
{
}
}
}
apm-sniffer/apm-toolkit-activation/pom.xml
浏览文件 @
b820a396
...
...
@@ -15,6 +15,7 @@
<module>
apm-toolkit-logback-1.x-activation
</module>
<module>
apm-toolkit-trace-context-activation
</module>
<module>
apm-toolkit-opentracing-activation
</module>
<module>
apm-toolkit-trace-activation
</module>
</modules>
<artifactId>
apm-toolkit-activation
</artifactId>
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录