mirror of
https://github.com/alibaba/testable-mock.git
synced 2025-01-25 20:00:17 +08:00
print diagnose descriptor in java-like format
This commit is contained in:
parent
24c6a9cc5c
commit
2976ca0211
@ -175,8 +175,7 @@ public class MockClassHandler extends BaseClassWithContextHandler {
|
|||||||
if (VOID_RES.equals(returnType)) {
|
if (VOID_RES.equals(returnType)) {
|
||||||
il.add(new InsnNode(POP));
|
il.add(new InsnNode(POP));
|
||||||
il.add(new InsnNode(RETURN));
|
il.add(new InsnNode(RETURN));
|
||||||
} else if (returnType.startsWith(String.valueOf(TYPE_ARRAY)) ||
|
} else if (returnType.charAt(0) == TYPE_ARRAY ||returnType.charAt(0) == TYPE_CLASS) {
|
||||||
returnType.startsWith(String.valueOf(TYPE_CLASS))) {
|
|
||||||
il.add(new TypeInsnNode(CHECKCAST, returnType));
|
il.add(new TypeInsnNode(CHECKCAST, returnType));
|
||||||
il.add(new InsnNode(ARETURN));
|
il.add(new InsnNode(ARETURN));
|
||||||
} else {
|
} else {
|
||||||
|
@ -67,8 +67,8 @@ public class SourceClassHandler extends BaseClassHandler {
|
|||||||
if (invokeOps.contains(instructions[i].getOpcode())) {
|
if (invokeOps.contains(instructions[i].getOpcode())) {
|
||||||
MethodInsnNode node = (MethodInsnNode)instructions[i];
|
MethodInsnNode node = (MethodInsnNode)instructions[i];
|
||||||
if (CONSTRUCTOR.equals(node.name)) {
|
if (CONSTRUCTOR.equals(node.name)) {
|
||||||
LogUtil.verbose(" Line %d, constructing \"%s\" as \"%s\"", getLineNum(instructions, i),
|
LogUtil.verbose(" Line %d, constructing \"%s\"", getLineNum(instructions, i),
|
||||||
node.owner, node.desc);
|
MethodUtil.toJavaDesc(node.owner, node.desc));
|
||||||
MethodInfo newOperatorInjectMethod = getNewOperatorInjectMethod(newOperatorInjectMethods, node);
|
MethodInfo newOperatorInjectMethod = getNewOperatorInjectMethod(newOperatorInjectMethods, node);
|
||||||
if (newOperatorInjectMethod != null) {
|
if (newOperatorInjectMethod != null) {
|
||||||
// it's a new operation and an inject method for it exist
|
// it's a new operation and an inject method for it exist
|
||||||
@ -79,14 +79,16 @@ public class SourceClassHandler extends BaseClassHandler {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
LogUtil.verbose(" Line %d, invoking \"%s\" as \"%s\"", getLineNum(instructions, i),
|
LogUtil.verbose(" Line %d, invoking \"%s\"", getLineNum(instructions, i),
|
||||||
node.name, node.desc);
|
MethodUtil.toJavaDesc(node.owner, node.name, node.desc));
|
||||||
MethodInfo mockMethod = getMemberInjectMethodName(memberInjectMethods, node);
|
MethodInfo mockMethod = getMemberInjectMethodName(memberInjectMethods, node);
|
||||||
if (mockMethod != null) {
|
if (mockMethod != null) {
|
||||||
// it's a member or static method and an inject method for it exist
|
// it's a member or static method and an inject method for it exist
|
||||||
int rangeStart = getMemberMethodStart(instructions, i);
|
int rangeStart = getMemberMethodStart(instructions, i);
|
||||||
if (rangeStart >= 0) {
|
if (rangeStart >= 0) {
|
||||||
|
if (rangeStart < i) {
|
||||||
handleFrameStackChange(mn, mockMethod, rangeStart, i);
|
handleFrameStackChange(mn, mockMethod, rangeStart, i);
|
||||||
|
}
|
||||||
instructions = replaceMemberCallOps(mn, mockMethod,
|
instructions = replaceMemberCallOps(mn, mockMethod,
|
||||||
instructions, node.owner, node.getOpcode(), rangeStart, i);
|
instructions, node.owner, node.getOpcode(), rangeStart, i);
|
||||||
i = rangeStart;
|
i = rangeStart;
|
||||||
|
@ -87,11 +87,12 @@ public class MockClassParser {
|
|||||||
for (AnnotationNode an : mn.visibleAnnotations) {
|
for (AnnotationNode an : mn.visibleAnnotations) {
|
||||||
String fullClassName = toDotSeparateFullClassName(an.desc);
|
String fullClassName = toDotSeparateFullClassName(an.desc);
|
||||||
if (fullClassName.equals(ConstPool.MOCK_CONSTRUCTOR)) {
|
if (fullClassName.equals(ConstPool.MOCK_CONSTRUCTOR)) {
|
||||||
LogUtil.verbose(" Mock constructor \"%s\" as \"(%s)V\" for \"%s\"", mn.name,
|
LogUtil.verbose(" Mock constructor \"%s\" as \"%s\"", mn.name,
|
||||||
MethodUtil.extractParameters(mn.desc), MethodUtil.getReturnType(mn.desc));
|
MethodUtil.toJavaDesc(MethodUtil.getReturnType(mn.desc), mn.desc));
|
||||||
addMockConstructor(methodInfos, cn, mn);
|
addMockConstructor(methodInfos, cn, mn);
|
||||||
} else if (fullClassName.equals(ConstPool.MOCK_METHOD) && AnnotationUtil.isValidMockMethod(mn, an)) {
|
} else if (fullClassName.equals(ConstPool.MOCK_METHOD) && AnnotationUtil.isValidMockMethod(mn, an)) {
|
||||||
LogUtil.verbose(" Mock method \"%s\" as \"%s\"", mn.name, getTargetMethodDesc(mn, an));
|
LogUtil.verbose(" Mock method \"%s\" as \"%s\"", mn.name, MethodUtil.toJavaDesc(
|
||||||
|
getTargetMethodOwner(mn, an), getTargetMethodName(mn, an), getTargetMethodDesc(mn, an)));
|
||||||
String targetMethod = AnnotationUtil.getAnnotationParameter(
|
String targetMethod = AnnotationUtil.getAnnotationParameter(
|
||||||
an, ConstPool.FIELD_TARGET_METHOD, mn.name, String.class);
|
an, ConstPool.FIELD_TARGET_METHOD, mn.name, String.class);
|
||||||
if (CONSTRUCTOR.equals(targetMethod)) {
|
if (CONSTRUCTOR.equals(targetMethod)) {
|
||||||
@ -107,6 +108,18 @@ public class MockClassParser {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String getTargetMethodOwner(MethodNode mn, AnnotationNode mockMethodAnnotation) {
|
||||||
|
Type type = AnnotationUtil.getAnnotationParameter(mockMethodAnnotation, ConstPool.FIELD_TARGET_CLASS,
|
||||||
|
null, Type.class);
|
||||||
|
return type == null ? MethodUtil.getFirstParameter(mn.desc) : type.getClassName();
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getTargetMethodName(MethodNode mn, AnnotationNode mockMethodAnnotation) {
|
||||||
|
String name = AnnotationUtil.getAnnotationParameter(mockMethodAnnotation, ConstPool.FIELD_TARGET_METHOD,
|
||||||
|
null, String.class);
|
||||||
|
return name == null ? mn.name : name;
|
||||||
|
}
|
||||||
|
|
||||||
private String getTargetMethodDesc(MethodNode mn, AnnotationNode mockMethodAnnotation) {
|
private String getTargetMethodDesc(MethodNode mn, AnnotationNode mockMethodAnnotation) {
|
||||||
Type type = AnnotationUtil.getAnnotationParameter(mockMethodAnnotation, ConstPool.FIELD_TARGET_CLASS,
|
Type type = AnnotationUtil.getAnnotationParameter(mockMethodAnnotation, ConstPool.FIELD_TARGET_CLASS,
|
||||||
null, Type.class);
|
null, Type.class);
|
||||||
|
@ -74,6 +74,6 @@ public class AnnotationUtil {
|
|||||||
public static boolean isValidMockMethod(MethodNode mn, AnnotationNode an) {
|
public static boolean isValidMockMethod(MethodNode mn, AnnotationNode an) {
|
||||||
Type targetClass = AnnotationUtil.getAnnotationParameter(an, ConstPool.FIELD_TARGET_CLASS, null, Type.class);
|
Type targetClass = AnnotationUtil.getAnnotationParameter(an, ConstPool.FIELD_TARGET_CLASS, null, Type.class);
|
||||||
String firstParameter = MethodUtil.getFirstParameter(mn.desc);
|
String firstParameter = MethodUtil.getFirstParameter(mn.desc);
|
||||||
return targetClass != null || firstParameter.startsWith(String.valueOf(TYPE_CLASS));
|
return targetClass != null || firstParameter.charAt(0) == TYPE_CLASS;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -105,4 +105,28 @@ public class MethodUtil {
|
|||||||
return b == TYPE_BYTE || b == TYPE_CHAR || b == TYPE_DOUBLE || b == TYPE_FLOAT
|
return b == TYPE_BYTE || b == TYPE_CHAR || b == TYPE_DOUBLE || b == TYPE_FLOAT
|
||||||
|| b == TYPE_INT || b == TYPE_LONG || b == TYPE_SHORT || b == TYPE_BOOL;
|
|| b == TYPE_INT || b == TYPE_LONG || b == TYPE_SHORT || b == TYPE_BOOL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* format to java style constructor descriptor
|
||||||
|
* @param owner class of method belongs to
|
||||||
|
* @param desc method constructor in bytecode format
|
||||||
|
* @return java style constructor descriptor
|
||||||
|
*/
|
||||||
|
public static String toJavaDesc(String owner, String desc) {
|
||||||
|
String parameters = MethodUtil.extractParameters(desc);
|
||||||
|
return String.format("%s(%s)", owner, parameters);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* format to java style method descriptor
|
||||||
|
* @param owner class of method belongs to
|
||||||
|
* @param name method name
|
||||||
|
* @param desc method descriptor in bytecode format
|
||||||
|
* @return java style method descriptor
|
||||||
|
*/
|
||||||
|
public static String toJavaDesc(String owner, String name, String desc) {
|
||||||
|
String returnType = MethodUtil.getReturnType(desc);
|
||||||
|
String parameters = MethodUtil.extractParameters(desc);
|
||||||
|
return String.format("%s %s::%s(%s)", returnType, owner, name, parameters);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user