• 记录造数据测试接口


    一、前言

    java开发中经常需要造数据进行测试接口,这里记录一下常用的通过造数据测试接口的方法。

    二、一般的接口传参方式

    1、接口的方式最好是使用JSON或者map的方式,这样的好处是传参可以灵活伸缩,返回的结果也最好是JSON或者map的方式

    1. /**
    2. * 获取授权访问令牌accessToken
    3. * @param params
    4. * @return
    5. */
    6. @PostMapping("token")
    7. JSONObject getAccessToken(@RequestBody Map params);

    2、组装参数方法

    1. /**
    2. * 组装获取Access Token参数
    3. */
    4. public Map getACTokenParam() {
    5. Map map = new HashMap<>();
    6. String timestamp = DateTimeUtils.getDateStr();
    7. client_secret+timestamp+client_id+username+password+grant_type+scope+client_secret
    8. String clientSecM = MD5Util.getMd5(clientSecret).toUpperCase();
    9. String passwordM = MD5Util.getMd5(password).toUpperCase();
    10. String subString = (clientSecM + timestamp + clientId + userName + passwordM + grantType + scope + clientSecM);
    11. String sign = MD5Util.getMd5(subString).toUpperCase();
    12. map.put("grant_type", grantType);
    13. map.put("client_id", clientId);
    14. map.put("timestamp", timestamp);
    15. map.put("username", userName);
    16. map.put("password", passwordM);
    17. map.put("scope", scope);
    18. map.put("sign", sign);
    19. return map;
    20. }

    3.常见的造数据

    随机生成4位数

        Random rand = new Random();
        int randomNum = rand.nextInt(9000) + 1000;

    休眠

    //休眠3秒
     Thread.sleep(3000);

    获取guid

        /**
         * 获取guid
         * 
         * @return
         */
        public static String getGuid() {
            return UUID.randomUUID().toString().replaceAll("\\-", "");
        }
     

    。。

    1. /**
    2. * 获取guid
    3. *
    4. * @return
    5. */
    6. public static String getGuid() {
    7. return UUID.randomUUID().toString().replaceAll("\\-", "");
    8. }

    三、示例

    1. /**
    2. * 测试用户
    3. * @throws Exception
    4. */
    5. public void testUser() throws Exception {
    6. // 创建一个ObjectMapper对象
    7. ObjectMapper mapper = new ObjectMapper();
    8. // 创建一个Json对象
    9. ObjectNode json = mapper.createObjectNode();
    10. URL url = new URL("http://127.0.0.1/tourist-contract/register");
    11. for (int i = 0; i < 500; i++) {
    12. Random rand = new Random();
    13. int randomNum = rand.nextInt(9000) + 1000;
    14. json.put("Phone", "1308111"+randomNum);
    15. json.put("openID", "user_20000" + i);
    16. json.put("UserName", "test_" + i);
    17. json.put("unifyID", "test_" + i);
    18. json.put("userID", "test_" + i);
    19. json.put("reservedField", "reservedField");
    20. ObjectNode json1 = mapper.createObjectNode();
    21. json1.put("sender", json);
    22. json1.put("mark", "travel");
    23. log.info("注册用户上链参数json:"+json1);
    24. //休眠3秒
    25. Thread.sleep(3000);
    26. // 接口调用
    27. ltApi(json1, url, "1308111"+randomNum, "用户注册", "新增");
    28. }
    29. }

    白盒测试

    白盒测试是软件开发过程中的一种测试方法,它主要关注软件内部的结构和逻辑。这种测试方法可以帮助开发人员发现并纠正软件中的错误,提高软件的可靠性和稳定性。以下是一些常见的Java白盒测试方法:

    1. 代码审查:代码审查是一种常用的白盒测试方法。在代码审查过程中,开发人员和其他团队成员一起对代码进行审查,查找潜在的错误或问题。这种方法可以有效地发现代码中存在的缺陷和漏洞。
    2. 单元测试:单元测试是对单个类、方法和函数的测试。通过编写测试用例来验证这些元素是否按照预期工作,从而确保代码的质量和可靠性。使用JUnit和NUnit等工具可以方便地进行单元测试。
    3. 集成测试:集成测试是在将各个模块组合在一起时进行的测试。这包括检查不同模块之间的交互和数据流,以确保它们能够正确地协同工作。可以使用桩(插入到被测代码中的代码)和替身(模拟外部行为的对象)等技术来进行集成测试。
    4. 系统测试:系统测试是在整个系统中进行的测试,包括用户界面、功能、性能等方面。系统测试可以帮助识别系统在不同运行条件下的行为,以及系统的整体稳定性。可以使用自动化工具如loadrunner等进行系统测试。
    5. 异常处理测试:在进行白盒测试时,一个重要的方面是处理异常情况。异常处理应该确保在不同的异常情况下,系统能够正确地做出响应和决策。因此,在进行白盒测试时需要特别注意异常处理部分的测试。
    6. 边界值测试:边界值分析是一种有效的白盒测试方法,它可以检查程序在处理输入时的行为是否符合预期。通过对输入数据进行统计分析,可以找出可能引起问题的最小输入值或最大输入值。
    7. 文档测试:文档测试是一种辅助的白盒测试方法,用于确保文档与代码的一致性。通过检查文档中的描述与代码实现是否一致,可以及时发现不一致的情况,避免出现误解或误操作等问题。

    总之,白盒测试是一种非常重要的软件开发过程,有助于确保代码的质量和可靠性。通过合理的白盒测试策略和方法,可以提高软件的可维护性、可扩展性和安全性等方面的质量水平。

  • 相关阅读:
    NFTScan NFT API 在 NFTFi 开发中的应用
    详细介绍mysql表格id清零的方法
    17 | xml
    SSL证书的加密算法有哪些?
    Centos系统使用rsyn实现双主机目录实时同步
    LeetCode 每日一题 2022/11/7-2022/11/13
    【Linux】centos 7.2 max user processes修改不生效
    电脑同时连接有线和无线网络怎么设置网络的优先级
    Windows使用模拟器启动AOSP源码编译的镜像
    数据结构:二叉查找树
  • 原文地址:https://blog.csdn.net/dongjing991/article/details/132813071