python unittest TestCase间共享数据(全局变量的使用)
文章目录
1.setupclass里设置self.xxx变量,不同用例之间无法实时共享参数变动
2.setupclass里设置globals().["xxx"]变量,不同用例之间可以实时共享参数变动
3.setupclass里设置 ClassName.XXX变量,不同用例之间可以实时共享参数变动
4.setupclass之前设置 XXX变量
1.setupclass里设置self.xxx变量,不同用例之间无法实时共享参数变动
from settings import *
import requests,json
import unittest class Login(unittest.TestCase): @classmethod
def setUpClass(self):
api_token = '/v1/api/common/getToken'
self.real_token_url = API_TEST_BASE_URL + api_token
self.token = None def test_get_token(self):
r = requests.post(url=self.real_token_url)
self.token = json.loads(r.text)['model']['token']
print("第一个case获得的token:",self.token)
return self.token def test_get_u(self):
print("第二个case获得token值:",self.token) if __name__ == '__main__':
unittest.main()
执行结果:
第一个case获得的token: 48579630472b45a0b0b553bc85a335f8
第二个case获得token值: None
- 说明在unttest框架中,testcase中间不共享变量的值,但是都可以从setupclass里面读取统一的变量值
- 可以setup时候设置全局变量,不同的case之间就可以共享这个变量了
2.setupclass里设置globals().[“xxx”]变量,不同用例之间可以实时共享参数变动
from settings import *
import requests,json
import unittest class Login(unittest.TestCase): @classmethod
def setUpClass(self):
api_token = '/v1/api/common/getToken'
self.real_token_url = API_TEST_BASE_URL + api_token
globals()["token"] = None def test_get_token(self):
r = requests.post(url=self.real_token_url)
globals()["token"] = json.loads(r.text)['model']['token']
print("第一个case获得的token:",globals()["token"])
return globals()["token"] def test_get_u(self):
print("第二个case获得token值:",globals()["token"]) if __name__ == '__main__':
unittest.main()
执行结果:
第一个case获得的token: 44c5fcccca6c4e64a1c5d314b7ee22fc
第二个case获得token值: 44c5fcccca6c4e64a1c5d314b7ee22fc
3.setupclass里设置 ClassName.XXX变量,不同用例之间可以实时共享参数变动
import unittest
class Mydemo(unittest.TestCase):
@classmethod
def setUpClass(cls):
Mydemo.a = ""
def test1(self):
print("test1-----{}".format(Mydemo.a))
Mydemo.a = ""
def test2(self):
print("test2-----{}".format(self.a))
print("test2_2---{}".format(Mydemo.a))
if __name__ == '__main__':
unittest.main()
执行结果:
test1-----88
test2-----99
test2_2---99
我们运行test1的时候,给Mydemo.a可以获取全局变量的a,打印完之后又设置了新的值
test2运行的时候,通过2中方式,都能获取到了全局变量的值。
4.setupclass之前设置 XXX变量
class AlienTest(unittest.TestCase):
status = 200 @classmethod
def setUpClass(cls):
cls.url = "http://www.baidu.com"
globals()['status'] = 300 def test_1_alien(self):
print("test_1_status:", self.status) def test_2_alien(self):
self.status = 404
print("test_2_status", self.status) def test_4_alien(self):
print("test_4_global_status", globals()['status'])
print("test_4_status", self.status) if __name__ == '__main__':
unittest.main()
test_1_status: 200
test_2_status 404
test_4_global_status 300
test_4_status 200
我自己在写接口自动化中遇到这样的问题,testcase中有一个变量的值是我想要的,这个值是shopid(我这个接口是新增店铺,新增成功之后会返回一个shopid)
,那么在
tearDownClass里面我就想要去删除他,所有需要获取到testcase中的shopid

