refactor log methods

This commit is contained in:
金戟 2020-12-05 00:12:53 +08:00
parent 08aa73b4bd
commit ad63de628d
8 changed files with 68 additions and 60 deletions

View File

@ -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);
} }
} }
} }

View File

@ -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);

View File

@ -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

View File

@ -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;
}
}

View File

@ -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;
} }

View File

@ -12,12 +12,7 @@ public enum MockDiagnose {
DISABLE, DISABLE,
/** /**
* Only show warning message * Print diagnose logs
*/
WARN_ONLY,
/**
* Print detail diagnose logs
*/ */
ENABLE ENABLE

View File

@ -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);
} }

View File

@ -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;
}
}