java test 经验之谈

  • 控制台日志校验
/**
     * 日志间谍类
     */
public static class Logget {
        ByteArrayOutputStream bytes = new ByteArrayOutputStream();//缓冲
        PrintStream console;
        public List<String> loglist = new ArrayList<>();

        public void listenSTD() {
            console = System.out;//获取System.out 输出流的句柄
            System.setOut(new PrintStream(bytes));
        }

        public void listenSTDAndClear() {
            listenSTD();
            loglist.clear();
            bytes.reset();
        }

        public List<String> close() {
            resetSTD();
            for (String s : bytes.toString().split("\r\n")
            ) {
                loglist.add(s);
            }
            return this.loglist;
        }

        private void resetSTD() {
            System.setOut(console);//复位
        }

        public List<String> closeandprintSTD() {
            resetSTD();
            System.out.print(bytes);
            return close();
        }
    }

//使用
logget=new Logget();
logger.listenSTDAndClear();//监听日志
日志打印
日志打印1
logtext = logget.closeandprintSTD();//释放监听,并获取截留,控制台输出原本截留的日志,logtext是用于校验的list
  • yaml加载校验
public <T> List<T> loadYAML(String content, Class cls) {
        ObjectMapper mapper = new ObjectMapper(new YAMLFactory());
        mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES,false);//字段映射缺少时忽略
        try {
            return mapper.readValue(content, mapper.getTypeFactory().constructParametricType(ArrayList.class, cls));
        } catch (JsonProcessingException e) {
            e.printStackTrace();
        }
        return null;
    }

    public <T> List<T> loadYAML(URL src,Class cls){
        //com.*
        ObjectMapper mapper = new ObjectMapper(new YAMLFactory());
        mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES,false);//字段映射缺少时忽略
        try {
            return mapper.readValue(src,mapper.getTypeFactory().constructParametricType(ArrayList.class, cls));
        } catch (JsonProcessingException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return null;
    }
  • 步骤打印
protected void title(String s) {
        String out = String.format("==[step%d].[%s]=", step++, s);
        try {
            while (new String(out.getBytes("GB2312"), "ISO-8859-1").length() < 50) {
                out += "=";
            }
        } catch (UnsupportedEncodingException u) {
            u.printStackTrace();
        }
        StackTraceElement stackTraceElement = Thread.currentThread().getStackTrace()[2];
        System.out.println(out + "(" + stackTraceElement.getFileName() + ":" + stackTraceElement.getLineNumber() + ")");
    }
  • 一次初始化
@Autowired
   protected FlowReq baseTestNameSpace;
   protected void initOnce(String uniqueName,Executor executor){
       Objects.requireNonNull(executor);
       if (!baseTestNameSpace.b(uniqueName)) {//只加载一次
           executor.runAction(this);
           baseTestNameSpace.append(uniqueName,true);
           log.info(uniqueName+" initOnce() Done");
       }
   }
    protected interface Executor{
       void runAction(BaseFlowTest a);
   }
//使用
   initOnce("init",(base)->{
       do();
   });
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值