接口测试平台:接口内容的设计(旧版已废弃)

男娘i 2023-05-30 06:27 87阅读 0赞

我们从表结构开始

  • 基础信息部分
    这部分主要是该条case的一些基础信息,例如创建人、最后更新人(同时也是最后调试过该case的人)。因为我们的平台有一个登录系统,所以所有case在被创建和被编辑的时候,会自动保存对应操作人的信息。
    在这里插入图片描述
    在这里插入图片描述
  • 接口信息
    这部分就是基础的接口信息。例如url、path、端口号等,在此不做过多叙述。
    在这里插入图片描述
    在这里插入图片描述
  • 请求参数
    这部分主要是配置接口的请求参数,例如header、body之类的,json会直接存为string,而form会以key value的形式,转成json类型的string,在下文会做详细说明。
    在这里插入图片描述
    在这里插入图片描述
  • 返回参数
    这里是做参数依赖和断言的关键。

例如我们在B接口中,需要依赖A接口的返回值,以下文截图为例:
将截图部分视为A接口,如果B接口中需要用到A接口返回的”success”的值,则以jsonPath或正则表达式的方式,将该字段值提取出来,然后设置变量名为SUCCESS,然后在B接口中,使用该参数时,传递${SUCCESS}即可。

校验:真实值的取值方式,也支持jsonPath和正则表达式的方式两种方式,然后与预期值的对比,目前只支持equals(相等)和contains(包含)两种。emm… 目前只支持body的校验。
当我们的接口在执行时,拿到返回结果后,会逐一检查校验条件是否都满足,只要有一条不满足,则会显示调试失败。
在这里插入图片描述
在这里插入图片描述
这里是bean文件,可以做个对比。

  1. @Data
  2. public class TestCase {
  3. /** 主键id */
  4. private int id;
  5. /** 创建人 */
  6. private String createrName;
  7. /** 创建人code */
  8. private String createrCode;
  9. /** 创建时间 */
  10. @JsonFormat(locale="zh", timezone="GMT+8", pattern="yyyy-MM-dd")
  11. private Date createDate;
  12. /** 更新人 */
  13. private String updaterName;
  14. /** 更新人 */
  15. private String updaterCode;
  16. /** 更新时间 */
  17. @JsonFormat(locale="zh", timezone="GMT+8", pattern="yyyy-MM-dd")
  18. private Date updateDate;
  19. /** 所属系统名称 */
  20. private String systemName;
  21. /** 接口名称 */
  22. private String apiName;
  23. /** url */
  24. private String apiUrl;
  25. /** 端口号 */
  26. private Integer apiPort;
  27. /** 请求方式 */
  28. private String apiMethod;
  29. /** 请求路径 */
  30. private String apiPath;
  31. /** 备注 */
  32. private String description;
  33. /** headers
  34. * 第一个为PO,第二个为VO,以下内推
  35. */
  36. private String headerValue;
  37. private List<RequestHeaders> headerForm;
  38. /**
  39. * body类型
  40. * 1.json 2.url form
  41. */
  42. private int bodyType;
  43. /** body-json */
  44. private String jsonValue;
  45. /** body-urlform */
  46. private String formValue;
  47. /** 需要保存的变量 */
  48. private String variableListValue;
  49. private List<VariableSave> variableList;
  50. /** 校验方式 */
  51. private String expectedListValue;
  52. private List<Expected> expectedList;
  53. /** 最后一次请求状态 */
  54. private Boolean status;
  55. /** 响应结果 */
  56. private String result;
  57. }

最后,对header、保存变量和校验方式的存储做一个说明。
以该条“保存变量”为例:
在这里插入图片描述
extractMethod对应的是变量的提取方式,extractRule是提取规则,variableName为变量名。

  1. [{"extractMethod":1,"extractRule":"$.success","variableName":"SUCCESS"},
  2. {"extractMethod":2,"extractRule":".*?","variableName":"ALL"}]

header、保存变量和校验方式均由以上形式,以JSONArray的方式存入数据库。
下篇文章。
下篇文章将会讲解接口的具体执行部分(因为这两篇文章加起来,就可以做一个接口自动化框架了~~),有疑问的小伙伴可在文章下方留言,我会不断优化文章的内容!

发表评论

表情:
评论列表 (有 0 条评论,87人围观)

还没有评论,来说两句吧...

相关阅读