未验证 提交 35d7a520 编写于 作者: C CharliePu 提交者: GitHub

A unit test can be better. (#6620)

上级 a396888d
...@@ -33,8 +33,8 @@ import org.apache.skywalking.apm.agent.test.tools.AgentServiceRule; ...@@ -33,8 +33,8 @@ import org.apache.skywalking.apm.agent.test.tools.AgentServiceRule;
import org.apache.skywalking.apm.agent.test.tools.SegmentStorage; import org.apache.skywalking.apm.agent.test.tools.SegmentStorage;
import org.apache.skywalking.apm.agent.test.tools.SegmentStoragePoint; import org.apache.skywalking.apm.agent.test.tools.SegmentStoragePoint;
import org.apache.skywalking.apm.agent.test.tools.TracingSegmentRunner; import org.apache.skywalking.apm.agent.test.tools.TracingSegmentRunner;
import org.apache.skywalking.apm.plugin.lettuce.v5.mock.MockClientOptions;
import org.apache.skywalking.apm.plugin.lettuce.v5.mock.MockRedisClusterClient; import org.apache.skywalking.apm.plugin.lettuce.v5.mock.MockRedisClusterClient;
import org.apache.skywalking.apm.plugin.lettuce.v5.mock.MockRedisClusterClientConstructorInterceptor;
import org.hamcrest.CoreMatchers; import org.hamcrest.CoreMatchers;
import org.hamcrest.MatcherAssert; import org.hamcrest.MatcherAssert;
import org.hamcrest.core.Is; import org.hamcrest.core.Is;
...@@ -120,11 +120,13 @@ public class RedisChannelWriterInterceptorTest { ...@@ -120,11 +120,13 @@ public class RedisChannelWriterInterceptorTest {
redisURIs.add(RedisURI.create("localhost", i)); redisURIs.add(RedisURI.create("localhost", i));
} }
MockRedisClusterClient mockRedisClusterClient = new MockRedisClusterClient(); MockRedisClusterClient mockRedisClusterClient = new MockRedisClusterClient();
MockRedisClusterClientConstructorInterceptor constructorInterceptor = new MockRedisClusterClientConstructorInterceptor(); MockClientOptions options = new MockClientOptions();
mockRedisClusterClient.setOptions(options);
RedisClusterClientConstructorInterceptor constructorInterceptor = new RedisClusterClientConstructorInterceptor();
constructorInterceptor.onConstruct(mockRedisClusterClient, new Object[] { constructorInterceptor.onConstruct(mockRedisClusterClient, new Object[] {
null, null,
redisURIs redisURIs
}); });
assertThat(mockRedisClusterClient.getOptions().getSkyWalkingDynamicField().toString().length(), Is.is(200)); assertThat(options.getSkyWalkingDynamicField().toString().length(), Is.is(200));
} }
} }
...@@ -18,22 +18,28 @@ ...@@ -18,22 +18,28 @@
package org.apache.skywalking.apm.plugin.lettuce.v5.mock; package org.apache.skywalking.apm.plugin.lettuce.v5.mock;
import io.lettuce.core.RedisURI; import io.lettuce.core.cluster.ClusterClientOptions;
import org.apache.skywalking.apm.agent.core.plugin.interceptor.enhance.EnhancedInstance; import org.apache.skywalking.apm.agent.core.plugin.interceptor.enhance.EnhancedInstance;
import org.apache.skywalking.apm.agent.core.plugin.interceptor.enhance.InstanceConstructorInterceptor;
import org.apache.skywalking.apm.agent.core.context.util.PeerFormat;
public class MockRedisClusterClientConstructorInterceptor implements InstanceConstructorInterceptor { public class MockClientOptions extends ClusterClientOptions implements EnhancedInstance {
private Object object;
public MockClientOptions() {
this(ClusterClientOptions.builder());
}
protected MockClientOptions(Builder builder) {
super(builder);
}
@Override
public Object getSkyWalkingDynamicField() {
return object;
}
@Override @Override
public void onConstruct(EnhancedInstance objInst, Object[] allArguments) { public void setSkyWalkingDynamicField(Object value) {
@SuppressWarnings("unchecked") Iterable<RedisURI> redisURIs = (Iterable<RedisURI>) allArguments[1]; this.object = value;
MockRedisClusterClient redisClusterClient = (MockRedisClusterClient) objInst;
StringBuilder peer = new StringBuilder();
for (RedisURI redisURI : redisURIs) {
peer.append(redisURI.getHost()).append(":").append(redisURI.getPort()).append(";");
}
EnhancedInstance optionsInst = redisClusterClient.getOptions();
optionsInst.setSkyWalkingDynamicField(PeerFormat.shorten(peer.toString()));
} }
} }
...@@ -18,41 +18,20 @@ ...@@ -18,41 +18,20 @@
package org.apache.skywalking.apm.plugin.lettuce.v5.mock; package org.apache.skywalking.apm.plugin.lettuce.v5.mock;
import io.lettuce.core.cluster.RedisClusterClient;
import org.apache.skywalking.apm.agent.core.plugin.interceptor.enhance.EnhancedInstance; import org.apache.skywalking.apm.agent.core.plugin.interceptor.enhance.EnhancedInstance;
public class MockRedisClusterClient implements EnhancedInstance { public class MockRedisClusterClient extends RedisClusterClient implements EnhancedInstance {
private Object ms; private Object object;
private EnhancedInstance options = new EnhancedInstance() {
private Object os;
@Override
public Object getSkyWalkingDynamicField() {
return os;
}
@Override
public void setSkyWalkingDynamicField(Object value) {
this.os = value;
}
};
public EnhancedInstance getOptions() {
return options;
}
public void setOptions(EnhancedInstance options) {
this.options = options;
}
@Override @Override
public Object getSkyWalkingDynamicField() { public Object getSkyWalkingDynamicField() {
return ms; return object;
} }
@Override @Override
public void setSkyWalkingDynamicField(Object value) { public void setSkyWalkingDynamicField(Object value) {
this.ms = value; this.object = value;
} }
} }
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册