全栈自动化测试之python接口自动化ConfigParser配置文件的使用

前言

本文主要介绍python模块的导入,包括模块的定义、模块的作用、导入方式以及模块的搜索路径以及python中异常的处理及断言,包括异常类型、异常捕获、主动跑出异常和断言。

全栈自动化测试之python接口自动化ConfigParser配置文件的使用_第1张图片

一、模块的定义

python模块(module),简单来说就是一个python文件,以.py结尾,文件内容包含了python对象定义和python语句。

二、模块的作用

  • 模块可以让你能够有逻辑地组织Python代码段
  • 把相关的功能代码写到到一个模块里能让你的代码更好用,更清晰易懂
  • 模块能定义函数,类和变量,模块里也能包含可执行的代码

三、模块的导入方式

1.直接导入模块或导入模块的某个对象:

  • import *            导入模块
  • import 模块名 as 别名     导入模块并起一个别名
  • from 模块名 import 函数名/变量名/类名    从模块导入一个对象(可以是类、方法、变量)
  • from 模块名import *     把模块的内容全部导入
  • from 模块名import 函数名/变量名/类名 as 别名 从模块导入一个对象并起一个别名

2.从一个python包导入:

  • from 包名 import 模块名
  • from 包名.模块名 import 函数名/变量名/类名
  • from 包名.包名 import 模块名

推荐使用下面几个:(尽量别用*)

import 模块名

from 模块名 import 函数名/变量名/类名

from 包名 import 模块名

另外,这里再提一下python包和普通文件夹的区别:

1、包里面多了一个__init__.py的文件
2、导入包的时候,包里面的__init__.py这个文件会自动执行。

四、模块导入的搜索路径

模块的搜索路径在sys模块下可以查看

import sys
print(sys.path)  # 返回的是一个列表,按照列表的路径一个个搜索导入的模块,
                 # 如果在这些路径找不到该模块就会报错

五、异常类型介绍

什么是异常?异常即是一个事件,该事件会在程序执行过程中发生,会影响程序的正常执行,一般情况下,在python无法正常处理程序时就会发生一个异常。异常是python对象,表示一个错误。当python脚本发生异常时我们需要捕获处理它,否则程序会终止执行。

全栈自动化测试之python接口自动化ConfigParser配置文件的使用_第2张图片

在python 中,所有的异常都是派生自BaseException类的实例,BaseException是所有异常的基类,下面四种是最常见的异常:

  • SystemExit 解释器请求退出
  • KeyboardInterrupt 用户中断执行(通常是输入^C)
  • GeneratorExit 生成器(generator)发生异常来通知退出
  • Exception 常规错误的基类

我们需要重点掌握Exception类,一般因代码引起的错误,是我们可以控制的,其他异常基类我们了解即可,常见的Exception类异常类型举例如下:

  • AttributeError:属性错误,特性引用和赋值失败时会引发属性错误
  • NameError:试图访问的变量名不存在
  • SyntaxError:语法错误,代码形式错误
  • IOError:一般常见于打开不存在文件时会引发IOError错误,也可以解理为输出输入错误
  • KeyError:使用了映射中不存在的关键字(键)时引发的关键字错误
  • IndexError:索引错误,使用的索引不存在,常索引超出序列范围,什么是索引
  • TypeError:类型错误,内建操作或是函数应于在了错误类型的对象时会引发类型错误
  • ZeroDivisonError:除数为0,在用除法操作时,第二个参数为0时引发了该错误
  • ValueError:值错误,传给对象的参数类型不正确,像是给int()函数传入了字符串数据类型的参数。

还有更多的异常类型,有兴趣的可以查阅官网文档或者百度查询。

六、异常捕获

1.try/except语法格式

捕捉异常可以使用try/except语句,如果你不想在异常发生时结束你的程序,只需在try里捕获它,使用except在错误发生后运行处理动作。语法格式如下:(注意:except中指定异常类型,可以指定一个也可以指定多个,也可以不指定,不指定时默认捕获所有Exception类型的异常)

try:

可能出现异常的代码

except 异常类型:

捕获到异常之后的处理方案

全栈自动化测试之python接口自动化ConfigParser配置文件的使用_第3张图片

上述例子中因为b没有被定义,在打印时无法找到b,因此抛出了一个NameError导致后面的代码无法继续执行,那么我们来捕获一下这个错误

try:
    # try有可能发生异常的代码
    a = '这是一个测试异常的文本'
    print(b)

except (NameError, FileNotFoundError):  # 当捕获到异常时处理的方案,可以有多个except,不指定异常类型,会捕获所有异常
    print("这里有一个异常!")

# except NameError:  指定捕捉异常NameError,其他的异常不会捕获

# except Exception as msg:    # 不确定什么异常异常,用exception,或者直接不指定
#     print(msg)

