• postman定义公共函数这样写,测试组长直呼牛逼!!!


    postman定义公共函数

    在postman中,如下面的代码:

    1、返回元素是否与预期值一致

    var assertEqual=(name,actual,expected)=>{tests[`${name}:实际结果: ${actual} , 期望结果:${expected}`]=actual===expected;};

    2、返回元素是否与预期值不一致

    var assertNotEqual=(name,actual,expected)=>{tests[`${name}:实际结果: ${actual} , 期望结果:${expected}`]=actual!==expected;};

    以上都是自定义的断言函数,每次在使用的时候都需要把代码进行复制粘贴,很不方便,可以使用公共函数来实现。

    eval() 函数作用

    可以接受一个字符串str作为参数,并把这个参数作为脚本代码来 执行。

    举例如下:把代码转成字符串并做一个变量,然后通过eval(变量名)函数转成代码直接调用

    复制代码

    //定义s为变量
    var s = 'var a = 10; var b = 20;'
    eval(s)  //把s变量的值转成代码;即a = 10;b = 20
    tests[a+b] = true  //输出a + b = 30
    
    //做断言,实际结果和预期结果一致
    var common_function = 'var assertEqual=(name,actual,expected)=>{tests[`${name}:实际结果:${actual} , 期望结果:${expected}`]=actual===expected;};'
    eval(common_function)
    assertEqual("验证title是否正确",title,"猫_百度搜索")

    复制代码

    如下操作完成公共函数的编写:

    备注:只能使用var定义的函数,不能用const

    1、把定义好的函数作为字符串存放在变量中;如下图的common_function变量

    2、把上一个定义的变量设置到全局变量中;

    3、在需要使用函数的地方,使用eval()函数把全局变量中的值转换为代码进行执行 。

     4、查看执行结果

     自动化测试相关教程推荐:

    2023最新自动化测试自学教程新手小白26天入门最详细教程,目前已有300多人通过学习这套教程入职大厂!!_哔哩哔哩_bilibili

    2023最新合集Python自动化测试开发框架【全栈/实战/教程】合集精华,学完年薪40W+_哔哩哔哩_bilibili

    测试开发相关教程推荐

    2023全网最牛,字节测试开发大佬现场教学,从零开始教你成为年薪百万的测试开发工程师_哔哩哔哩_bilibili

    postman/jmeter/fiddler测试工具类教程推荐

    讲的最详细JMeter接口测试/接口自动化测试项目实战合集教程,学jmeter接口测试一套教程就够了!!_哔哩哔哩_bilibili

    2023自学fiddler抓包,请一定要看完【如何1天学会fiddler抓包】的全网最详细视频教程!!_哔哩哔哩_bilibili

    2023全网封神,B站讲的最详细的Postman接口测试实战教学,小白都能学会_哔哩哔哩_bilibili

    通过上面的方式知道可以把函数代码放到全局变量中,那么可以把经常用到的函数代码一起放到全局变量中;

    示例:复制代码

    //获取当前时间戳 毫秒
    var now_time = Date.now()
    pm.globals.set("now_time",now_time)
    
    //guid实现
    const guid = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'
    .replace(/x/g, () => (Math.floor(Math.random() * 16)).toString(16))
    .replace(/y/g, () => (Math.floor(Math.random() * 4 + 8)).toString(16));
    pm.globals.set("guid_value",guid)
    
    //随机整数实现
    const randomInt = (min, max) => Math.floor(Math.random() * (max - min + 1)) + 
    min
    pm.globals.set("randomInt_num",randomInt(8,15))
    
    //从多个选项中选择实现
    const randomInt = (min, max) => Math.floor(Math.random() * (max - min + 1)) + 
    min
    const getRandomValue = list => list[randomInt(0, list.length - 1)];
    const charsInName = ['王','李','张']
    pm.globals.set("people_name",getRandomValue(charsInName))
    
    
    //随机手机号实现
    const randomInt = (min, max) => Math.floor(Math.random() * (max - min + 1)) + 
    min
    var mobile_num = `18${randomInt(100000000, 999999999)}`;
    pm.globals.set("mobile_num",mobile_num)
    
    //同步等待实现:等待5秒后开始执行
    const sleep = (milliseconds) => {
    const start = Date.now();
    while (Date.now() <= start + milliseconds) {}
    }
    sleep(5000)

    把上方的代码拼到一起如下:

    var now_time = Date.now();var guid = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx';var randomInt = (min, max) => Math.floor(Math.random() * (max - min + 1)) + min;var randomInt = (min, max) => Math.floor(Math.random() * (max - min + 1)) + min;var getRandomValue = list => list[randomInt(0, list.length - 1)];var mobile_num = `18${randomInt(100000000, 999999999)}`;var sleep = (milliseconds) => {const start = Date.now();while (Date.now() <= start + milliseconds) {}};var assertEqual=(name,actual,expected)=>{tests[`${name}:实际结果:${actual} , 期望结果:${expected}`]=actual===expected;};

    在全局变量中定义一个公共函数common_function,变量值为拼接的函数

     在Pre-request Script和tests页签中调用common_function中的函数

    以随机手机号举例:

    1、在Pre-request Script页签中调用公共函数common_function,并再设置一个随机手机号的全局变量;如下图

     

     2、在tests页签中做断言

     3、查看执行结果

     

     总结:

     光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

    如果对你有帮助的话,点个赞收个藏,给作者一个鼓励。也方便你下次能够快速查找。

    如有不懂还要咨询下方小卡片,博主也希望和志同道合的测试人员一起学习进步

    在适当的年龄,选择适当的岗位,尽量去发挥好自己的优势。

    我的自动化测试开发之路,一路走来都离不每个阶段的计划,因为自己喜欢规划和总结,

    测试开发视频教程、学习笔记领取传送门!!

  • 相关阅读:
    机器学习中类别不平衡问题的解决方案
    指针和数组试题解析(4)字符数组部分续集
    Java内存模型基础(JMM)
    使用 kind 搭建 Kubernetes学习环境
    python 第二次作业
    Spring Boot_1【配置环境&&项目结构&&Spring Security相关】
    element-plus 踩的坑
    vue组件精讲
    React18 渲染列表与添加key值
    LLM - 大模型速递 Baichuan2 快速入门
  • 原文地址:https://blog.csdn.net/m0_59868866/article/details/134562598