关于面试总结12-接口自动化面试题

前言

前面总结了一篇关于接口测试的常规面试题,现在接口自动化测试用的比较多,也是被很多公司看好。那么想做接口自动化测试需要具备哪些能力呢?
也就是面试的过程中,面试官会考哪些问题,知道你是不是真的做过接口自动化测试?总的来说问的比较多的就是以下几个问题:

1.json和字典的区别?  -对基础数据类型的考察
2.测试的数据你放在哪?  -数据与脚本分离
3.参数化  - 数据驱动模式
4.下个接口请求参数依赖上个接口的返回数据 - 参数关联
5.依赖于登录的接口如何处理 -token和session的管理
6.依赖第三方的接口如何处理  -mock模拟数据返回
7.不可逆的操作,如何处理,比如删除一个订单这种接口如何测试 -造数据
8.接口产生的垃圾数据如何清理 - 数据清理
9.一个订单的几种状态如何全部测到,如:未处理,处理中,处理失败,处理成功  - 造数据,改数据库订单状态
10.python如何连接数据库操作?
11.其它的就是运行出报告、代码管理(git)、运行策略和持续集成jenkins相关了

1.json和字典dict的区别?

现在自动化培训烂大街,是个人都能说的上几个框架,面试如果问框架相关问题,求职者只需一瓶82年的雪碧,会吹的让你怀疑人生!
所以面试官为了更清楚的知道你是停留在表面上的花拳绣腿还是有扎实的基础,就不会问框架这种东西了。基本上问几个数据类型的基础就知道有没货了。

那么json和字典到底有什么区别呢?初学者连python的基础数据类型都没搞清楚,直接撸框架,有的人学了几个月可能都迷迷糊糊的,以为json就是字典。这个是肯定不对的。

首先python里面的基础数据类型有:int、str、 float、list、bool、tuple、dict、set这几种类型,里面没json这种数据类型。

JSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式。它基于 ECMAScript (欧洲计算机协会制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。

由于你的代码是python写的(也有可能是php,java,c,ruby等语言),但是后端接口是java写的(也有可能是其它语言),不同的语言数据类型是不一样的(就好比中国的语言和美国的语言数据类型也不一样,中国的一般说一只羊,一头牛,美国都是 a /an这种单位),所以就导致你提交的数据,别的开发语言无法识别,这就需要规范传输的数据(传输的数据都是一个字符串),大家都遵循一个规范,按一个标准的格式去传输,于是就有就json这种国际化规范的数据类型。

json本质上还是字符串,只是按key:value这种键值对的格式来的字符串

import json # a是字典dict a = {"a": 1, "b": 2, "c": True} # b是json b = '{"a": 1, "b": 2, "c": true}' print(type(a)) print(json.dumps(a))   # a转json

运行结果

<class 'dict'> {"a": 1, "b": 2, "c": true} <class 'str'> {'a': 1, 'b': 2, 'c': True}

2.测试的数据你放在哪?

测试数据到底该怎么放,这个是面试官最喜欢问的一个题了,似乎仁者见仁智者见智,没有标准的答案,有的人说放excel,也有的说放.py脚本,也有的说放ini配置文件,
还有放到json,yaml文件,txt文件,甚至有的放数据库,五花八门,一百个做自动化的小伙伴有100个放的地方。

这里总结下测试的数据到底该怎么放?

首先测试的数据是分很多种的,有登录的账户数据,也有注册的账户数据,还有接口的参数,还有邮箱配置的数据等等等等,所以这个题不能一概而论给答死了。要不然就是给自己挖坑。

以下两个大忌不能回答:

  • 测试的数据是不能写死到代码里面的,这个是原则问题,也是写代码的大忌(你要是回答写在代码里面,估计就是回去等通知了)

  • 测试数据放到.py的开头,这种其实很方便,对于少量的,固定不变的数据其实是可以放的,但是面试时候,千万不能这样说,面试官喜欢装逼的方法

测试数据存放总结:

1.对于账号密码,这种管全局的参数,可以用命令行参数,单独抽出来,写的配置文件里(如ini)
2.对于一些一次性消耗的数据,比如注册,每次注册不一样的数,可以用随机函数生成
3.对于一个接口有多组测试的参数,可以参数化,数据放yaml,text,json,excel都可以
4.对于可以反复使用的数据,比如订单的各种状态需要造数据的情况,可以放到数据库,每次数据初始化,用完后再清理
5.对于邮箱配置的一些参数,可以用ini配置文件
6.对于全部是独立的接口项目,可以用数据驱动方式,用excel/csv管理测试的接口数据
7.对于少量的静态数据,比如一个接口的测试数据,也就2-3组,可以写到py脚本的开头,十年八年都不会变更的

总之不同的测试数据,可以用不同的文件管理

3.什么是数据驱动,如何参数化?

参数化和数据驱动的概念这个肯定要知道的,参数化的思想是代码用例写好了后,不需要改代码,只需维护测试数据就可以了,并且根据不同的测试数据生成多个用例
python里面用unittest框架

import unittest import ddt # 测试数据 datas = [ {"user": "admin", "psw": "123", "result": "true"},        {"user": "admin1", "psw": "1234", "result": "true"},        {"user": "admin2", "psw": "1234", "result": "true"},        {"user": "admin3", "psw": "1234", "result": "true"},        {"user": "admin4", "psw": "1234", "result": "true"},        {"user": "admin5", "psw": "1234", "result": "true"},        {"user": "admin6", "psw": "1234", "result": "true"},        {"user": "admin7", "psw": "1234", "result": "true"},        {"user": "admin8", "psw": "1234", "result": "true"},        {"user": "admin9", "psw": "1234", "result": "true"},        {"user": "admin10", "psw": "1234", "result": "true"},        {"user": "admin11", "psw": "1234", "result": "true"}] @ddt.ddt class Test(unittest.TestCase):    @ddt.data(*datas)    def test_(self, d):        """上海-悠悠:{0}"""        print("测试数据:%s" % d) if __name__ == "__main__":    unittest.main()

unittest框架还有一个paramunittest也可以实现

import unittest import paramunittest import time # python3.6 # 作者:上海-悠悠 @paramunittest.parametrized(    {"user": "admin", "psw": "123", "result": "true"},    {"user": "admin1", "psw": "1234", "result": "true"},    {"user": "admin2", "psw": "1234", "result": "true"},    {"user": "admin3", "psw": "1234", "result": "true"},    {"user": "admin4", "psw": "1234", "result": "true"},    {"user": "admin5", "psw": "1234", "result": "true"},    {"user": "admin6", "psw": "1234", "result": "true"},    {"user": "admin7", "psw": "1234", "result": "true"},    {"user": "admin8", "psw": "1234", "result": "true"},    {"user": "admin9", "psw": "1234", "result": "true"},    {"user": "admin10", "psw": "1234", "result": "true"},    {"user": "admin11", "psw": "1234", "result": "true"}, ) class TestDemo(unittest.TestCase):    def setParameters(self, user, psw, result):        '''这里注意了,user, psw, result三个参数和前面定义的字典一一对应'''        self.user = user        self.user = psw        self.result = result    def testcase(self):        print("开始执行用例:--------------")        time.sleep(0.5)        print("输入用户名:%s" % self.user)        print("输入密码:%s" % self.user)        print("期望结果:%s " % self.result)        time.sleep(0.5)        self.assertTrue(self.result == "true") if __name__ == "__main__":    unittest.main(verbosity=2)

如果用的是pytest框架,也能实现参数化

# content of test_canshu1.py # coding:utf-8 import pytest @pytest.mark.parametrize("test_input,expected",                         [ ("3+5", 8),                           ("2+4", 6),                           ("6 * 9", 42),                         ]) def test_eval(test_input, expected):    assert eval(test_input) == expected if __name__ == "__main__":    pytest.main(["-s", "test_canshu1.py"])

pytest里面还有一个更加强大的功能,获得多个参数化参数的所有组合,可以堆叠参数化装饰器

import pytest @pytest.mark.parametrize("x", [0, 1]) @pytest.mark.parametrize("y", [2, 3]) def test_foo(x, y):    print("测试数据组合:x->%s, y->%s" % (x, y)) if __name__ == "__main__":    pytest.main(["-s", "test_canshu1.py"])

4.下个接口请求参数依赖上个接口的返回数据

这个很容易,不同的接口封装成不同的函数或方法,需要的数据return出来,用一个中间变量a去接受,后面的接口传a就可以了
参考这篇python接口自动化26-参数关联(JSESSIONID)

5.依赖于登录的接口如何处理

登录接口依赖token的,可以先登录后,token存到一个yaml或者json,或者ini的配置文件里面,后面所有的请求去拿这个数据就可以全局使用了
参考之前分享的一篇python接口自动化24-token关联登录

如果是cookies的参数,可以用session自动关联

s=requests.session()

后面请求用s.get()和s.post()就可以自动关联cookies了

6.依赖第三方的接口如何处理

这个需要自己去搭建一个mock服务,模拟接口返回数据,参考python笔记25-mock-server之moco环境搭建

moco是一个开源的框架,在github上可以下载到https://github.com/dreamhead/moco

moco服务搭建需要自己能够熟练掌握,面试会问你具体如何搭建 ,如何模拟返回的数据,是用的什么格式,如何请求的

7.不可逆的操作,如何处理,比如删除一个订单这种接口如何测试

此题考的是造数据的能力,接口的请求数据,很多都是需要依赖前面一个状态的
比如工作流这种,流向不同的人状态不一样,操作权限不一样,测试的时候,每种状态都要测到,就需要自己会造数据了。
平常手工测试造数据,直接在数据库改字段状态。那么自动化也是一样,造数据可以用python连数据库了,做增删改查的操作
测试用例前置操作,setUp做数据准备
后置操作,tearDown做数据清理

8.接口产生的垃圾数据如何清理

跟上面一样,造数据和数据清理,需用python连数据库了,做增删改查的操作
测试用例前置操作,setUp做数据准备
后置操作,tearDown做数据清理

9.一个订单的几种状态如何全部测到,如:未处理,处理中,处理失败,处理成功

跟上面一样,也是考察造数据,修改数据的状态

10.python如何连接数据库操作?

这个就是详细的考察你是如何用python连数据库的,并且最好能现场写代码那种(有的笔试题就是python连数据库)
具体问你用到哪个模块,查询的数据是什么类型?如何删除数据?如何新增数据?如何修改数据?
PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。
详情参考教程http://www.runoob.com/python3/python3-mysql.html

#!/usr/bin/python3 # 查询EMPLOYEE表中salary(工资)字段大于1000的所有数据: import pymysql # 打开数据库连接 db = pymysql.connect("localhost","testuser","test123","TESTDB" ) # 使用cursor()方法获取操作游标 cursor = db.cursor() # SQL 查询语句 sql = "SELECT * FROM EMPLOYEE       WHERE INCOME > %s" % (1000) try:   # 执行SQL语句   cursor.execute(sql)   # 获取所有记录列表   results = cursor.fetchall()   for row in results:      fname = row[0]      lname = row[1]      age = row[2]      sex = row[3]      income = row[4]       # 打印结果      print ("fname=%s,lname=%s,age=%s,sex=%s,income=%s" %             (fname, lname, age, sex, income )) except:   print ("Error: unable to fetch data") # 关闭数据库连接 db.close()

其它的就是运行出报告、代码管理(git)、运行策略和持续集成jenkins相关了,这个所以的自动化但是一样的,后面会单独讲一篇jenkins持续集成相关

2019年《python全栈自动化测试课程》2月16号开学!

主讲老师:上海-悠悠

上课方式:QQ群视频在线教学

上课时间:每周六、周日晚上20:30-22:30

2019年《python全栈自动化测试课程》2月16号开学!

(0)

相关推荐

  • Python实战013:如何将数据以JSON格式输出

    JSON(全称:JavaScript Object Notation) 是一种轻量级的数据交换格式,它的结构简洁.层次清晰也没有xml那么多标签描述让文件更加小巧且解析速度更快.非常适合做网络传输的数 ...

  • 用Python分析元旦旅游热门城市,告诉你哪些景点性价比更高

    元旦马上就要到了,难得的3天小长假,玩肯定是要去玩的,但去哪儿玩是个问题.于是,J哥以旅游热门城市厦门为例,用Python获取了去哪儿网的相关景点数据,包括景点名称.地区.评分.销量.价格.坐标等字段 ...

  • python基础之JSON标准库

    一.序列化的一些简单概念 我们平常使用的python对象所进行的操作是在内存中,当程序关闭就会被清空,所以我们需要用一种合适的方法将这些数据保存下来. 为了将我们的数据进行永久存储,需要引入序列化(p ...

  • python中的json、pickle

    json 提供了四个功能: dumps:将json数据转换为字符串 json.dumps(obj,skipkeys=False,separators=None,sort_keys=False) loa ...

  • Python网络爬虫学习基础笔记

    python requests库爬虫基础 本次学习的python爬虫所使用的是requests库 下面就是requests库的7种主要方法 方法名 说明 requests.request() 构造一个 ...

  • Python常用配置文件ini、json、yaml读写总结

    原创 吾非同 吾非同 3天前 开发项目时,为了维护一些经常需要变更的数据,比如数据库的连接信息.请求的url.测试数据等,需要将这些数据写入配置文件,将数据和代码分离,只需要修改配置文件的参数,就可以 ...

  • python接口自动化40-盘点requests那些不常用(面试经常问)的高级技能

    前言 如果面试问你如何用 python 发 get/post 请求? 这种问题只要是个小白花10分钟随便看下博客都能学得会. 面试官如果知道你是资深的,还是初级的呢?面试其实最喜欢考那些你不常用的功能 ...

  • 接口自动化

    一.自动化分类 (1)接口自动化 > python/java+requests+unittest框架来实现 > python/java+RF(RobotFramework)框架来实现--对 ...

  • python接口自动化1-发送get请求

    前言 requests模块,也就是老污龟,为啥叫它老污龟呢,因为这个官网上的logo就是这只污龟,接下来后面的自动化都离不开它. 一.环境安装 1.用pip安装requests模块 >>p ...

  • python接口自动化2-发送post请求

    前言 发送post的请求参考例子很简单,实际遇到的情况却是很复杂的,首先第一个post请求肯定是登录了,但登录是最难处理的.登录问题解决了,后面都简单了. 一.查看官方文档 1.学习一个新的模块,其实 ...

  • python接口自动化3-自动发帖(session)

    前言 上一篇模拟登录博客园,但这只是第一步,一般登录后,还会有其它的操作,如发帖,评论等,这时候如何保持会话呢? 一.session简介 1.查看帮助文档,贴了一部分,后面省略了 >>im ...

  • python接口自动化4-绕过验证码登录(cookie)

    前言 有些登录的接口会有验证码:短信验证码,图形验证码等,这种登录的话验证码参数可以从后台获取的(或者查数据库最直接). 获取不到也没关系,可以通过添加cookie的方式绕过验证码. 一.抓登录coo ...

  • python接口自动化5-Json数据处理

    前言 有些post的请求参数是json格式的,这个前面第二篇post请求里面提到过,需要导入json模块处理. 一般常见的接口返回数据也是json格式的,我们在做判断时候,往往只需要提取其中几个关键的 ...

  • python接口自动化6-重定向(Location)

    前言 某屌丝男A鼓起勇气向女神B打电话表白,女神B是个心机婊觉得屌丝男A是好人,不想直接拒绝于是设置呼叫转移给闺蜜C了,最终屌丝男A和女神闺蜜C表白成功了,这种场景其实就是重定向了. 一.重定向 1. ...

  • python接口自动化7-参数关联

    前言 我们用自动化发帖之后,要想接着对这篇帖子操作,那就需要用参数关联了,发帖之后会有一个帖子的id,获取到这个id,继续操作传这个帖子id就可以了 一.删除草稿箱 1.我们前面讲过登录后保存草稿箱, ...