mirror of
https://github.com/alibaba/testable-mock.git
synced 2025-01-10 20:30:11 +08:00
refactor log methods
This commit is contained in:
parent
08aa73b4bd
commit
ad63de628d
@ -1,7 +1,8 @@
|
|||||||
package com.alibaba.testable.agent;
|
package com.alibaba.testable.agent;
|
||||||
|
|
||||||
import com.alibaba.testable.agent.transformer.TestableClassTransformer;
|
import com.alibaba.testable.agent.transformer.TestableClassTransformer;
|
||||||
import com.alibaba.testable.agent.util.LogUtil;
|
import com.alibaba.testable.core.util.LogUtil;
|
||||||
|
import com.alibaba.testable.core.model.MockDiagnose;
|
||||||
|
|
||||||
import java.lang.instrument.Instrumentation;
|
import java.lang.instrument.Instrumentation;
|
||||||
|
|
||||||
@ -13,6 +14,7 @@ public class PreMain {
|
|||||||
|
|
||||||
private static final String AND = "&";
|
private static final String AND = "&";
|
||||||
private static final String DEBUG = "debug";
|
private static final String DEBUG = "debug";
|
||||||
|
private static final String VERBOSE = "verbose";
|
||||||
|
|
||||||
public static void premain(String agentArgs, Instrumentation inst) {
|
public static void premain(String agentArgs, Instrumentation inst) {
|
||||||
parseArgs(agentArgs);
|
parseArgs(agentArgs);
|
||||||
@ -25,7 +27,9 @@ public class PreMain {
|
|||||||
}
|
}
|
||||||
for (String a : args.split(AND)) {
|
for (String a : args.split(AND)) {
|
||||||
if (a.equals(DEBUG)) {
|
if (a.equals(DEBUG)) {
|
||||||
LogUtil.globalDebugEnable = true;
|
LogUtil.setDefaultLevel(LogUtil.LEVEL_DIAGNOSE);
|
||||||
|
} else if (a.equals(VERBOSE)) {
|
||||||
|
LogUtil.setDefaultLevel(LogUtil.LEVEL_VERBOSE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,7 +4,7 @@ import com.alibaba.testable.agent.constant.ConstPool;
|
|||||||
import com.alibaba.testable.agent.model.MethodInfo;
|
import com.alibaba.testable.agent.model.MethodInfo;
|
||||||
import com.alibaba.testable.agent.util.BytecodeUtil;
|
import com.alibaba.testable.agent.util.BytecodeUtil;
|
||||||
import com.alibaba.testable.agent.util.ClassUtil;
|
import com.alibaba.testable.agent.util.ClassUtil;
|
||||||
import com.alibaba.testable.agent.util.LogUtil;
|
import com.alibaba.testable.core.util.LogUtil;
|
||||||
import org.objectweb.asm.Opcodes;
|
import org.objectweb.asm.Opcodes;
|
||||||
import org.objectweb.asm.tree.*;
|
import org.objectweb.asm.tree.*;
|
||||||
|
|
||||||
@ -52,7 +52,7 @@ public class SourceClassHandler extends BaseClassHandler {
|
|||||||
|
|
||||||
private void transformMethod(ClassNode cn, MethodNode mn, Set<MethodInfo> memberInjectMethods,
|
private void transformMethod(ClassNode cn, MethodNode mn, Set<MethodInfo> memberInjectMethods,
|
||||||
Set<MethodInfo> newOperatorInjectMethods) {
|
Set<MethodInfo> newOperatorInjectMethods) {
|
||||||
LogUtil.debug(" Handling method %s", mn.name);
|
LogUtil.diagnose(" Handling method %s", mn.name);
|
||||||
AbstractInsnNode[] instructions = mn.instructions.toArray();
|
AbstractInsnNode[] instructions = mn.instructions.toArray();
|
||||||
List<MethodInfo> memberInjectMethodList = new ArrayList<MethodInfo>(memberInjectMethods);
|
List<MethodInfo> memberInjectMethodList = new ArrayList<MethodInfo>(memberInjectMethods);
|
||||||
int i = 0;
|
int i = 0;
|
||||||
@ -155,7 +155,7 @@ public class SourceClassHandler extends BaseClassHandler {
|
|||||||
|
|
||||||
private AbstractInsnNode[] replaceNewOps(ClassNode cn, MethodNode mn, String newOperatorInjectMethodName,
|
private AbstractInsnNode[] replaceNewOps(ClassNode cn, MethodNode mn, String newOperatorInjectMethodName,
|
||||||
AbstractInsnNode[] instructions, int start, int end) {
|
AbstractInsnNode[] instructions, int start, int end) {
|
||||||
LogUtil.debug(" Line %d, mock method %s used", getLineNum(instructions, start),
|
LogUtil.diagnose(" Line %d, mock method %s used", getLineNum(instructions, start),
|
||||||
newOperatorInjectMethodName);
|
newOperatorInjectMethodName);
|
||||||
String classType = ((TypeInsnNode)instructions[start]).desc;
|
String classType = ((TypeInsnNode)instructions[start]).desc;
|
||||||
String constructorDesc = ((MethodInsnNode)instructions[end]).desc;
|
String constructorDesc = ((MethodInsnNode)instructions[end]).desc;
|
||||||
@ -187,7 +187,7 @@ public class SourceClassHandler extends BaseClassHandler {
|
|||||||
private AbstractInsnNode[] replaceMemberCallOps(ClassNode cn, MethodNode mn, String substitutionMethod,
|
private AbstractInsnNode[] replaceMemberCallOps(ClassNode cn, MethodNode mn, String substitutionMethod,
|
||||||
AbstractInsnNode[] instructions, String ownerClass,
|
AbstractInsnNode[] instructions, String ownerClass,
|
||||||
int opcode, int start, int end) {
|
int opcode, int start, int end) {
|
||||||
LogUtil.debug(" Line %d, mock method %s used", getLineNum(instructions, start), substitutionMethod);
|
LogUtil.diagnose(" Line %d, mock method %s used", getLineNum(instructions, start), substitutionMethod);
|
||||||
mn.maxStack++;
|
mn.maxStack++;
|
||||||
MethodInsnNode method = (MethodInsnNode)instructions[end];
|
MethodInsnNode method = (MethodInsnNode)instructions[end];
|
||||||
String testClassName = ClassUtil.getTestClassName(cn.name);
|
String testClassName = ClassUtil.getTestClassName(cn.name);
|
||||||
|
@ -9,7 +9,7 @@ import com.alibaba.testable.agent.model.MethodInfo;
|
|||||||
import com.alibaba.testable.agent.tool.ComparableWeakRef;
|
import com.alibaba.testable.agent.tool.ComparableWeakRef;
|
||||||
import com.alibaba.testable.agent.util.AnnotationUtil;
|
import com.alibaba.testable.agent.util.AnnotationUtil;
|
||||||
import com.alibaba.testable.agent.util.ClassUtil;
|
import com.alibaba.testable.agent.util.ClassUtil;
|
||||||
import com.alibaba.testable.agent.util.LogUtil;
|
import com.alibaba.testable.core.util.LogUtil;
|
||||||
import com.alibaba.testable.core.model.MockDiagnose;
|
import com.alibaba.testable.core.model.MockDiagnose;
|
||||||
import org.objectweb.asm.ClassReader;
|
import org.objectweb.asm.ClassReader;
|
||||||
import org.objectweb.asm.tree.AnnotationNode;
|
import org.objectweb.asm.tree.AnnotationNode;
|
||||||
@ -43,15 +43,15 @@ public class TestableClassTransformer implements ClassFileTransformer {
|
|||||||
try {
|
try {
|
||||||
if (shouldTransformAsSourceClass(className)) {
|
if (shouldTransformAsSourceClass(className)) {
|
||||||
// it's a source class with testable enabled
|
// it's a source class with testable enabled
|
||||||
LogUtil.debug("Handling source class %s", className);
|
LogUtil.diagnose("Handling source class %s", className);
|
||||||
List<MethodInfo> injectMethods = getTestableMockMethods(ClassUtil.getTestClassName(className));
|
List<MethodInfo> injectMethods = getTestableMockMethods(ClassUtil.getTestClassName(className));
|
||||||
return new SourceClassHandler(injectMethods).getBytes(classFileBuffer);
|
return new SourceClassHandler(injectMethods).getBytes(classFileBuffer);
|
||||||
} else if (shouldTransformAsTestClass(className)) {
|
} else if (shouldTransformAsTestClass(className)) {
|
||||||
// it's a test class with testable enabled
|
// it's a test class with testable enabled
|
||||||
LogUtil.debug("Handling test class %s", className);
|
LogUtil.diagnose("Handling test class %s", className);
|
||||||
return new TestClassHandler().getBytes(classFileBuffer);
|
return new TestClassHandler().getBytes(classFileBuffer);
|
||||||
}
|
}
|
||||||
resetMockContext();
|
LogUtil.resetLogLevel();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -79,7 +79,7 @@ public class TestableClassTransformer implements ClassFileTransformer {
|
|||||||
for (MethodNode mn : cn.methods) {
|
for (MethodNode mn : cn.methods) {
|
||||||
checkMethodAnnotation(cn, methodInfos, mn);
|
checkMethodAnnotation(cn, methodInfos, mn);
|
||||||
}
|
}
|
||||||
LogUtil.debug(" Found %d mock methods", methodInfos.size());
|
LogUtil.diagnose(" Found %d mock methods", methodInfos.size());
|
||||||
return methodInfos;
|
return methodInfos;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
return new ArrayList<MethodInfo>();
|
return new ArrayList<MethodInfo>();
|
||||||
@ -149,18 +149,12 @@ public class TestableClassTransformer implements ClassFileTransformer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void setupMockContext(AnnotationNode an) {
|
private void setupMockContext(AnnotationNode an) {
|
||||||
MockDiagnose mockDebug = AnnotationUtil.getAnnotationParameter(an, FIELD_DIAGNOSE, null, MockDiagnose.class);
|
MockDiagnose diagnose = AnnotationUtil.getAnnotationParameter(an, FIELD_DIAGNOSE, null, MockDiagnose.class);
|
||||||
if (MockDiagnose.ENABLE.equals(mockDebug)) {
|
if (diagnose != null) {
|
||||||
LogUtil.enableDebugLog();
|
LogUtil.enableDiagnose(diagnose == MockDiagnose.ENABLE);
|
||||||
} else if (MockDiagnose.DISABLE.equals(mockDebug)) {
|
|
||||||
LogUtil.disableDebugLog();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void resetMockContext() {
|
|
||||||
LogUtil.resetDebugLog();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Split desc to "first parameter" and "desc of rest parameters"
|
* Split desc to "first parameter" and "desc of rest parameters"
|
||||||
* @param desc method desc
|
* @param desc method desc
|
||||||
|
@ -1,33 +0,0 @@
|
|||||||
package com.alibaba.testable.agent.util;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author flin
|
|
||||||
*/
|
|
||||||
public class LogUtil {
|
|
||||||
|
|
||||||
private static final int LEVEL_ERROR = 0;
|
|
||||||
private static final int LEVEL_WARN = 1;
|
|
||||||
private static final int LEVEL_DIAGNOSE = 2;
|
|
||||||
private static int level;
|
|
||||||
|
|
||||||
public static boolean globalDebugEnable = false;
|
|
||||||
|
|
||||||
public static void debug(String msg, Object... args) {
|
|
||||||
if (level >= LEVEL_DIAGNOSE) {
|
|
||||||
System.out.println(String.format("[DIAGNOSE] " + msg, args));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void enableDebugLog() {
|
|
||||||
level = LEVEL_DIAGNOSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void disableDebugLog() {
|
|
||||||
level = LEVEL_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void resetDebugLog() {
|
|
||||||
level = globalDebugEnable ? LEVEL_DIAGNOSE : LEVEL_WARN;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -18,6 +18,6 @@ public @interface MockWith {
|
|||||||
* switch of mock diagnose information of current test class
|
* switch of mock diagnose information of current test class
|
||||||
* @return enable or disable
|
* @return enable or disable
|
||||||
*/
|
*/
|
||||||
MockDiagnose diagnose() default MockDiagnose.WARN_ONLY;
|
MockDiagnose diagnose() default MockDiagnose.DISABLE;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -12,12 +12,7 @@ public enum MockDiagnose {
|
|||||||
DISABLE,
|
DISABLE,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Only show warning message
|
* Print diagnose logs
|
||||||
*/
|
|
||||||
WARN_ONLY,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Print detail diagnose logs
|
|
||||||
*/
|
*/
|
||||||
ENABLE
|
ENABLE
|
||||||
|
|
||||||
|
@ -35,8 +35,10 @@ public class InvokeRecordUtil {
|
|||||||
List<Object[]> records = getInvokeRecord(mockMethodName, testCaseName);
|
List<Object[]> records = getInvokeRecord(mockMethodName, testCaseName);
|
||||||
if (isConstructor) {
|
if (isConstructor) {
|
||||||
records.add(args);
|
records.add(args);
|
||||||
|
LogUtil.verbose("Mock constructor invoked \"%s\"", key);
|
||||||
} else {
|
} else {
|
||||||
records.add(slice(args, 1));
|
records.add(slice(args, 1));
|
||||||
|
LogUtil.verbose("Mock method invoked \"%s\"", key);
|
||||||
}
|
}
|
||||||
INVOKE_RECORDS.put(key, records);
|
INVOKE_RECORDS.put(key, records);
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,46 @@
|
|||||||
|
package com.alibaba.testable.core.util;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author flin
|
||||||
|
*/
|
||||||
|
public class LogUtil {
|
||||||
|
|
||||||
|
public static final int LEVEL_ERROR = 0;
|
||||||
|
public static final int LEVEL_WARN = 1;
|
||||||
|
public static final int LEVEL_DIAGNOSE = 2;
|
||||||
|
public static final int LEVEL_VERBOSE = 3;
|
||||||
|
|
||||||
|
private static int defaultLogLevel = LEVEL_WARN;
|
||||||
|
private static int level;
|
||||||
|
|
||||||
|
public static void verbose(String msg, Object... args) {
|
||||||
|
if (level >= LEVEL_VERBOSE) {
|
||||||
|
System.out.println(String.format("[VERBOSE] " + msg, args));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void diagnose(String msg, Object... args) {
|
||||||
|
if (level >= LEVEL_DIAGNOSE) {
|
||||||
|
System.out.println(String.format("[DIAGNOSE] " + msg, args));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void warn(String msg, Object... args) {
|
||||||
|
if (level >= LEVEL_WARN) {
|
||||||
|
System.out.println(String.format("[WARN] " + msg, args));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void enableDiagnose(boolean enable) {
|
||||||
|
level = enable ? LEVEL_DIAGNOSE : LEVEL_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void setDefaultLevel(int level) {
|
||||||
|
defaultLogLevel = level;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void resetLogLevel() {
|
||||||
|
level = defaultLogLevel;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user