db = config.db
class Login(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.db = config.db
cls.cursor = db.cursor(cursor = cursors.DictCursor)
print("连接数据库成功!\n") @classmethod
def tearDownClass(cls):
print("cls.shop_id:"+str(Login.shop_id))
deleteRecord(cls.db,cls.cursor,"t_shop_info","id",int(Login.shop_id))
cls.cursor.close()
cls.db.close()
print("关闭数据库成功!\n") @parameterized.expand(ReadParameterized(path,"shop",api_name+".json").read_params())
def test_shop_login(self,case_number):
try:
param = PostParameter().post_param(path,"shop",api_name+".json",case_number) r = Api_AddShop().add_shop(param["url"],param["headers"],param["common_param"],param["data"],param["expect_results"]) self.assertEqual(param["expect_results"]["code"],r["code"])
self.assertEqual(param["expect_results"]["msg"], r["msg"])
# 定义全局变量 shop_id
Login.shop_id = str(r["data"]["shop_id"])
except Exception as e:
print("this except is "+str(e))
# raise e if __name__ == '__main__':
unittest.main()
引用文章来源:
https://blog.csdn.net/happyteafriends/article/details/22728749
https://www.cnblogs.com/hhudaqiang/p/6596043.html
文章转自:https://blog.csdn.net/chenmozhe22/article/details/81302780?utm_source=blogxgwz6
python unittest TestCase间共享数据(全局变量的使用)的更多相关文章
- python 进程间共享数据 (二)
Python中进程间共享数据,除了基本的queue,pipe和value+array外,还提供了更高层次的封装.使用multiprocessing.Manager可以简单地使用这些高级接口. Mana ...
- Python multiprocessing.Manager介绍和实例(进程间共享数据)
Python中进程间共享数据,处理基本的queue,pipe和value+array外,还提供了更高层次的封装.使用multiprocessing.Manager可以简单地使用这些高级接口. Mana ...
- python 进程间共享数据 (一)
def worker(num, mystr, arr): num.value *= 2 mystr.value = "ok" for i in range(len(arr)): a ...
- 详解 Qt 线程间共享数据(用信号槽方式)
使用共享内存.即使用一个两个线程都能够共享的变量(如全局变量),这样两个线程都能够访问和修改该变量,从而达到共享数据的目的. Qt 线程间共享数据是本文介绍的内容,多的不说,先来啃内容.Qt线程间共享 ...
- Qt学习:线程间共享数据(使用信号槽传递数据,必须提前使用qRegisterMetaType来注册参数的类型)
Qt线程间共享数据主要有两种方式: 使用共享内存.即使用一个两个线程都能够共享的变量(如全局变量),这样两个线程都能够访问和修改该变量,从而达到共享数据的目的: 使用singal/slot机制,把数据 ...
- 进程间共享数据Manager
一.前言 进程间的通信Queue()和Pipe(),可以实现进程间的数据传递.但是要使python进程间共享数据,我们就要使用multiprocessing.Manager. Manager()返回的 ...
- 【C++】DLL内共享数据区在进程间共享数据(重要)
因项目需要,需要在DLL中共享数据,即DLL中某一变量只执行一次,在运行DLL中其他函数时该变量值不改变:刚开始想法理解错误,搜到了DLL进程间共享数据段,后面发现直接在DLL中定义全局变量就行,当时 ...
- windows核心编程之进程间共享数据
有时候我们会遇到window进程间共享数据的需求,例如说我想知道系统当前有多少某个进程的实例. 我们能够在程序中定义一个全局变量.初始化为0.每当程序启动后就加1.当然我们我们能够借助第三方介质来储存 ...
- 详解 Qt 线程间共享数据(使用signal/slot传递数据,线程间传递信号会立刻返回,但也可通过connect改变)
使用共享内存.即使用一个两个线程都能够共享的变量(如全局变量),这样两个线程都能够访问和修改该变量,从而达到共享数据的目的. Qt 线程间共享数据是本文介绍的内容,多的不说,先来啃内容.Qt线程间共享 ...
随机推荐
- 2018版移动端ui规范
计规范是一种将移动端常用控件标准化.统一化的的文档 今天整理了一篇设计规范的文章概论,讲诉中会以ios做介绍,安卓由于开源,平台相对教多不做单一阐述,实际操作的时候,我们不管是做一代还是二次的迭代产品 ...
- 国外程序员整理的 PHP 资源大全
原文:http://blog.jobbole.com/82908/ ziadoz 在 Github 发起维护的一个 PHP 资源列表,内容包括:库.框架.模板.安全.代码分析.日志.第三方库.配置工具 ...
- 干货福利:如何使用Python中Django模板?
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者: 穆胜亮 篇文章将学习如何使用Django模板.模板是在Django ...
- python学习21之高级特性
'''''''''1.切片(1)谁可以进行切片操作?——列表,元组,字符串(2)切片有以下几种操作'''#[a:b]:取从下标为a的元素开始,到下标为b-1的元素结束L=['aa','bb','cc' ...
- HTTP 1.1, 返回值100.
HTTP 1.1支持只发送header信息(不带任何body信息),如果服务器认为客户端有权限请求服务器,则返回100,否则返回401.客户端如果接受到100,才开始把请求body发送到服务器. 这样 ...
- java并发Exchanger的使用
目录 简介 类定义 类继承 构造函数 两个主要方法 具体的例子 结语 简介 Exchanger是java 5引入的并发类,Exchanger顾名思义就是用来做交换的.这里主要是两个线程之间交换持有的对 ...
- 【Linux题目】第七关
1. 如果想修改开机内核参数,应该修改哪个文件? A. /dev/sda1 B. /etc/fstab 磁盘自动挂载的文件 C. /boot/grub/grub.conf D. /etc/rc.loc ...
- Eclipse Mac OS 安装 最新版 Subversion插件subclipse
subclipse 目前全部转移到github 官方地址 https://github.com/subclipse/subclipse/wiki Eclipse mac版 安装 最新版svn插件sub ...
- Uber是一部无所不在的数字出行物联网
"Uber化"是整合服务产业与智能车联网的知识经济,是数字时代展现个人化生活态度无可逆转的趋势,是新兴数字族群运用数字工具集体分享出行资源的平台. 搭过Uber的消费者,对其服务质 ...
- Kudu,支持快速分析的新型Hadoop存储系统
Kudu是Cloudera开源的新型列式存储系统,是Apache Hadoop生态圈的新成员之一(incubating),专门为了对快速变化的数据进行快速的分析,填补了以往Hadoop存储层的空缺.本 ...