在做接口测试中,可谓是踩坑不断,如果遇到一类问题,如B接口的请求参数需要A接口的返回值这种情况也是时常发生。
如果不知道global()这个函数时,我们可以这样做,如下:
import unittest
data = {}
class Test(unittest.TestCase):
def test_a(self):
global data
## 假设这个是这个接口的返回值
return_value = {'code':1}
print(f'这个接口返回为{return_value}')
data = return_value
def test_b(self):
## 假设这个接口要用这个data
print(f'这里是需要用到的test_a的返回值的函数:%s'%data)
def test_c(self):
## 假设这个接口也要用这个data
print(f'这里是需要用到的test_a的返回值的函数:%s'%data)
if __name__ == '__main__':
unittest.main()
结果如下:
由上可见,如果一个接口要用另一个接口的返回值,可以定义一个全局的变量,使用global来配合使用,这个只是其中的一个方式。不过这样比较难管理,而且还易受执行顺序,变量影响等因素影响。下面推荐unittest中的globals()这个方法
1、简单的一个使用例子
import unittest
class Test(unittest.TestCase):
def test_a(self):
## 假设这个是这个接口的返回值
return_value = {'code':1}
print(f'这个接口返回为{return_value}')
## 这里使用globals()
globals()['a'] = return_value
def test_b(self):
## 假设这个接口要用这个data
print(f'这里是需要用到的test_a的返回值的函数:%s'%globals()['a'])
def test_c(self):
## 假设这个接口也要用这个data
print(f'这里是需要用到的test_a的返回值的函数:%s'%globals()['a'])
if __name__ == '__main__':
unittest.main()
结果如下:
由上可见,globals()的一个简单的用法。很方便的管理了这种问题
2、那么问题又来了,如果我需要用A接口的返回值作为B接口的参数,而B接口的返回值要作为C接口的参数,这样子可不可以用globals()实现呢。
当c的请求参数依赖a和b时,使用太多的globals()会不太好关联,可以把globals()函数放到setUp前置里面,如下:
复制代码
import unittest
class Test(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.g = globals()
def test_a(self):
## 假设这个是这个接口的返回值
return_valueA = {'code':1}
print(f'这个接口返回为{return_valueA}')
## 这里使用globals()
## A接口的返回值
self.g['a'] = return_valueA
def test_b(self):
## 假设这个接口要用这个data
## B接口需要用到A接口的返回值
print(f'这里是需要用到的test_b的返回值的函数:%s'%self.g['a'])
## 假设他是b接口的返回值
return_valueB = {'messge':"ok"}
## 直接用globals()赋值就ok了
self.g['b'] = return_valueB
def test_c(self):
## 假设这个是C接口,需要用到B接口的返回值
print(f'这里是需要用到的test_b的返回值的函数:%s'%self.g['b'])
if name == ‘main’:
unittest.main()
复制代码
结果如下:
由上可见,这个使用globals()很简单的就解决了。
那么又有问题来了,如果我先执行的B接口,又执行了AC接口,这个不就乱套了吗?答案是确实会乱套,可以先查一下unittest的用例执行顺序,这里不做多解释了