python判断非法输入_python nose测试框架全面介绍八---接口测试中非法参数的断言...

在测接口时,会有这样的场景,输入非法的参数,校验返回的错误码及错误内容

通常做法为发请求,将错误的返回结果拿出,再进行对比匹配;但存在一个问题,需要再写错误返回分析函数,不能与之前正常发请求的函数共用。

这时,我们可以用上assertRaises、assertRaisesRegexp;python 2.7中unittest中叫assertRaises,nose.tools中叫assert_raises、assert_raises_regexp

一、unittest中的assertRaises

看看官方说明吧:

29bd1401697ad3677d4da02b70f76381.png

可以对异常和告警使用上面两个方法进行断言。

看个例子吧:

importunittestdefmode(dividend,divisor):

remainder= dividend %divisor

quotient= (dividend - remainder) /dividendreturnquotient,remainderclassRaiseTest():deftest_raise(self):

self.assertRaise(ZeroDivisionError, mode,7,0)deftest_raise_regexp(self):

self.assertRaiseRegexp(ZeroDivisionError, r'.*?Zero', mode,7,0)if __name__ == '__main__':

unittest.main()

注意:里面的引用函数是不带()的,直接是mode

异常名的也是不带引号的,如果使用自定义的异常是要先引入的

二、nose中的assertRaises

还是上面那断代码,改用nose方式

#coding:utf-8

'''Created on 2018年1月4日

@author: hu'''

from nose.tools importassert_raises,assert_raises_regexpdefmode(dividend,divisor):

remainder= dividend %divisor

quotient= (dividend - remainder) /dividendreturnquotient,remainderclassRaiseTest():deftest_raise(self):

assert_raises(ZeroDivisionError, mode,7,0)deftest_raise_regexp(self):

assert_raises_regexp(ZeroDivisionError, r'.*?Zero', mode,7,0)

执行结果也是一致的

三:接口测试中常见的用法

根据上面的断言特证,我们在接口测试中底层的请求封装中可以直接类似这样写:

defshow_xxxxx(self, id):"""查看xxxx,id为参数"""url= "xxxx/%s" %str(volume_id)

resp, body=self.get(url)

body=json.loads(body)

self.expected_success(200, resp.status)return body

其中expected_success是自己的封装,里面封装了抛错,这里就不举例了

然后在实际测异常参数时,就可以这么写

deftest_get_invalid_xxxxx_id(self):#Negative: Should not be able to get xxxxx with invalid id

self.assertRaises(你自己定义的错误类型,

self.show_xxxxxx,'#$%%&^&^')

或者用assertRaiseRegexp判断错误内容

这样一来,可以少写很多代码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
pytest是一个Python测试框架,它是基于`unittest`和`nose`这两个Python测试框架的经验基础上发展而来的。相比于其他测试框架,pytest具有更简洁、更灵活的语法,让编写和管理测试用例更加方便。 在使用pytest之前,我们需要将其导入到我们的Python项目。可以通过`pip`命令来安装pytest包,具体命令为`pip install pytest`。安装完成后,我们可以在Python代码通过`import pytest`语句来引入pytest模块。 导入pytest后,我们就可以使用pytest提供的丰富的装饰器和断言函数来编写测试用例。pytest支持使用`@pytest.fixture`装饰器定义测试用例前后需要执行的操作,比如创建数据库连接等。使用`@pytest.mark.parametrize`装饰器可以方便地对测试用例进行参数化,减少重复性的代码。 pytest还提供了丰富的断言函数,用于验证测试结果是否符合预期。常用的断言函数有`assert`、`assertEqual`、`assertTrue`等。使用这些断言函数可以方便地检查测试用例的执行结果,并在测试失败时输出详细的错误信息,帮助我们快速定位问题。 除了基本的测试用例编写和断言功能外,pytest还提供了插件机制,可以通过插件扩展pytest的功能。例如,`pytest-html`插件可以生成HTML格式的测试报告,`pytest-xdist`插件可以实现用例的并行执行,提高测试效率。 总结来说,pytest是一个功能强大、灵活且易于使用的Python测试框架。通过导入pytest模块,并利用它提供的装饰器和断言函数,我们可以高效地编写和管理测试用例。同时,借助插件机制,我们可以扩展pytest的功能,满足更多的测试需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值