java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > metershpere调用自定义jar包

metershpere实现调用自定义jar包中的方法

作者:gr1785

在MeterSphere接口测试中,面对多层循环逻辑和逻辑判断等复杂情况,直接编写测试用例往往显得混乱不便,本文介绍了一个简化这一过程的方法:首先使用IDEA创建Maven工程,编写所需逻辑并生成jar包;然后在MeterSphere中上传此jar包

背景

在编写一些稍微复杂一点的逻辑的接口测试用例时,大家可以感觉到metershpere用起来并不方便,即使用已有的控件写出来了看起来也异常混乱,比如有多层循环逻辑再加上一些逻辑判断,场景变量,全局变量来回变更时,保证metershpere的界面会让你看的头晕。

这时多数同学一定会选择自己定义脚本来解决。

这样所有复杂的实现逻辑都可以在jar包中实现,在beanshell脚本中调用就显得非常方便。

1. 生成jar包

IDE 选择IDEA,网上可以下载到社区版,对于我们编jar完全够用。

新建工程时建议选择maven工程,这样后续导入依赖库和编包都会很方便。

在pom.xml中添加项目的三方依赖库

编写完代码后直接双击package即可生成jar包

import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.List;
 
public class GenerateSignature {
    public static String getSignature1(String myJsonString)
    {
        LinkedHashMap<String, Object> body = JSON.parseObject(myJsonString, LinkedHashMap.class, Feature.OrderedField);
        JSONObject myJsonObject = new JSONObject(body);
        System.out.println(myJsonObject.toString());
        String myStr = getSigStr1(body);
        String signature = MD5Util.getMd5Lower(myStr);
        return signature+"_"+myTime;
 
    }
 
    public static String getSignature2(HashMap<String,Object> myHashMap)
    {
        int myShutMapTime = 0;
        int myDelayTime = 0;
        List<String> myStoreCodes = null;
        String myStoreCode = null;
        String mySignatureContent = null;
        Integer myId = (Integer) myHashMap.get("myId");
        String myReason = (String) myHashMap.get("myReason");
        int myType = (int) myHashMap.get("myType");
        long myTime = (long) myHashMap.get("time");
 
        String signature = MD5Util.getMd5Lower(mySignatureContent);
        return signature;
    }
}

说明:

1. 在工程src/main/java下面如果没有定义目录,在beanshell中直接导入类名即可

2. GenerateSignature类中提供出来的方法建议都定义成public static 形式,这样在beanshell脚本中通过类名可以直接调用 GenerateSignature.getSignature1("myString")

3. 参数传入可以以消息体字符串传入,也可以以Map形式传入

2. 上传Jar包

项目设置==》文件管理==》添加文件 选择文件上传

最后点击查看将添加jar包开关打开

3. beanshell脚本调用代码

如下:

import java.util.HashMap;
import GeneragteSignature;
// 参数为字符串
String myBody = "{\"userName\":\"xxx\",\"orderId\":\"1723333333\"}";
mySig1 = GeneragteSignature.getSignature1(myBody);
log.info("mySig1: " + mySig1);
 
//参数为Map
Map map = new HashMap();
map.put("myId", null);
map.put("myReason", null);
map.put("myType", 1);
map.put("time", 0L);
mySig2 = GeneragteSignature.getSignature2(map1);
log.info("mySig2: " + mySig2);

说明:

1. 脚本中演示了两种参数方式调用,一种直接传消息体字符串,这个字符串需要经过压缩转义

大家可以直接到网上查找json字符串压缩转义网站进行处理,如:

2. 如果已Map形式传入,需要注意map中字段类型,比如如果是long行,传入值需要写成 0L 形式

3. 声明为Map形式可以直接这样写 Map map = new HashMap(); 不需要带泛型<>, 如果带了beanshell可能会不支持

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文