print(a)

运行结果:

C:\software\python\python.exe D:/learn/python18_http_request/exercise/test.py
这里有一个异常!
这是一个测试异常的文本

Process finished with exit code 0

2.异常处理中的else和finally

在try/except语句中可以使用else和finally,try语句里的代码没有异常才会执行else里的语句,而finally语句是不管try里有没有异常它都会执行

try:
    # try下面写有可能会出现异常的代码
    score = int(input("请输入成绩:"))
    # 因为input获取的都是字符串,int()是强制转换成int类型,英文字符等是无法转换成int类型的字都会报错
except Exception:
    # 处理异常之后的处理,
    print("用输入的数据不符合规范,默认给0分")
    score = 0
else:
    # 代码没有出现异常,执行else中的代码
    print("代码没有出现异常,执行else")
finally:
    # 不管代码有没有出现异常都会去执行的代码
    print("finally不管代码有没有出现异常都会去执行的代码")
    print("分数录入为:{}".format(score))

运行结果:

C:\software\python\python.exe D:/learn/python18_http_request/exercise/test.py
请输入成绩:nine
用输入的数据不符合规范,默认给0分
finally不管代码有没有出现异常都会去执行的代码
分数录入为:0

Process finished with exit code 0

七、主动抛出异常

异常捕获后为什么还要主动去抛出一个异常呢?这是为了方便我们知道出现异常的具体情况,我们还可以自定义异常

语法格式:raise 异常类型(异常信息)

try:
    # try 有可能发生异常的代码
    a = 1111
    print(b)
except NameError as msg:
    print(msg)
    raise msg  # 捕获后运行不会报错,再抛出就会看到异常
else:  # try里面的代码都是正常执行,没有发生任何异常,就会执行这里
    print("程序运行正常!")
finally:
    print("不管有没有异常,我都会被执行!")

运行结果:

C:\software\python\python.exe D:/learn/python18_http_request/exercise/test.py
name 'b' is not defined
不管有没有异常,我都会被执行!
Traceback (most recent call last):
  File "D:/learn/python18_http_request/exercise/test.py", line 15, in 
    raise msg  # 捕获后运行不会报错,再抛出就会看到异常
  File "D:/learn/python18_http_request/exercise/test.py", line 12, in 
    print(b)
NameError: name 'b' is not defined

Process finished with exit code 1

在自动化测试中,我们只需要掌握如何捕获异常如何抛出异常即可,自定义异常这里就不多作解释,有兴趣的可以自定百度。

四、断言assert

什么是断言?其实assert断言就是用于判断一个表达式,在表达式条件为 false 的时候触发断言异常,断言可以在条件不满足程序运行的情况下直接返回错误,而不必等待程序运行后出现崩溃的情况,例如我们的代码只能在a>8时运行,可以先判断当前是否符合条件。语法格式如下:

assert 表达式,提示信息  (也可以没有提示信息)

# assert:断言
res1 = {'code': 1, 'msg': '登陆成功'}
res2 = {'code': 0, 'msg': '登陆失败'}

# 加一个断言,判断结果是否如预期,如果与预期不一致,会报出断言异常并打印提示信息
assert res1 == res2, '该用例不通过!'

运行结果:

C:\software\python\python.exe D:/learn/python18_http_request/exercise/test.py
Traceback (most recent call last):
  File "D:/learn/python18_http_request/exercise/test.py", line 15, in 
    assert res1 == res2, '该用例不通过!'  # 加一个断言,判断结果是否如预期,如果与预期不一致,会报出断言异常并打印提示信息
AssertionError: 该用例不通过!

Process finished with exit code 1

我们也可以用try/except来捕获这个断言异常:

# assert:断言
res1 = {'code': 1, 'msg': '登陆成功'}
res2 = {'code': 0, 'msg': '登陆失败'}

# 用try--except捕获断言异常
try:
    assert res1 == res2
except AssertionError as e:
    print("编号A1用例不通过!")
    raise e  # 处理异常后,抛出异常
else:
    print("编号A1用例通过!")

运行结果:

C:\software\python\python.exe D:/learn/python18_http_request/exercise/test.py
编号A1用例不通过!
Traceback (most recent call last):
  File "D:/learn/python18_http_request/exercise/test.py", line 18, in 
    raise e  # 处理异常后,抛出异常
  File "D:/learn/python18_http_request/exercise/test.py", line 15, in 
    assert res1 == res2
AssertionError

Process finished with exit code 1

 

最后: 为了回馈铁杆粉丝们,我给大家整理了完整的软件测试视频学习教程,朋友们如果需要可以自行免费领取 【保证100%免费】

在这里插入图片描述

全套资料获取方式:点击下方小卡片自行领取即可

你可能感兴趣的:(软件测试,程序员,自动化测试,python,测试工程师)