Commit 35b3317e6a1daa63bb3995a9a6a497717c12bd08

Authored by liujiqiang
1 parent fa3e2fbe

mysession更新

Showing 53 changed files with 119 additions and 3078 deletions
commons/MySession.py
... ... @@ -8,67 +8,95 @@ log=Logger()
8 8  
9 9 class mysession():
10 10 "封装了requests的基类,以供后期统一使用"
11   -
12   - url="http://test.uap.diligrp.com/login/login.action"
13   - header={
14   - "Host": "test.uap.diligrp.com",
15   - "Connection": "keep-alive",
16   - "Content-Length": "33",
17   - "Cache-Control": "max-age=0",
18   - "Upgrade-Insecure-Requests": "1",
19   - "Origin": "http://test.uap.diligrp.com",
20   - "Content-Type": "application/x-www-form-urlencoded",
21   - "User-Agent": "Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.212Safari/537.36",
22   - "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
23   - "Referer": "http://test.uap.diligrp.com/login/index.html",
24   - "Accept-Encoding": "gzip,deflate",
25   - "Accept-Language": "zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7",
26   - "Cookie": "UAP_accessToken=;UAP_refreshToken=;UAP_loginPath="}
27   - body="userName=sg_wenze&password=111111"
28   -
  11 +
  12 + url = "http://test.uap.diligrp.com/login/login.action"
  13 + header = {
  14 + "Host": "test.uap.diligrp.com",
  15 + "Connection": "keep-alive",
  16 + "Content-Length": "33",
  17 + "Cache-Control": "max-age=0",
  18 + "Upgrade-Insecure-Requests": "1",
  19 + "Origin": "http://test.uap.diligrp.com",
  20 + "Content-Type": "application/x-www-form-urlencoded",
  21 + "User-Agent": "Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.212Safari/537.36",
  22 + "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
  23 + "Referer": "http://test.uap.diligrp.com/login/index.html",
  24 + "Accept-Encoding": "gzip,deflate",
  25 + "Accept-Language": "zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7",
  26 + "Cookie": "UAP_accessToken=;UAP_refreshToken=;UAP_loginPath="}
  27 + body = "userName=sg_wenze&password=111111"
  28 +
29 29 def __init__(self):
30 30 "如下代码,可以通过配置文件来控制测试环境和灰度环境,http和https"
31   - self.url=mysession.url.replace("http://test.",com.get_global_config("global_data", "environment", "en") )
32   - self.header=mysession.header
33   - self.body=mysession.body
34   - self.timeout = (5,5)
  31 + self.url = mysession.url.replace("http://test.", com.get_global_config("global_data", "environment", "en"))
  32 + self.header = mysession.header
  33 + self.body = mysession.body
  34 + self.timeout = (5, 5)
35 35 self.max_retries = 3
36 36 self.keep_alive = False
37   - self.ssl_verify=False
38   - self.proxies=None
39   - self.allow_redirects=False
40   -# self.proxies={'http': 'http://localhost:8888', 'https': 'http://localhost:8888'}
  37 + self.ssl_verify = False
  38 + self.proxies = None
  39 + self.allow_redirects = False
41 40  
42   - def get_session(self,account,**kwargs):
  41 + # self.proxies={'http': 'http://localhost:8888', 'https': 'http://localhost:8888'}
  42 + def cliLogin(self):
  43 + self.webHeaders, self.clientHeaders, self.userInfo = cliSession().loginUser()
  44 +
  45 + def get_session(self, account, **kwargs):
  46 + print("get_session")
43 47 "如下代码,可以通过配置文件来控制登录的账户session"
44   - self.body=self.body.replace("sg_wenze", com.get_global_config("global_data", "account", account).split("&")[0])
45   - self.body=self.body.replace("111111", com.get_global_config("global_data", "account", account).split("&")[1])
46   - #requests.session()会话保持,比如使用session成功的登录了某个网站,
47   - #则在再次使用该session对象求求该网站的其他网页都会默认使用该session之前使用的cookie等参数
48   - self.se=requests.session()
49   - #使用session对象的方法POST/GET等
50   - re=self.se.post(url=self.url, headers=self.header,data=self.body,proxies=self.proxies,**kwargs)
51   - #返回session对象,供其他接口使用
52   - return self.se
  48 + self.body = self.body.replace("sg_wenze",
  49 + com.get_global_config("global_data", "account", account).split("&")[0])
  50 + self.body = self.body.replace("111111", com.get_global_config("global_data", "account", account).split("&")[1])
  51 + # requests.session()会话保持,比如使用session成功的登录了某个网站,
  52 + # 则在再次使用该session对象求求该网站的其他网页都会默认使用该session之前使用的cookie等参数
  53 + self.se = requests.session()
  54 + # 使用session对象的方法POST/GET等
  55 + re = self.se.post(url=self.url, headers=self.header, data=self.body, proxies=self.proxies, **kwargs)
  56 + # 返回session对象,供其他接口使用
  57 + print(self.se.cookies)
  58 + return self.se
53 59  
54 60 def close_session(self):
55 61 "关闭session"
56 62 self.se.close()
57 63  
58   -
59   - def check_login(self,account,**kwargs):
  64 + def check_login(self, account, **kwargs):
60 65 "验证登录接口"
61   - self.body=self.body.replace("sg_wenze", com.get_global_config("global_data", "account", account).split("&")[0])
62   - self.body=self.body.replace("111111", com.get_global_config("global_data", "account", account).split("&")[1])
63   - #POST请求,
64   - re=self.se.post(url=self.url, headers=self.header,data=self.body,proxies=self.proxies,allow_redirects=False,**kwargs)
65   - #判断请求
  66 + self.body = self.body.replace("sg_wenze",
  67 + com.get_global_config("global_data", "account", account).split("&")[0])
  68 + self.body = self.body.replace("111111", com.get_global_config("global_data", "account", account).split("&")[1])
  69 + # POST请求,
  70 + re = self.se.post(url=self.url, headers=self.header, data=self.body, proxies=self.proxies,
  71 + allow_redirects=False, **kwargs)
  72 + # 判断请求
66 73 assert "UAP_accessToken" in re.headers["Set-Cookie"]
67 74 assert "UAP_refreshToken" in re.headers["Set-Cookie"]
68 75 assert "UAP_loginPath" in re.headers["Set-Cookie"]
69 76 print("登录接口验证成功")
70 77 return re
71 78  
  79 + def useHeadersRequests(self, method=None, url=None, headers=None, data=None, **kwargs):
  80 + """
  81 + 模拟客户端接口操作,使用headers进行cookies传递,调用requests库进行接口访问
  82 + :param method:接口请求方式,POST,GET等
  83 + :param url:接口路径
  84 + :param data:接口数据
  85 + :kwargs:其他requests.request()支持参数可以直接传递
  86 + """
  87 + print(url)
  88 + # print(headers)
  89 + print(data)
  90 + log.info("{0:=^86}".format(''))
  91 + log.info("{}\n{}\n{}\n".format(url, data, kwargs))
  92 + if "gateway" in url:
  93 + # 判断接口路径,通过接口路径钟是否包含gateway来判定接口是否是由客户端进行访问,来判定headers使用
  94 + self.clientHeaders = dict(self.clientHeaders, **headers)
  95 + res = requests.request(method=method, url=url, data=data, headers=self.clientHeaders, **kwargs)
  96 + else:
  97 + self.webHeaders = dict(self.webHeaders, **headers)
  98 + res = requests.request(method=method, url=url, data=data, headers=self.webHeaders, **kwargs)
  99 + return res
72 100  
73 101 def get(self, url, **kwargs):
74 102 """Sends a GET request. Returns :class:`Response` object.
... ... @@ -77,13 +105,13 @@ class mysession():
77 105 :param \*\*kwargs: Optional arguments that ``request`` takes.
78 106 :rtype: requests.Response
79 107 """
80   - #记录日志
  108 + # 记录日志
81 109 log.info("{0:=^86}".format(''))
82   - log.info("{}\n{}\n".format(url,kwargs))
83   - #进行请求
84   - re=self.se.get(url,**kwargs,proxies=self.proxies,timeout=self.timeout)
  110 + log.info("{}\n{}\n".format(url, kwargs))
  111 + # 进行请求
  112 + re = self.se.get(url, **kwargs, proxies=self.proxies, timeout=self.timeout)
85 113 return re
86   -
  114 +
87 115 def post(self, url, data=None, json=None, **kwargs):
88 116 """Sends a POST request. Returns :class:`Response` object.
89 117 :param url: URL for the new :class:`Request` object.
... ... @@ -93,11 +121,11 @@ class mysession():
93 121 :param \*\*kwargs: Optional arguments that ``request`` takes.
94 122 :rtype: requests.Response
95 123 """
96   - #记录日志
  124 + # 记录日志
97 125 log.info("{0:=^86}".format(''))
98   - log.info("{}\n{}\n{}\n{}".format(url,data,json,kwargs))
99   - #进行请求
100   - re=self.se.post(url, data=data, json=json,proxies=self.proxies, **kwargs,timeout=self.timeout)
  126 + log.info("{}\n{}\n{}\n{}".format(url, data, json, kwargs))
  127 + # 进行请求
  128 + re = self.se.post(url, data=data, json=json, proxies=self.proxies, **kwargs, timeout=self.timeout)
101 129 return re
102 130  
103 131 def options(self, url, **kwargs):
... ... @@ -106,10 +134,10 @@ class mysession():
106 134 :param \*\*kwargs: Optional arguments that ``request`` takes.
107 135 :rtype: requests.Response
108 136 """
109   - #记录日志
110   - log.info(url,kwargs)
111   - #进行请求
112   - re=self.se.options(url,**kwargs)
  137 + # 记录日志
  138 + log.info(url, kwargs)
  139 + # 进行请求
  140 + re = self.se.options(url, **kwargs)
113 141 return re
114 142  
115 143 def head(self, url, **kwargs):
... ... @@ -119,12 +147,12 @@ class mysession():
119 147 :param \*\*kwargs: Optional arguments that ``request`` takes.
120 148 :rtype: requests.Response
121 149 """
122   - #记录日志
123   - log.info(url,kwargs)
124   - #进行请求
125   - re=self.se.head(url,**kwargs)
  150 + # 记录日志
  151 + log.info(url, kwargs)
  152 + # 进行请求
  153 + re = self.se.head(url, **kwargs)
126 154 return re
127   -
  155 +
128 156 def put(self, url, data=None, **kwargs):
129 157 """Sends a PUT request. Returns :class:`Response` object.
130 158 :param url: URL for the new :class:`Request` object.
... ... @@ -133,54 +161,54 @@ class mysession():
133 161 :param \*\*kwargs: Optional arguments that ``request`` takes.
134 162 :rtype: requests.Response
135 163 """
136   - #记录日志
137   - log.info(url,data,kwargs)
138   - #进行请求
139   - re=self.se.put(url, data,**kwargs)
  164 + # 记录日志
  165 + log.info(url, data, kwargs)
  166 + # 进行请求
  167 + re = self.se.put(url, data, **kwargs)
140 168 return re
141   -
  169 +
142 170 def delete(self, url, **kwargs):
143 171 """Sends a DELETE request. Returns :class:`Response` object.
144 172 :param url: URL for the new :class:`Request` object.
145 173 :param \*\*kwargs: Optional arguments that ``request`` takes.
146 174 :rtype: requests.Response
147 175 """
148   - #记录日志
149   - log.info(url,kwargs)
150   - #进行请求
151   - re=self.se.delete(url,**kwargs)
  176 + # 记录日志
  177 + log.info(url, kwargs)
  178 + # 进行请求
  179 + re = self.se.delete(url, **kwargs)
152 180 return re
153   -
  181 +
154 182 def set_mark(self):
155 183 "用户自定义优先级方法"
156   - mark_list=eval(com.get_global_config("global_data","mark","list"))
157   - print("预设运行标记:",mark_list)
  184 + mark_list = eval(com.get_global_config("global_data", "mark", "list"))
  185 + print("预设运行标记:", mark_list)
158 186 global _global_mark
159   - if type(mark_list)==type([]) and len(mark_list)!=0 :
160   - _global_mark=mark_list
  187 + if type(mark_list) == type([]) and len(mark_list) != 0:
  188 + _global_mark = mark_list
161 189 return _global_mark
162   - elif type(mark_list)==type([]) and len(mark_list)==0:
163   - _global_mark=False
  190 + elif type(mark_list) == type([]) and len(mark_list) == 0:
  191 + _global_mark = False
164 192 return _global_mark
165 193 else:
166 194 raise Exception("error,pls check mark data")
167 195  
168   - def mark(self,m=None):
  196 + def mark(self, m=None):
169 197 try:
170   - #没有输入任何预设值,默认跑全部
171   - if _global_mark == False :
  198 + # 没有输入任何预设值,默认跑全部
  199 + if _global_mark == False:
172 200 return True
173   - #输入预设值且未标记用例,默认跑全部
  201 + # 输入预设值且未标记用例,默认跑全部
174 202 elif _global_mark != False and (m in _global_mark):
175   - return True
  203 + return True
176 204 else:
177 205 return False
178 206 except Exception as e:
179 207 return False
180 208  
181 209  
182   -
183   -my=mysession()
  210 +my = mysession()
184 211 my.set_mark()
185   -s1=my.get_session("user01")
  212 +s1 = my.get_session("user01")
186 213 # s2=my.get_session("user02")
  214 +my.cliLogin()
... ...
report/test.log
1   -[2021-07-19 17:33:21] [INFO] : ======================================================================================
2   -[2021-07-19 17:33:21] [INFO] : http://test.trace.diligrp.com:8393/fieldConfig/doUpdate.action
  1 +[2021-07-19 17:40:17] [INFO] : ======================================================================================
  2 +[2021-07-19 17:40:17] [INFO] : http://test.trace.diligrp.com:8393/fieldConfig/doUpdate.action
3 3 None
4 4 {'moduleType': '1', 'marketId': '8', 'fieldConfigDetailList': [{'fieldName': 'unitPrice', 'jsonPath': '$.unitPrice', 'defaultId': '3', 'displayed': '1', 'required': '0'}, {'fieldName': 'arrivalTallynos', 'jsonPath': '$.arrivalTallynos', 'defaultId': '10', 'displayed': '1', 'required': '0'}, {'fieldName': 'brandName', 'jsonPath': '$.brandName', 'defaultId': '5', 'displayed': '1', 'required': '0'}, {'fieldName': 'truckTareWeight', 'jsonPath': '$.truckTareWeight', 'defaultId': '1', 'displayed': '1', 'required': '0'}, {'fieldName': 'originId', 'jsonPath': '$.originId', 'defaultId': '7', 'displayed': '1', 'required': '0'}, {'fieldName': 'specName', 'jsonPath': '$.specName', 'defaultId': '4', 'displayed': '1', 'required': '0'}, {'fieldName': 'truckType', 'jsonPath': '$.truckType', 'defaultId': '2', 'displayed': '1', 'required': '1', 'availableValueList': ['10', '20']}, {'fieldName': 'imageCertList', 'jsonPath': '$.imageCertList[*]certType', 'defaultId': '11', 'displayed': '1', 'required': '0', 'availableValueList': ['2', '3']}, {'fieldName': 'arrivalDatetime', 'jsonPath': '$.arrivalDatetime', 'defaultId': '9', 'displayed': '1', 'required': '0'}, {'fieldName': 'remark', 'jsonPath': '$.remark', 'defaultId': '8', 'displayed': '1', 'required': '0'}, {'fieldName': 'remark', 'jsonPath': '$.remark', 'defaultId': '6', 'displayed': '1', 'required': '0'}, {'fieldName': 'measureType', 'jsonPath': '$.measureType', 'defaultId': '12', 'displayed': '1', 'required': '1', 'availableValueList': ['10', '20']}]}
5 5 {'headers': {'Host': 'test.trace.diligrp.com:8393', 'Connection': 'keep-alive', 'Content-Length': '1378', 'Accept': 'application/json,text/javascript,*/*;q=0.01', 'X-Requested-With': 'XMLHttpRequest', 'User-Agent': 'Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/91.0.4472.77Safari/537.36', 'Content-Type': 'application/json', 'Origin': 'http://test.trace.diligrp.com:8393', 'Referer': 'http://test.trace.diligrp.com:8393/fieldConfig/bill.html', 'Accept-Encoding': 'gzip,deflate', 'Accept-Language': 'zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7'}}
6   -[2021-07-19 17:33:22] [INFO] : ======================================================================================
7   -[2021-07-19 17:33:22] [INFO] : http://test.trace.diligrp.com:8393/newRegisterBill/doAdd.action
  6 +[2021-07-19 17:40:18] [INFO] : ======================================================================================
  7 +[2021-07-19 17:40:18] [INFO] : http://test.trace.diligrp.com:8393/newRegisterBill/doAdd.action
8 8 None
9 9 {'registerHeadWeight': '0', 'registerHeadRemainWeight': '0', 'imageCertList': [], 'measureType': 20, 'registType': 10, 'userId': 516, 'arrivalTallynos': [], 'arrivalDatetime': '', 'truckType': 10, 'weight': '111', 'weightUnit': 1, 'productName': '大白菜', 'productId': 2190, 'originName': '', 'originId': '', 'unitPrice': '', 'truckTareWeight': '', 'remark': '', 'specName': '', 'brandName': '', 'plate': '川A123456'}
10 10 {'headers': {'Host': 'test.trace.diligrp.com', 'Connection': 'keep-alive', 'Content-Length': '325', 'Accept': 'application/json,text/javascript,*/*;q=0.01', 'User-Agent': 'Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.212Safari/537.36', 'Content-Type': 'application/json', 'Origin': 'http://test.trace.diligrp.com:8393', 'Referer': 'http://test.trace.diligrp.com:8393/newRegisterBill/add.html', 'Accept-Encoding': 'gzip,deflate', 'Accept-Language': 'zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7'}}
11   -[2021-07-19 17:33:22] [INFO] : ======================================================================================
12   -[2021-07-19 17:33:22] [INFO] : http://test.trace.diligrp.com:8393/fieldConfig/doUpdate.action
13   -None
14   -{'moduleType': '1', 'marketId': '8', 'fieldConfigDetailList': [{'fieldName': 'unitPrice', 'jsonPath': '$.unitPrice', 'defaultId': '3', 'displayed': '1', 'required': '0'}, {'fieldName': 'arrivalTallynos', 'jsonPath': '$.arrivalTallynos', 'defaultId': '10', 'displayed': '1', 'required': '0'}, {'fieldName': 'brandName', 'jsonPath': '$.brandName', 'defaultId': '5', 'displayed': '1', 'required': '0'}, {'fieldName': 'truckTareWeight', 'jsonPath': '$.truckTareWeight', 'defaultId': '1', 'displayed': '1', 'required': '0'}, {'fieldName': 'originId', 'jsonPath': '$.originId', 'defaultId': '7', 'displayed': '1', 'required': '0'}, {'fieldName': 'specName', 'jsonPath': '$.specName', 'defaultId': '4', 'displayed': '1', 'required': '0'}, {'fieldName': 'truckType', 'jsonPath': '$.truckType', 'defaultId': '2', 'displayed': '1', 'required': '1', 'availableValueList': ['10', '20']}, {'fieldName': 'imageCertList', 'jsonPath': '$.imageCertList[*]certType', 'defaultId': '11', 'displayed': '1', 'required': '0', 'availableValueList': ['2', '3']}, {'fieldName': 'arrivalDatetime', 'jsonPath': '$.arrivalDatetime', 'defaultId': '9', 'displayed': '1', 'required': '0'}, {'fieldName': 'remark', 'jsonPath': '$.remark', 'defaultId': '8', 'displayed': '1', 'required': '0'}, {'fieldName': 'remark', 'jsonPath': '$.remark', 'defaultId': '6', 'displayed': '1', 'required': '0'}, {'fieldName': 'measureType', 'jsonPath': '$.measureType', 'defaultId': '12', 'displayed': '1', 'required': '1', 'availableValueList': ['10', '20']}]}
15   -{'headers': {'Host': 'test.trace.diligrp.com:8393', 'Connection': 'keep-alive', 'Content-Length': '1378', 'Accept': 'application/json,text/javascript,*/*;q=0.01', 'X-Requested-With': 'XMLHttpRequest', 'User-Agent': 'Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/91.0.4472.77Safari/537.36', 'Content-Type': 'application/json', 'Origin': 'http://test.trace.diligrp.com:8393', 'Referer': 'http://test.trace.diligrp.com:8393/fieldConfig/bill.html', 'Accept-Encoding': 'gzip,deflate', 'Accept-Language': 'zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7'}}
16   -[2021-07-19 17:33:23] [INFO] : ======================================================================================
17   -[2021-07-19 17:33:23] [INFO] : http://test.trace.diligrp.com:8393/fieldConfig/doUpdate.action
18   -None
19   -{'moduleType': '1', 'marketId': '8', 'fieldConfigDetailList': [{'fieldName': 'unitPrice', 'jsonPath': '$.unitPrice', 'defaultId': '3', 'displayed': '1', 'required': '0'}, {'fieldName': 'arrivalTallynos', 'jsonPath': '$.arrivalTallynos', 'defaultId': '10', 'displayed': '1', 'required': '0'}, {'fieldName': 'brandName', 'jsonPath': '$.brandName', 'defaultId': '5', 'displayed': '1', 'required': '0'}, {'fieldName': 'truckTareWeight', 'jsonPath': '$.truckTareWeight', 'defaultId': '1', 'displayed': '1', 'required': '0'}, {'fieldName': 'originId', 'jsonPath': '$.originId', 'defaultId': '7', 'displayed': '1', 'required': '0'}, {'fieldName': 'specName', 'jsonPath': '$.specName', 'defaultId': '4', 'displayed': '1', 'required': '0'}, {'fieldName': 'truckType', 'jsonPath': '$.truckType', 'defaultId': '2', 'displayed': '1', 'required': '1', 'availableValueList': ['10', '20']}, {'fieldName': 'imageCertList', 'jsonPath': '$.imageCertList[*]certType', 'defaultId': '11', 'displayed': '1', 'required': '0', 'availableValueList': ['2', '3']}, {'fieldName': 'arrivalDatetime', 'jsonPath': '$.arrivalDatetime', 'defaultId': '9', 'displayed': '1', 'required': '0'}, {'fieldName': 'remark', 'jsonPath': '$.remark', 'defaultId': '8', 'displayed': '1', 'required': '0'}, {'fieldName': 'remark', 'jsonPath': '$.remark', 'defaultId': '6', 'displayed': '1', 'required': '0'}, {'fieldName': 'measureType', 'jsonPath': '$.measureType', 'defaultId': '12', 'displayed': '1', 'required': '1', 'availableValueList': ['10', '20']}]}
20   -{'headers': {'Host': 'test.trace.diligrp.com:8393', 'Connection': 'keep-alive', 'Content-Length': '1378', 'Accept': 'application/json,text/javascript,*/*;q=0.01', 'X-Requested-With': 'XMLHttpRequest', 'User-Agent': 'Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/91.0.4472.77Safari/537.36', 'Content-Type': 'application/json', 'Origin': 'http://test.trace.diligrp.com:8393', 'Referer': 'http://test.trace.diligrp.com:8393/fieldConfig/bill.html', 'Accept-Encoding': 'gzip,deflate', 'Accept-Language': 'zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7'}}
21   -[2021-07-19 17:33:24] [INFO] : 发送邮件
22   -[2021-07-19 17:33:26] [INFO] : 邮件发送完毕
... ...
src/commons/.gitignore deleted 100644 → 0
1   -/Logging.pyc
2   -/SendEmail.pyc
3   -/__init__.pyc
4   -/common.pyc
src/commons/ConfigDB.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import pymysql
4   -import time
5   -import commons.common as ca
6   -import json
7   -from commons.Logging import Logger
8   -# import chardet
9   -log=Logger()
10   -
11   -
12   -dbhost=ca.get_global_config('global_data','Database','dbhost')
13   -dbport=int(ca.get_global_config('global_data','Database','dbport'))
14   -dbname=ca.get_global_config('global_data','Database','dbname')
15   -dbuser=ca.get_global_config('global_data','Database','dbuser')
16   -dbpassword=ca.get_global_config('global_data','Database','dbpassword')
17   -#dbcharset=get_global_config('Database','dbcharset')
18   -
19   -def mysql_conn_test():
20   - # 数据库连接重试功能和连接超时功能的DB连接
21   - _conn_status = True
22   - _max_retries_count = 3 # 设置最大重试次数
23   - _conn_retries_count = 0 # 初始重试次数
24   - _conn_timeout = 3 # 连接超时时间为3秒
25   - while _conn_status and _conn_retries_count < _max_retries_count:
26   - try:
27   - print('连接数据库中..')
28   - db = pymysql.connect(host=dbhost,
29   - port=dbport,
30   - user=dbuser,
31   - passwd=dbpassword,
32   - database=dbname,
33   - charset='utf8',
34   - connect_timeout=_conn_timeout)
35   - _conn_status = False # 如果conn成功则_status为设置为False则退出循环,返回db连接对象
36   - print("连接结果 ",db)
37   - return db
38   - except:
39   - _conn_retries_count += 1
40   - print(_conn_retries_count)
41   - print('connect db is error!!')
42   - time.sleep(3) # 此为测试看效果
43   - continue
44   - raise Exception("pls check your mysql config!")
45   -
46   -
47   -def mysql_selectOne(select_action):
48   - action=select_action
49   - db = pymysql.connect(host=dbhost,
50   - port=dbport,
51   - user=dbuser,
52   - passwd=dbpassword,
53   - database=dbname,
54   - charset='utf8',
55   - connect_timeout=3)
56   - cursor = db.cursor()
57   - try:
58   - # 使用execute方法执行SQL语句
59   - cursor.execute(action)
60   - data = cursor.fetchone()
61   - return data
62   - except Exception as e:
63   - print("数据库操作异常:%s" % str(e))
64   - log.error("数据库操作异常:%s" % str(e))
65   - assert False
66   - finally:
67   - # 关闭数据库连接
68   - db.close()
69   -
70   -def mysql_selectAll(select_action):
71   - action=select_action
72   - db = pymysql.connect(host=dbhost,
73   - port=dbport,
74   - user=dbuser,
75   - passwd=dbpassword,
76   - database=dbname,
77   - charset='utf8',
78   - connect_timeout=3)
79   - cursor = db.cursor()
80   - try:
81   - # 使用execute方法执行SQL语句
82   - cursor.execute(action)
83   - # 使用 fetchall() 方法获取所有数据
84   - data = cursor.fetchall()
85   -# print data
86   - return data
87   - except Exception as e:
88   - print("数据库操作异常:%s" % str(e))
89   - log.error("数据库操作异常:%s" % str(e))
90   - assert False
91   - finally:
92   - # 关闭数据库连接
93   - db.close()
94   -
95   -def mysql_delete(delete_action):
96   - action=delete_action
97   - db = pymysql.connect(host=dbhost,
98   - port=dbport,
99   - user=dbuser,
100   - passwd=dbpassword,
101   - database=dbname,
102   - charset='utf8',
103   - connect_timeout=3)
104   - cursor = db.cursor()
105   - try:
106   - # 使用execute方法执行SQL语句
107   - cursor.execute(action)
108   - # 提交
109   - db.commit()
110   - except Exception as e:
111   - print("数据库操作异常:%s" % str(e))
112   - log.error("数据库操作异常:%s" % str(e))
113   - # 错误回滚
114   - db.rollback()
115   - finally:
116   - # 关闭数据库连接
117   - db.close()
118   -
119   -def mysql_update(update_action):
120   - action=update_action
121   - db = pymysql.connect(host=dbhost,
122   - port=dbport,
123   - user=dbuser,
124   - passwd=dbpassword,
125   - database=dbname,
126   - charset='utf8',
127   - connect_timeout=3)
128   - cursor = db.cursor()
129   - try:
130   - # 使用execute方法执行SQL语句
131   - cursor.execute(action)
132   - # 提交
133   - db.commit()
134   - except Exception as e:
135   - print("数据库操作异常:%s" % str(e))
136   - log.error("数据库操作异常:%s" % str(e))
137   - # 错误回滚
138   - db.rollback()
139   - finally:
140   - # 关闭数据库连接
141   - db.close()
142   -
143   -def mysql_insert(insert_action):
144   - action=insert_action
145   - db = pymysql.connect(host=dbhost,
146   - port=dbport,
147   - user=dbuser,
148   - passwd=dbpassword,
149   - database=dbname,
150   - charset='utf8',
151   - connect_timeout=3)
152   - cursor = db.cursor()
153   - try:
154   - # 使用execute方法执行SQL语句
155   - cursor.execute(action)
156   - # 提交
157   - db.commit()
158   - except Exception as e:
159   - print("数据库操作异常:%s" % str(e))
160   - log.error("数据库操作异常:%s" % str(e))
161   - # 错误回滚
162   - db.rollback()
163   - finally:
164   - # 关闭数据库连接
165   - db.close()
166   -
167   -def mysql_check_insert(api,section,check_sql,delete_sql,insert_sql):
168   - log.info(u"======测试数据准备======")
169   - check=ca.get_api_config(api, section, check_sql)
170   - delete=ca.get_api_config(api, section, delete_sql)
171   - insert=ca.get_api_config(api, section, insert_sql)
172   -
173   - try:
174   - db = pymysql.connect(dbhost, dbuser, dbpassword, dbname, charset='utf8' )
175   - cursor = db.cursor()
176   - # 使用execute方法执行SQL语句
177   - cursor.execute(check)
178   - result=cursor.fetchall()
179   - # 提交
180   - db.commit()
181   - if result:
182   - log.info(u"检查到数据库有重复数据%r"%str(result))
183   - log.info(u"删除查询到的重复数据%r"%str(delete))
184   - cursor.execute(delete)
185   - log.info(u"删除数据完成")
186   - log.info(u"向数据库中插入测试数据%r"%str(insert))
187   - cursor.execute(insert)
188   - log.info(u"插入数据完成")
189   - result=cursor.fetchall()
190   - db.commit()
191   - return result
192   - else:
193   - log.info(u"数据库没有重复数据直接插入自定义数据%r"%str(insert))
194   - result=cursor.execute(insert)
195   - log.info(u"插入数据完成,返回结果为为%r"%str(result))
196   -# cursor.fetchall()
197   - db.commit()
198   - return result
199   -
200   - except Exception as e:
201   - print(u"数据库操作异常:%r" % str(e))
202   - log.error(u"数据库操作异常:%r" % str(e))
203   - # 错误回滚
204   - db.rollback()
205   - assert False
206   - finally:
207   - # 关闭数据库连接
208   - db.close()
209   -
210   -def Check_in_Mysql(in_data,sql_spm):
211   - log.info(u"======从数据库中查询传入数据======")
212   - result=mysql_selectAll(sql_spm)
213   - log.info(u"传入in_data为: %s"%in_data)
214   - log.info(u"数据库查询到的结果为 %s"%result)
215   -
216   - result=str(result)
217   - if len(str(in_data)) == 0 and len(result)!=0:
218   - log.error(u"传入数据为空!!\n")
219   - assert False
220   - return
221   - elif len(str(in_data)) == 0 and len(result)==0:
222   - log.error(u"传入数据与数据库查询结果都为空!!\n")
223   - assert False
224   - return
225   - elif len(str(in_data)) != 0 and len(result)==0:
226   - log.error(u"数据库查询结果为空\n")
227   - assert False
228   - return
229   - elif isinstance(in_data,(list)):
230   - log.info(u'检查的数据格式 为list类型')
231   - for i in range(0,len(in_data)):
232   - in_data[i]=str(in_data[i]).decode("utf-8").encode("unicode-escape")
233   -
234   - if in_data[i] in result:
235   - assert True
236   - log.info(u"遍历list第%d次,插入数据%r与数据库查询结果一致"%(i,in_data[i]))
237   - else:
238   - log.error(u"#########ERROR#########:\n in_data与数据库查询结果不一致%r"%in_data[i])
239   - assert False
240   - return True
241   -
242   - elif str(in_data).decode("utf-8").encode("unicode-escape") in result:
243   - assert True
244   - log.info(u"in_data与数据库查询结果一致!!%r"%in_data)
245   - return True
246   - else:
247   - log.info(u"#########ERROR#########:\n in_data与数据库查询结果不一致!!%r"%in_data)
248   - assert False
249   -
250   -def Check_in_Response(check_data,src_data):
251   - "check_data必须为列表形式,src_data必须为r.json()的数据类型"
252   - log.info(u"======从响应Body中查询传入数据======")
253   - src_data=json.dumps(src_data)
254   - src_data=src_data.replace(" ","")
255   - log.info(u"传入check_data为: %s"%check_data)
256   - log.info(u"对比的响应数据为 %s"%src_data)
257   - if len(check_data) == 0 or len(src_data)==0:
258   - log.error(u"传入数据为空!!\n")
259   - assert False
260   - return
261   - elif isinstance (check_data,str) :
262   - check_data=check_data.replace(" ","").replace("[","").replace("]","").decode("utf-8").split(",")
263   - for i in range(0,len(check_data)):
264   - #由于数据库查询的数据中,中文的格式为unicode-escape,所以传入的数据需要进行encode
265   - check_data[i]=check_data[i].decode("utf-8").encode("unicode-escape")
266   -# print type(check_data),check_data[i]
267   - if check_data[i] in src_data:
268   - assert True
269   - log.info(u"遍历list第%d次,字段%s在请求响应结果中"%((i+1),check_data[i].decode("unicode-escape")))
270   - else:
271   - log.error(u"#########ERROR#########:\n check_data不在请求响应结果中%s"%check_data[i].decode("unicode-escape"))
272   - assert False
273   - return True
274   - elif isinstance (check_data,list) and len(check_data) > 0:
275   - for i in range(0,len(check_data)):
276   - check_data[i]=check_data[i].decode("utf-8").encode("unicode-escape")
277   - print(type(check_data),check_data[i],str(check_data[i]))
278   - print(type(src_data),src_data)
279   - if check_data[i] in src_data:
280   - assert True
281   - log.info(u"遍历list第%d次,插入数据%r与数据库查询结果一致"%(i,check_data[i]))
282   - else:
283   - log.error(u"#########ERROR#########:\n check_data数据库查询结果不一致%r"%check_data[i])
284   - assert False
285   - return True
286   - else:
287   - log.info(u"#########ERROR#########:\n 检查数据有问题,请检查!!!!!%r")
288   - assert False
src/commons/Faker.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import random
4   -from faker import Factory
5   -
6   -class random_data():
7   -
8   - def __init__(self, type='zh_CN'):
9   - self.type = type
10   - self.fake = Factory().create(self.type)
11   -
12   - def date(self):
13   - "随机时间"
14   - return self.fake.date(pattern="%Y-%m-%d")
15   -
16   - def name(self):
17   - "随机姓名"
18   - return self.fake.name()
19   -
20   - def identity_card(self):
21   - "随机姓名"
22   - return self.fake.ssn(min_age=18, max_age=90)
23   -
24   - def plate(self):
25   - "随机车牌号"
26   - return self.fake.license_plate()
27   -
28   - def plate_cn(self,plate_len=6):
29   - char0='京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽赣粤青藏川宁琼'
30   - char1='ABCDEFGHJKLMNPQRSTUVWXYZ'#车牌号中没有I和O,可自行百度
31   - char2='1234567890'
32   - len0=len(char0)-1
33   - len1 = len(char1) - 1
34   - len2 = len(char2) - 1
35   - ########
36   - code = ''
37   - index0 = random.randint(0,len0 )
38   - index1 = random.randint(0,len1)
39   - code += char0[index0]
40   - code += char1[index1]
41   - for i in range(0, plate_len-1):
42   - index2 = random.randint(1, len2)
43   - code += char2[index2]
44   - return(code)
45   -
46   - def country(self):
47   - "随机国家代码"
48   - return self.fake.country()
49   -
50   - def province(self):
51   - "随机省份"
52   - return self.fake.province()
53   -
54   - def city(self):
55   - "随机城市"
56   - return self.fake.city_suffix()
57   -
58   - def district(self):
59   - "随机街道"
60   - return self.fake.district()
61   -
62   - def address(self):
63   - "随机地址全称"
64   - return self.fake.address()
65   -
66   - def phone_number(self):
67   - "随机手机号"
68   - return self.fake.phone_number()
69   -
70   - def email(self):
71   - "随机邮件"
72   - return self.fake.email()
73   -
74   - def longitude(self):
75   - "随机经度"
76   - return self.fake.longitude()
77   -
78   - def latitude (self):
79   - "随机维度"
80   - return self.fake.latitude ()
81   -
82   - def credit_card_number (self):
83   - "随机卡号"
84   - return self.fake.credit_card_number ()
85   -
86   -
87   -
88   -a=random_data()
89   -print(a.date())
90   -print(a.name())
91   -print(a.identity_card())
92   -print(a.plate())
93   -print(a.plate_cn(6))
94   -print(a.country())
95   -print(a.province())
96   -print(a.city())
97   -print(a.district())
98   -print(a.address())
99   -print(a.phone_number())
100   -print(a.email())
101   -print(a.longitude())
102   -print(a.latitude())
103   -print(a.credit_card_number())
104   -
src/commons/Logging.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import logging,os
4   -
5   -class Logger():
6   -
7   - def __init__(self, path=__name__,clevel = logging.ERROR,Flevel = logging.DEBUG,test = 'w'):
8   - current_path=os.path.dirname(os.path.dirname(__file__))
9   - path=current_path+"/report"+"/test.log"
10   -
11   - self.logger = logging.getLogger(path)
12   -
13   - self.logger.setLevel(logging.DEBUG)
14   -
15   - fmt = logging.Formatter('[%(asctime)s] [%(levelname)s] : %(message)s', '%Y-%m-%d %H:%M:%S')
16   -
17   - sh = logging.StreamHandler()
18   -
19   - sh.setFormatter(fmt)
20   -
21   - sh.setLevel(clevel)
22   -
23   - #设置文件日志
24   -
25   - fh = logging.FileHandler(path,mode=test,encoding="utf-8")
26   -
27   - fh.setFormatter(fmt)
28   -
29   - fh.setLevel(Flevel)
30   -
31   - self.logger.addHandler(sh)
32   -
33   - self.logger.addHandler(fh)
34   -
35   -
36   - def debug(self,message):
37   -
38   - self.logger.debug(message)
39   -
40   - def info(self,message):
41   -
42   - self.logger.info(message)
43   -
44   -
45   - def warn(self,message):
46   -
47   - self.logger.warn(message)
48   -
49   -
50   - def error(self,message):
51   -
52   - self.logger.error(message)
53   -
54   -
55   - def critical(self,message):
56   -
57   - self.logger.critical(message)
src/commons/MySession.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import requests
4   -import json
5   -from commons import common as com
6   -from commons.Logging import Logger
7   -log=Logger()
8   -
9   -class mysession():
10   - "封装了requests的基类,以供后期统一使用"
11   -
12   - url="http://test.uap.diligrp.com/login/login.action"
13   - header={
14   - "Host": "test.uap.diligrp.com",
15   - "Connection": "keep-alive",
16   - "Content-Length": "33",
17   - "Cache-Control": "max-age=0",
18   - "Upgrade-Insecure-Requests": "1",
19   - "Origin": "http://test.uap.diligrp.com",
20   - "Content-Type": "application/x-www-form-urlencoded",
21   - "User-Agent": "Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.212Safari/537.36",
22   - "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
23   - "Referer": "http://test.uap.diligrp.com/login/index.html",
24   - "Accept-Encoding": "gzip,deflate",
25   - "Accept-Language": "zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7",
26   - "Cookie": "UAP_accessToken=;UAP_refreshToken=;UAP_loginPath="}
27   - body="userName=sg_wenze&password=111111"
28   -
29   - def __init__(self):
30   - "如下代码,可以通过配置文件来控制测试环境和灰度环境,http和https"
31   - self.url=mysession.url.replace("http://test.",com.get_global_config("global_data", "environment", "en") )
32   - self.header=mysession.header
33   - self.body=mysession.body
34   - self.timeout = (5,5)
35   - self.max_retries = 3
36   - self.keep_alive = False
37   - self.ssl_verify=False
38   - self.proxies=None
39   - self.allow_redirects=False
40   -# self.proxies={'http': 'http://localhost:8888', 'https': 'http://localhost:8888'}
41   -
42   - def get_session(self,account,**kwargs):
43   - "如下代码,可以通过配置文件来控制登录的账户session"
44   - self.body=self.body.replace("sg_wenze", com.get_global_config("global_data", "account", account).split("&")[0])
45   - self.body=self.body.replace("111111", com.get_global_config("global_data", "account", account).split("&")[1])
46   - #requests.session()会话保持,比如使用session成功的登录了某个网站,
47   - #则在再次使用该session对象求求该网站的其他网页都会默认使用该session之前使用的cookie等参数
48   - self.se=requests.session()
49   - #使用session对象的方法POST/GET等
50   - re=self.se.post(url=self.url, headers=self.header,data=self.body,proxies=self.proxies,**kwargs)
51   - #返回session对象,供其他接口使用
52   - return self.se
53   -
54   - def close_session(self):
55   - "关闭session"
56   - self.se.close()
57   -
58   -
59   - def check_login(self,account,**kwargs):
60   - "验证登录接口"
61   - self.body=self.body.replace("sg_wenze", com.get_global_config("global_data", "account", account).split("&")[0])
62   - self.body=self.body.replace("111111", com.get_global_config("global_data", "account", account).split("&")[1])
63   - #POST请求,
64   - re=self.se.post(url=self.url, headers=self.header,data=self.body,proxies=self.proxies,allow_redirects=False,**kwargs)
65   - #判断请求
66   - assert "UAP_accessToken" in re.headers["Set-Cookie"]
67   - assert "UAP_refreshToken" in re.headers["Set-Cookie"]
68   - assert "UAP_loginPath" in re.headers["Set-Cookie"]
69   - print("登录接口验证成功")
70   - return re
71   -
72   -
73   - def get(self, url, **kwargs):
74   - """Sends a GET request. Returns :class:`Response` object.
75   -
76   - :param url: URL for the new :class:`Request` object.
77   - :param \*\*kwargs: Optional arguments that ``request`` takes.
78   - :rtype: requests.Response
79   - """
80   - #记录日志
81   - log.info("{0:=^86}".format(''))
82   - log.info("{}\n{}\n".format(url,kwargs))
83   - #进行请求
84   - re=self.se.get(url,**kwargs,proxies=self.proxies,timeout=self.timeout)
85   - return re
86   -
87   - def post(self, url, data=None, json=None, **kwargs):
88   - """Sends a POST request. Returns :class:`Response` object.
89   - :param url: URL for the new :class:`Request` object.
90   - :param data: (optional) Dictionary, list of tuples, bytes, or file-like
91   - object to send in the body of the :class:`Request`.
92   - :param json: (optional) json to send in the body of the :class:`Request`.
93   - :param \*\*kwargs: Optional arguments that ``request`` takes.
94   - :rtype: requests.Response
95   - """
96   - #记录日志
97   - log.info("{0:=^86}".format(''))
98   - log.info("{}\n{}\n{}\n{}".format(url,data,json,kwargs))
99   - #进行请求
100   - re=self.se.post(url, data=data, json=json,proxies=self.proxies, **kwargs,timeout=self.timeout)
101   - return re
102   -
103   - def options(self, url, **kwargs):
104   - """Sends a OPTIONS request. Returns :class:`Response` object.
105   - :param url: URL for the new :class:`Request` object.
106   - :param \*\*kwargs: Optional arguments that ``request`` takes.
107   - :rtype: requests.Response
108   - """
109   - #记录日志
110   - log.info(url,kwargs)
111   - #进行请求
112   - re=self.se.options(url,**kwargs)
113   - return re
114   -
115   - def head(self, url, **kwargs):
116   - """Sends a HEAD request. Returns :class:`Response` object.
117   -
118   - :param url: URL for the new :class:`Request` object.
119   - :param \*\*kwargs: Optional arguments that ``request`` takes.
120   - :rtype: requests.Response
121   - """
122   - #记录日志
123   - log.info(url,kwargs)
124   - #进行请求
125   - re=self.se.head(url,**kwargs)
126   - return re
127   -
128   - def put(self, url, data=None, **kwargs):
129   - """Sends a PUT request. Returns :class:`Response` object.
130   - :param url: URL for the new :class:`Request` object.
131   - :param data: (optional) Dictionary, list of tuples, bytes, or file-like
132   - object to send in the body of the :class:`Request`.
133   - :param \*\*kwargs: Optional arguments that ``request`` takes.
134   - :rtype: requests.Response
135   - """
136   - #记录日志
137   - log.info(url,data,kwargs)
138   - #进行请求
139   - re=self.se.put(url, data,**kwargs)
140   - return re
141   -
142   - def delete(self, url, **kwargs):
143   - """Sends a DELETE request. Returns :class:`Response` object.
144   - :param url: URL for the new :class:`Request` object.
145   - :param \*\*kwargs: Optional arguments that ``request`` takes.
146   - :rtype: requests.Response
147   - """
148   - #记录日志
149   - log.info(url,kwargs)
150   - #进行请求
151   - re=self.se.delete(url,**kwargs)
152   - return re
153   -
154   - def set_mark(self):
155   - "用户自定义优先级方法"
156   - mark_list=eval(com.get_global_config("global_data","mark","list"))
157   - print("预设运行标记:",mark_list)
158   - global _global_mark
159   - if type(mark_list)==type([]) and len(mark_list)!=0 :
160   - _global_mark=mark_list
161   - return _global_mark
162   - elif type(mark_list)==type([]) and len(mark_list)==0:
163   - _global_mark=False
164   - return _global_mark
165   - else:
166   - raise Exception("error,pls check mark data")
167   -
168   - def mark(self,m=None):
169   - try:
170   - #没有输入任何预设值,默认跑全部
171   - if _global_mark == False :
172   - return True
173   - #输入预设值且未标记用例,默认跑全部
174   - elif _global_mark != False and (m in _global_mark):
175   - return True
176   - else:
177   - return False
178   - except Exception as e:
179   - return False
180   -
181   -
182   -
183   -my=mysession()
184   -my.set_mark()
185   -s1=my.get_session("user01")
186   -# s2=my.get_session("user02")
src/commons/SendEmail.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import os
4   -import smtplib
5   -from email.mime.multipart import MIMEMultipart
6   -from email.header import Header
7   -from email.mime.text import MIMEText
8   -from email.mime.image import MIMEImage
9   -from email.mime.application import MIMEApplication
10   -from commons.Logging import Logger
11   -log=Logger()
12   -
13   -def send_email_text():
14   - # 1. 编写邮件内容(Email邮件需要专门的MIME格式)
15   - msg = MIMEText('this is a test email', 'plain', 'utf-8')
16   -
17   - # 2. 组装Email头(发件人,收件人,主题)
18   - msg['From'] = 'autotest@diligrp.com' # 发件人
19   - msg['To'] = 'lixi@diligrp.com' # 收件人
20   - msg['Subject'] = 'Api Test Report' # 邮件主题
21   -
22   - # 3. 连接smtp服务器并发送邮件
23   - smtp = smtplib.SMTP_SSL('smtp.exmail.qq.com')
24   - smtp.login('autotest@diligrp.com', 'MvkuGGCfMtAdbJvE')
25   - smtp.sendmail("autotest@diligrp.com", "lixi@diligrp.com", msg.as_string())
26   - smtp.quit()
27   -
28   -
29   -def send_email(send_file,send_to=["lixi@diligrp.com"]):
30   -
31   - log_path=os.path.dirname(os.path.dirname(__file__))
32   - log_path=log_path+"/report/test.log"
33   - send_msg=(",".join(str(i) for i in send_to))
34   - msg = MIMEMultipart() # 混合MIME格式
35   - msg['From'] = 'autotest@diligrp.com' # 发件人
36   - msg['To'] = send_msg # 收件人
37   - msg['Subject'] = Header('接口测试报告', 'utf-8') # 中文邮件主题,指定utf-8编码
38   -
39   - text = MIMEText('this is a test email', 'plain', 'utf-8')
40   - msg.attach(MIMEText(open(send_file,'rb' ).read(), 'html', 'utf-8'))
41   -
42   - att1 = MIMEText(open(send_file, 'rb').read(), 'base64', 'utf-8')
43   - att1["Content-Disposition"] = 'attachment; filename="report.html"'
44   -
45   - att2 = MIMEText(open(log_path, 'rb').read(), 'base64', 'utf-8')
46   - att2["Content-Type"] = 'application/octet-stream'
47   - att2["Content-Disposition"] = 'attachment; filename="test.log"'
48   - msg.attach(text)
49   - msg.attach(att1)
50   - msg.attach(att2)
51   -
52   - #一下发送日志不会在test.log上,因为提前msg.attach了
53   - log.info("发送邮件")
54   - try:
55   - smtp = smtplib.SMTP_SSL('smtp.exmail.qq.com') # smtp服务器地址 使用SSL模式
56   - re=smtp.login('autotest@diligrp.com', 'MvkuGGCfMtAdbJvE') # 用户名和密码
57   - smtp.sendmail("autotest@diligrp.com", send_to, msg.as_string())
58   - print(re)
59   - except Exception as e:
60   - log.error(str(e))
61   - print(e)
62   - finally:
63   - smtp.quit()
64   - log.info("邮件发送完毕")
src/commons/__init__.py deleted 100644 → 0
1   -# -*- coding:utf-8 -*-
2   -# import rsa
3   -# import binascii
4   -# import base64
5   -# import requests,json
6   -# import time
7   -# import sys
8   -# reload(sys)
9   -# sys.setdefaultencoding('utf8')
10 0 \ No newline at end of file
src/commons/api/__init__.py deleted 100644 → 0
1   -# -*- coding:utf-8 -*-
2   -import rsa
3   -import binascii
4   -import base64
5   -import requests,json
6   -import time
7   -# import sys
8   -# reload(sys)
9   -# sys.setdefaultencoding('utf8')
10 0 \ No newline at end of file
src/commons/api/doAdd.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import requests
4   -import json
5   -import urllib3
6   -from commons import common as com
7   -from commons.MySession import my,s1
8   -urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
9   -
10   -
11   -class doAdd():
12   -
13   - url="http://test.trace.diligrp.com:8393/newRegisterBill/doAdd.action"
14   - header={
15   - "Host": "test.trace.diligrp.com",
16   - "Connection": "keep-alive",
17   - "Content-Length": "325",
18   - "Accept": "application/json,text/javascript,*/*;q=0.01",
19   - "User-Agent": "Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.212Safari/537.36",
20   - "Content-Type": "application/json",
21   - "Origin": "http://test.trace.diligrp.com:8393",
22   - "Referer": "http://test.trace.diligrp.com:8393/newRegisterBill/add.html",
23   - "Accept-Encoding": "gzip,deflate",
24   - "Accept-Language": "zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7"}
25   - body={"registerHeadWeight":"0","registerHeadRemainWeight":"0","imageCertList":[],"measureType":20,"registType":10,"userId":516,"arrivalTallynos":[],"arrivalDatetime":"","truckType":10,"weight":"111","weightUnit":1,"productName":"大白菜","productId":2190,"originName":"","originId":"","unitPrice":"","truckTareWeight":"","remark":"","specName":"","brandName":"","plate":"川A123456"}
26   -
27   -
28   - def __init__(self):
29   - self.url=doAdd.url.replace("http://test.",com.get_global_config("global_data", "environment", "en") )
30   - self.header=doAdd.header
31   - self.body=doAdd.body
32   -
33   -
34   -# tt=doAdd()
35   -# re=my.post(url=tt.url,headers=tt.header,json=tt.body2)
36   -# print(re.json())
37   -# print(re.headers)
38 0 \ No newline at end of file
src/commons/api/doAudit.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import requests
4   -import json
5   -import urllib3
6   -from commons import common as com
7   -from commons.MySession import my
8   -urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
9   -
10   -class doAudit():
11   -
12   - url="http://test.trace.diligrp.com:8393/newRegisterBill/doAudit.action?id=5888&verifyStatus=20"
13   - header={
14   - "Host": "test.trace.diligrp.com",
15   - "Connection": "keep-alive",
16   - "Accept": "application/json,text/javascript,*/*;q=0.01",
17   - "User-Agent": "Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.212Safari/537.36",
18   - "X-Requested-With": "XMLHttpRequest",
19   - "Referer": "http://test.trace.diligrp.com:8393/newRegisterBill/add.html",
20   - "Accept-Encoding": "gzip,deflate",
21   - "Accept-Language": "zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7"}
22   -
23   -
24   - def __init__(self):
25   - self.url=doAudit.url.replace("http://test.",com.get_global_config("global_data", "environment", "en") )
26   - self.header=doAudit.header
27   -
28   -
29   -
30   -
31   -# tt=doAudit()
32   -# re=my.get(url=tt.url,headers=tt.header)
33   -# print(re.json())
34 0 \ No newline at end of file
src/commons/api/doUndo.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import requests
4   -import json
5   -import urllib3
6   -from commons import common as com
7   -from commons.MySession import my,s1
8   -urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
9   -
10   -
11   -class doUndo():
12   -
13   - url="http://test.trace.diligrp.com:8393/newRegisterBill/doUndo.action?id=6668"
14   - header={
15   - "Host": "test.trace.diligrp.com:8393",
16   - "Connection": "keep-alive",
17   - "Accept": "application/json,text/javascript,*/*;q=0.01",
18   - "User-Agent": "Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/91.0.4472.124Safari/537.36",
19   - "X-Requested-With": "XMLHttpRequest",
20   - "Referer": "http://test.trace.diligrp.com:8393/newRegisterBill/index.html",
21   - "Accept-Encoding": "gzip,deflate",
22   - "Accept-Language": "zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7"}
23   -
24   -
25   - def __init__(self):
26   - self.url=doUndo.url.replace("http://test.",com.get_global_config("global_data", "environment", "en") )
27   - self.header=doUndo.header
28   -
29   -
30   -
31   -# tt=doUndo()
32   -# re=my.get(url=tt.url,headers=tt.header)
33   -# print(re.json())
src/commons/api/fieldConfig.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import requests
4   -import json
5   -import urllib3
6   -from commons import common as com
7   -from commons.MySession import my
8   -urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
9   -
10   -class fieldConfig():
11   -
12   - url="http://test.trace.diligrp.com:8393/fieldConfig/doUpdate.action"
13   - header={
14   - "Host": "test.trace.diligrp.com:8393",
15   - "Connection": "keep-alive",
16   - "Content-Length": "1378",
17   - "Accept": "application/json,text/javascript,*/*;q=0.01",
18   - "X-Requested-With": "XMLHttpRequest",
19   - "User-Agent": "Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/91.0.4472.77Safari/537.36",
20   - "Content-Type": "application/json",
21   - "Origin": "http://test.trace.diligrp.com:8393",
22   - "Referer": "http://test.trace.diligrp.com:8393/fieldConfig/bill.html",
23   - "Accept-Encoding": "gzip,deflate",
24   - "Accept-Language": "zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7"}
25   -
26   - body={"moduleType":"1","marketId":"8","fieldConfigDetailList":[{"fieldName":"unitPrice","jsonPath":"$.unitPrice","defaultId":"3","displayed":"1","required":"0"},{"fieldName":"arrivalTallynos","jsonPath":"$.arrivalTallynos","defaultId":"10","displayed":"1","required":"0"},{"fieldName":"brandName","jsonPath":"$.brandName","defaultId":"5","displayed":"1","required":"0"},{"fieldName":"truckTareWeight","jsonPath":"$.truckTareWeight","defaultId":"1","displayed":"1","required":"0"},{"fieldName":"originId","jsonPath":"$.originId","defaultId":"7","displayed":"1","required":"0"},{"fieldName":"specName","jsonPath":"$.specName","defaultId":"4","displayed":"1","required":"0"},{"fieldName":"truckType","jsonPath":"$.truckType","defaultId":"2","displayed":"1","required":"1","availableValueList":["10","20"]},{"fieldName":"imageCertList","jsonPath":"$.imageCertList[*]certType","defaultId":"11","displayed":"1","required":"0","availableValueList":["2","3"]},{"fieldName":"arrivalDatetime","jsonPath":"$.arrivalDatetime","defaultId":"9","displayed":"1","required":"0"},{"fieldName":"remark","jsonPath":"$.remark","defaultId":"8","displayed":"1","required":"0"},{"fieldName":"remark","jsonPath":"$.remark","defaultId":"6","displayed":"1","required":"0"},{"fieldName":"measureType","jsonPath":"$.measureType","defaultId":"12","displayed":"1","required":"1","availableValueList":["10","20"]}]}
27   -
28   - def __init__(self):
29   - self.url=fieldConfig.url.replace("http://test.",com.get_global_config("global_data", "environment", "en") )
30   - self.header=fieldConfig.header
31   - self.body=fieldConfig.body
32   -
33   -
34   -
35   -
36   -# tt=fieldConfig()
37   -# re=my.post(url=tt.url,headers=tt.header,json=tt.body)
38   -# print(re.json())
39 0 \ No newline at end of file
src/commons/api/login.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import requests
4   -import json
5   -from commons import common as com
6   -
7   -class login():
8   - url="http://test.uap.diligrp.com/login/login.action"
9   - header={
10   - "Host": "test.uap.diligrp.com",
11   - "Connection": "keep-alive",
12   - "Content-Length": "33",
13   - "Cache-Control": "max-age=0",
14   - "Upgrade-Insecure-Requests": "1",
15   - "Origin": "http://test.uap.diligrp.com",
16   - "Content-Type": "application/x-www-form-urlencoded",
17   - "User-Agent": "Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.212Safari/537.36",
18   - "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
19   - "Referer": "http://test.uap.diligrp.com/login/index.html",
20   - "Accept-Encoding": "gzip,deflate",
21   - "Accept-Language": "zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7",
22   - "Cookie": "UAP_accessToken=;UAP_refreshToken=;UAP_loginPath="}
23   - body="userName=sg_wenze&password=111111"
24   -
25   - def __init__(self):
26   - "如下代码,可以通过配置文件来控制测试环境和灰度环境,http和https"
27   - self.url=login.url.replace("http://test.",com.get_global_config("global_data", "environment", "en") )
28   - self.header=login.header
29   - self.body=login.body
30   -
31   - def post(self,name,password,**kwargs):
32   - """为登录接口单独写的一个POST请求方法;
33   - #参数话账户和密码,通过再业务代码中传递不同的账户和密码,实现测试的不同场景"""
34   - self.body=self.body.replace("sg_wenze", name)
35   - self.body=self.body.replace("111111", password)
36   - re=requests.post(url=self.url, headers=self.header,data=self.body,allow_redirects=False,**kwargs)
37   - #返回请求对象,供断言使用
38   - return re
39   -
40   - def login_session(self,name,password,**kwargs):
41   - "对外提供的方法"
42   - self.body=self.body.replace("sg_wenze", name)
43   - self.body=self.body.replace("111111", password)
44   - self.se=requests.session()
45   - self.se.post(url=self.url, headers=self.header,data=self.body,**kwargs)
46   - #返回请求对象,供断言使用
47   - return self.se
48   -
49   -
50   -
51   -# t=login()
52   -# re=t.post("sg_wenze", "111111")
53   -# print(re.headers)
54 0 \ No newline at end of file
src/commons/api/logout.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import requests
4   -import json
5   -from commons import common as com
6   -
7   -
8   -class logout():
9   - url="http://test.uap.diligrp.com/login/logout.action"
10   - header={
11   - "Host": "test.uap.diligrp.com",
12   - "Connection": "keep-alive",
13   - "Content-Length": "33",
14   - "X-Requested-With": "XMLHttpRequest",
15   - "Origin": "http://test.uap.diligrp.com",
16   - "Content-Type": "application/x-www-form-urlencoded; charset=UTF-8",
17   - "User-Agent": "Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.212Safari/537.36",
18   - "Accept": "*/*",
19   - "Referer": "http://test.uap.diligrp.com/login/index.html",
20   - "Accept-Encoding": "gzip,deflate",
21   - "Accept-Language": "zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7",
22   - "Cookie": "UAP_accessToken=;UAP_refreshToken=;UAP_loginPath="}
23   - body="systemCode=UAP&userId=210"
24   -
25   - def __init__(self):
26   - #如下代码,可以通过配置文件来控制测试环境和灰度环境,http和https
27   - self.url=logout.url.replace("http://test.",com.get_global_config("global_data", "environment", "en") )
28   - self.header=logout.header
29   - self.body=logout.body
30   -
31   - def post(self,session,account,**kwargs):
32   - #需要用专用的测试账户来测试,否则会影响其他用例
33   - self.body=self.body.replace("210", com.get_global_config("global_data", "userId", account))
34   - re=session.post(url=self.url, headers=self.header,data=self.body,**kwargs)
35   - return re
36   -
37   -
38   -
39   -
40   -# t=logout()
41   -# re=t.post("user01",proxies={'http': 'http://localhost:8888'})
42   -# print(re.json())
43 0 \ No newline at end of file
src/commons/api/upStream.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import requests
4   -import json
5   -import urllib3
6   -from commons import common as com
7   -from commons.MySession import my
8   -urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
9   -
10   -class upStream():
11   -
12   - url="http://test.trace.diligrp.com:8393/upStream/listPage.action"
13   - header={
14   - "Host": "test.trace.diligrp.com",
15   - "Connection": "keep-alive",
16   - "Content-Length": "325",
17   - "Accept": "application/json,text/javascript,*/*;q=0.01",
18   - "X-Requested-With": "XMLHttpRequest",
19   - "User-Agent": "Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.212Safari/537.36",
20   - "Content-Type": "application/json",
21   - "Origin": "http://test.trace.diligrp.com:8393",
22   - "Referer": "http://test.trace.diligrp.com:8393/upStream/index.html",
23   - "Accept-Encoding": "gzip,deflate",
24   - "Accept-Language": "zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7"}
25   - body={"rows":10,"page":1,"sort":"id","order":"desc","metadata":{"created":"{\"provider\":\"datetimeProvider\",\"index\":10,\"field\":\"created\"}","upORdown":"{\"provider\":\"userFlagProvider\",\"index\":20,\"field\":\"upORdown\"}","upstreamType":"{\"provider\":\"upStreamTypeProvider\",\"index\":30,\"field\":\"upstreamType\"}"}}
26   -
27   -
28   - def __init__(self):
29   - self.url=upStream.url.replace("http://test.",com.get_global_config("global_data", "environment", "en") )
30   - self.header=upStream.header
31   - self.body=upStream.body
32   -
33   -
34   -
35   -# uu=upStream()
36   -# re=my.post(url=uu.url,headers=uu.header,json=uu.body)
37   -# print(re.json())
38   -#=========================================================
39   -# body=uu.body.copy()
40   -# body["likeName"]="111"
41   -# re=my.post(url=uu.url,headers=uu.header,json=body)
42   -# print(re.json())
43 0 \ No newline at end of file
src/commons/common.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import os
4   -import configparser
5   -import unittest
6   -from discover import DiscoveringTestLoader
7   -from commons.Logging import Logger
8   -log=Logger()
9   -
10   -
11   -def get_global_config(file,section, key):
12   - "object file is *src/config/global_data.conf"
13   - current_path=os.path.dirname(__file__)
14   - src_path=os.path.dirname(current_path)
15   -# global_setting_path=src_path+'/config/global_data.conf'
16   - global_setting_path=src_path+'/config/'+file+".conf"
17   - #验证文件是否存在
18   - file_path = os.path.exists(global_setting_path)
19   - if file_path:
20   - #获取文件的数据
21   - if isinstance(key,int):
22   - log.error("key of section cannot be int Type :<%r> "%str(key))
23   - raise Exception("key of section cannot be int Type :<%r> "%str(key))
24   - else:
25   - config = configparser.ConfigParser()
26   - config.read(global_setting_path,encoding="utf-8")
27   - return config.get(section, key)
28   - else:
29   - log.error("File Not Exist :<%r> "%str(global_setting_path))
30   - raise Exception("File Not Exist :<%r> "%str(global_setting_path))
31   -
32   -
33   -def get_api_config(api,section,key):
34   - "object file is *src/config/api/*.conf"
35   - current_path=os.path.dirname(__file__)
36   - src_path=os.path.dirname(current_path)
37   - api_path=src_path+"/config/api/"
38   - api_config_path=api_path+api+".conf"
39   - #验证文件是否存在
40   - file_path = os.path.exists(api_config_path)
41   - if file_path:
42   - #获取文件的数据
43   - if isinstance(key,int):
44   - log.error("key of section cannot be int Type :<%r> "%str(key))
45   - raise Exception("key of section cannot be int Type :<%r> "%str(key))
46   - else:
47   - config = configparser.ConfigParser()
48   - config.read(api_config_path,encoding="utf-8")
49   - return config.get(section, key)
50   - else:
51   - log.error("File Not Exist :<%r> "%str(api_config_path))
52   - raise Exception("File Not Exist :<%r> "%str(api_config_path))
53   -
54   -
55   -def run_one(name):
56   - test_suite = unittest.TestSuite()
57   - #创建测试套
58   - test_suite.addTest(name)
59   - #显示运行用例
60   - print("运行用例为{}".format(test_suite))
61   - runner = unittest.TextTestRunner()
62   - runner.run(test_suite)
63   -
64   -def run_list(name):
65   - test_suite = unittest.TestSuite()
66   - test_suite.addTests(name)
67   - #显示运行用例
68   - print("运行用例为{}".format(test_suite))
69   - runner = unittest.TextTestRunner()
70   - runner.run(test_suite)
71   -
72   -def run_class(name):
73   - test_cases = unittest.TestLoader().loadTestsFromTestCase(name)
74   - #显示运行用例
75   - print("运行用例为{}".format(test_cases))
76   - runner = unittest.TextTestRunner()
77   - runner.run(test_cases)
78   -
79   -def run_Module(name):
80   - test_cases = unittest.TestLoader().loadTestsFromModule(name)
81   - #显示运行用例
82   - print("运行用例为{}".format(test_cases))
83   - runner = unittest.TextTestRunner()
84   - runner.run(test_cases)
85   -
86   -def run_Name(name):
87   - test_cases = unittest.TestLoader().loadTestsFromName(name)
88   - #显示运行用例
89   - print("运行用例为{}".format(test_cases))
90   - runner = unittest.TextTestRunner()
91   - runner.run(test_cases)
src/config/__init__.py deleted 100644 → 0
src/config/api/customer.conf deleted 100644 → 0
1   -# -*- coding: UTF-8 -*-
2   -[fieldConfig]
3   -method=post
4   -url=http://test.trace.diligrp.com:8393/fieldConfig/doUpdate.action
5   -body_format=JSON
6   -
7   -header={
8   - "Host": "test.trace.diligrp.com",
9   - "Connection": "keep-alive",
10   - "Content-Length": "325",
11   - "Accept": "application/json,text/javascript,*/*;q=0.01",
12   - "X-Requested-With": "XMLHttpRequest",
13   - "User-Agent": "Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.212Safari/537.36",
14   - "Content-Type": "application/json",
15   - "Origin": "http://test.trace.diligrp.com:8393",
16   - "Referer": "http://test.trace.diligrp.com:8393/upStream/index.html",
17   - "Accept-Encoding": "gzip,deflate",
18   - "Accept-Language": "zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7"}
19   -
20   -[fieldConfig01]
21   -body={"rows":10,"page":1,"sort":"id","order":"desc","metadata":{"created":"{\"provider\":\"datetimeProvider\",\"index\":10,\"field\":\"created\"}","upORdown":"{\"provider\":\"userFlagProvider\",\"index\":20,\"field\":\"upORdown\"}","upstreamType":"{\"provider\":\"upStreamTypeProvider\",\"index\":30,\"field\":\"upstreamType\"}"}}
22   -
23   -
24   -[fieldConfig02]
25   -body={"rows":10,"page":1,"sort":"id","order":"desc","metadata":{"created":"{\"provider\":\"datetimeProvider\",\"index\":10,\"field\":\"created\"}","upORdown":"{\"provider\":\"userFlagProvider\",\"index\":20,\"field\":\"upORdown\"}","upstreamType":"{\"provider\":\"upStreamTypeProvider\",\"index\":30,\"field\":\"upstreamType\"}"}}
26   -
27   -
28   -[fieldConfig03]
29   -body={"rows":10,"page":1,"sort":"id","order":"desc","metadata":{"created":"{\"provider\":\"datetimeProvider\",\"index\":10,\"field\":\"created\"}","upORdown":"{\"provider\":\"userFlagProvider\",\"index\":20,\"field\":\"upORdown\"}","upstreamType":"{\"provider\":\"upStreamTypeProvider\",\"index\":30,\"field\":\"upstreamType\"}"}}
30   -
31   -
32   -
33   -
34   -
src/config/api/login.conf deleted 100644 → 0
src/config/api/upStream.conf deleted 100644 → 0
1   -# -*- coding: UTF-8 -*-
2   -[upStream]
3   -method=post
4   -url=http://test.trace.diligrp.com:8393/upStream/listPage.action
5   -body_format=JSON
6   -header={
7   - "Host": "test.trace.diligrp.com",
8   - "Connection": "keep-alive",
9   - "Content-Length": "325",
10   - "Accept": "application/json,text/javascript,*/*;q=0.01",
11   - "X-Requested-With": "XMLHttpRequest",
12   - "User-Agent": "Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.212Safari/537.36",
13   - "Content-Type": "application/json",
14   - "Origin": "http://test.trace.diligrp.com:8393",
15   - "Referer": "http://test.trace.diligrp.com:8393/upStream/index.html",
16   - "Accept-Encoding": "gzip,deflate",
17   - "Accept-Language": "zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7"}
18   -
19   -[upStream01]
20   -body={"rows":10,"page":1,"sort":"id","order":"desc","metadata":{"created":"{\"provider\":\"datetimeProvider\",\"index\":10,\"field\":\"created\"}","upORdown":"{\"provider\":\"userFlagProvider\",\"index\":20,\"field\":\"upORdown\"}","upstreamType":"{\"provider\":\"upStreamTypeProvider\",\"index\":30,\"field\":\"upstreamType\"}"}}
21   -
22   -
23   -[upStream02]
24   -body={"rows":10,"page":1,"sort":"id","order":"desc","metadata":{"created":"{\"provider\":\"datetimeProvider\",\"index\":10,\"field\":\"created\"}","upORdown":"{\"provider\":\"userFlagProvider\",\"index\":20,\"field\":\"upORdown\"}","upstreamType":"{\"provider\":\"upStreamTypeProvider\",\"index\":30,\"field\":\"upstreamType\"}"}}
25   -
26   -
27   -[upStream03]
28   -body={"rows":10,"page":1,"sort":"id","order":"desc","metadata":{"created":"{\"provider\":\"datetimeProvider\",\"index\":10,\"field\":\"created\"}","upORdown":"{\"provider\":\"userFlagProvider\",\"index\":20,\"field\":\"upORdown\"}","upstreamType":"{\"provider\":\"upStreamTypeProvider\",\"index\":30,\"field\":\"upstreamType\"}"}}
29   -
30   -
31   -[upStream04]
32   -body={"rows":10,"page":1,"sort":"id","order":"desc","metadata":{"created":"{\"provider\":\"datetimeProvider\",\"index\":10,\"field\":\"created\"}","upORdown":"{\"provider\":\"userFlagProvider\",\"index\":20,\"field\":\"upORdown\"}","upstreamType":"{\"provider\":\"upStreamTypeProvider\",\"index\":30,\"field\":\"upstreamType\"}"}}
33   -
34   -
35   -[upStream05]
36   -body={"rows":10,"page":1,"sort":"id","order":"desc","metadata":{"created":"{\"provider\":\"datetimeProvider\",\"index\":10,\"field\":\"created\"}","upORdown":"{\"provider\":\"userFlagProvider\",\"index\":20,\"field\":\"upORdown\"}","upstreamType":"{\"provider\":\"upStreamTypeProvider\",\"index\":30,\"field\":\"upstreamType\"}"}}
37   -
38   -
39   -[upStream06]
40   -body={"rows":10,"page":1,"sort":"id","order":"desc","metadata":{"created":"{\"provider\":\"datetimeProvider\",\"index\":10,\"field\":\"created\"}","upORdown":"{\"provider\":\"userFlagProvider\",\"index\":20,\"field\":\"upORdown\"}","upstreamType":"{\"provider\":\"upStreamTypeProvider\",\"index\":30,\"field\":\"upstreamType\"}"}}
41   -
42   -
43   -[upStream07]
44   -body={"rows":10,"page":1,"sort":"id","order":"desc","metadata":{"created":"{\"provider\":\"datetimeProvider\",\"index\":10,\"field\":\"created\"}","upORdown":"{\"provider\":\"userFlagProvider\",\"index\":20,\"field\":\"upORdown\"}","upstreamType":"{\"provider\":\"upStreamTypeProvider\",\"index\":30,\"field\":\"upstreamType\"}"}}
45   -
46   -expect_response={"code":"200","data":951,"message":"创建客户订单成功","result":"创建客户订单成功","success":true}
47   -
48   -
49   -
50   -
51   -
src/config/global_data.conf deleted 100644 → 0
1   -# -*- coding: UTF-8 -*-
2   -
3   -[account]
4   -user01=sg_wenze&111111
5   -user02=sgwanggang&111111
6   -user03=hz_wenze&111111
7   -
8   -[userId]
9   -user01=210
10   -user02=87
11   -user03=256
12   -
13   -[email]
14   -list=["lixi@diligrp.com","175930106@qq.com"]
15   -list11=["tg@diligrp.com","175930106@qq.com"]
16   -
17   -[mark]
18   -list=["test"]
19   -list1=["p1","P2",1,"test"]
20   -
21   -[Database]
22   -dbhost=10.35.100.34
23   -dbport=3306
24   -dbname=dili_trace
25   -dbuser=root
26   -dbpassword=123456
27   -dbcharset=utf8
28   -
29   -[environment]
30   -en=http://test.
31   -
32   -
33   -
34   -
35   -
36   -
src/config/global_data_backup.backup deleted 100644 → 0
1   -# -*- coding: UTF-8 -*-
2   -
3   -[account]
4   -user01=sg_wenze&111111
5   -user02=sgwanggang&111111
6   -user03=hz_wenze&111111
7   -
8   -[userId]
9   -user01=210
10   -user02=87
11   -user03=256
12   -
13   -[environment]
14   -en=http://test.
15   -
16   -[mark]
17   -list=["test"]
18   -list1=["p1","P2",1,"test"]
19   -
20   -[Database]
21   -dbhost=10.35.100.34
22   -dbport=3306
23   -dbname=dili_trace
24   -dbuser=root
25   -dbpassword=123456
26   -dbcharset=utf8
27   -
28   -[email]
29   -list=[]
30   -list1=["lixi@diligrp.com","LI@diligrp.com"]
31   -
32   -
33   -
34   -
35   -
36   -
src/main.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import os,time
4   -import sys
5   -import unittest
6   -import re
7   -import HTMLTestRunner_cn
8   -import commons.ConfigDB as db
9   -from discover import DiscoveringTestLoader
10   -from commons import SendEmail as em
11   -from commons import common as com
12   -from commons.MySession import my
13   -
14   -def Create_Testcase_suite():
15   - '''创建测试套件'''
16   - testunit=unittest.TestSuite()
17   - test_Loader = DiscoveringTestLoader()
18   - discover=test_Loader.discover("./testcase/",pattern='test_*.py',top_level_dir=None)
19   - print(discover)
20   - for test_suite in discover:
21   - testunit.addTests(test_suite)
22   -# print(testunit)
23   - return testunit
24   -
25   -
26   -def Run_Testcase(testsuit):
27   - '''运行测试用例并生成报告'''
28   - now = time.strftime("%Y-%m-%d %H_%M_%S",time.localtime())
29   - path=os.path.dirname(os.path.abspath(sys.argv[0]))
30   - report_file=path+"/report/"+now+"_result.html"
31   - #创建报告文件
32   - fp=open(report_file,'wb')
33   -
34   - runner=HTMLTestRunner_cn.HTMLTestRunner(
35   - stream=fp,
36   - title=u'重构项目接口测试报告',
37   - description=u'用例简要执行情况如下:(注:报告详细信息需要下载report.html并用浏览器打开)',
38   - verbosity = 2)
39   - #执行用例
40   - runner.run(testsuit)
41   - #关闭文件
42   - fp.close()
43   - return report_file
44   -
45   -def Send_email(filename):
46   - '''判断邮件发送逻辑'''
47   - l=eval(com.get_global_config("global_data", "email","list").lower())
48   - if type(l)!=type([]):
49   - raise Exception("error,pls input list type send-email address")
50   - elif len(l)==0:
51   - print("\n list of send-email is null,won't send email!")
52   - elif len(l)!=0:
53   - for i in l:
54   - print("\n check send-email format : {}".format(i))
55   - if re.match(r'^[0-9a-zA-Z_]{1,19}@[0-9a-zA-Z]{1,13}\.[com,cn,net]{1,3}$',i):
56   - pass
57   - else:
58   - raise Exception("error,pls check your send-email format")
59   - #发送邮件
60   - em.send_email(filename, l)
61   - else:
62   - print("\n Haven't sent the email,pls check send-email address!")
63   -
64   -
65   -
66   -if __name__ == "__main__":
67   - #检测数据库
68   - db.mysql_conn_test()
69   - #检测登录接口
70   - my.check_login("user01")
71   - #创建测试套,运行测试用例,生成报告
72   - report=Run_Testcase(Create_Testcase_suite())
73   - #发送邮件
74   - Send_email(report)
src/report/123.jpg deleted 100644 → 0

3.49 KB

src/report/2021-07-13 17_43_09_result.html deleted 100644 → 0
1   -<?xml version="1.0" encoding="UTF-8"?>
2   -<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3   -<html xmlns="http://www.w3.org/1999/xhtml">
4   -<head>
5   - <title>重构项目接口测试报告</title>
6   - <meta name="generator" content="HTMLTestRunner 0.8.3"/>
7   - <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
8   -
9   -<style type="text/css" media="screen">
10   -body { font-family: verdana, arial, helvetica, sans-serif; font-size: 80%; }
11   -table { font-size: 100%; }
12   -pre {
13   - white-space: pre-wrap;
14   - word-wrap: break-word;
15   -}
16   -
17   -/* -- heading ---------------------------------------------------------------------- */
18   -h1 {
19   - font-size: 16pt;
20   - color: gray;
21   -}
22   -.heading {
23   - float:left;
24   - width:30%;
25   - margin-top: 0ex;
26   - margin-bottom: 1ex;
27   -}
28   -
29   -.heading .attribute {
30   - margin-top: 1ex;
31   - margin-bottom: 0;
32   -}
33   -
34   -.heading .description {
35   - margin-top: 4ex;
36   - margin-bottom: 6ex;
37   -}
38   -
39   -/* -- css div popup ------------------------------------------------------------------------ */
40   -a.popup_link {
41   -}
42   -
43   -a.popup_link:hover {
44   - color: red;
45   -}
46   -.img{
47   - height: 100%;
48   - border-collapse: collapse;
49   - border: 2px solid #777;
50   -}
51   -
52   -.screenshots {
53   - z-index: 100;
54   - position:fixed;
55   - height: 80%;
56   - left: 50%;
57   - top: 50%;
58   - transform: translate(-50%,-50%);
59   - display: none;
60   -}
61   -
62   -.imgyuan{
63   - height: 20px;
64   - border-radius: 12px;
65   - background-color: red;
66   - padding-left: 13px;
67   - margin: 0 auto;
68   - position: relative;
69   - top: -40px;
70   - background-color: rgba(1, 150, 0, 0.3);
71   -}
72   -.imgyuan font{
73   - border:1px solid white;
74   - width:11px;
75   - height:11px;
76   - border-radius:50%;
77   - margin-right: 9px;
78   - margin-top: 4px;
79   - display: block;
80   - float: left;
81   - background-color: white;
82   -}
83   -.close_shots {
84   - background-image: url();
85   - background-size: 22px 22px;
86   - -moz-background-size: 22px 22px;
87   - background-repeat: no-repeat;
88   - position: absolute;
89   - top: 5px;
90   - right: 5px;
91   - height: 22px;
92   - z-index: 99;
93   - width: 22px;
94   -}
95   -.popup_window {
96   - display: none;
97   - position: relative;
98   - left: 0px;
99   - top: 0px;
100   - padding: 10px;
101   - background-color: #E6E6D6;
102   - font-family: "Lucida Console", "Courier New", Courier, monospace;
103   - text-align: left;
104   - font-size: 8pt;
105   -}
106   -
107   -}
108   -/* -- report ------------------------------------------------------------------------ */
109   -#show_detail_line {
110   - float:left;
111   - width:100%;
112   - margin-top: 3ex;
113   - margin-bottom: 1ex;
114   -}
115   -
116   -#result_table {
117   - margin: 1em 0;
118   - width: 100%;
119   - overflow: hidden;
120   - background: #FFF;
121   - color: #024457;
122   - border-radius: 10px;
123   - border: 1px solid #167F92;
124   -}
125   -#result_table th {
126   - border: 1px solid #FFFFFF;
127   - background-color: #167F92;
128   - color: #FFF;
129   - padding: 0.5em;
130   - &:first-child {
131   - display: table-cell;
132   - text-align: center;
133   - }
134   - &:nth-child(2) {
135   - display: table-cell;
136   - span {display:none;}
137   - &:after {content:attr(data-th);}
138   - }
139   - @media (min-width: 480px) {
140   - &:nth-child(2) {
141   - span {display: block;}
142   - &:after {display: none;}
143   - }
144   - }
145   - }
146   -#result_table td {
147   - word-wrap: break-word;
148   - max-width: 7em;
149   - padding: 0.3em;
150   - &:first-child {
151   - display: table-cell;
152   - text-align: center;
153   - }
154   - @media (min-width: 400px) {
155   - border: 1px solid #D9E4E6;
156   - }
157   - }
158   -
159   -#result_table th, td {
160   - margin: .5em 1em;
161   - @media (min-width: 400px) {
162   - display: table-cell;
163   - padding: 1em;
164   - }
165   - }
166   -
167   -#total_row { font-weight: bold; }
168   -.passClass { background-color: #6c6; !important ;}
169   -.failClass { background-color: #c60; !important ;}
170   -.errorClass { background-color: #c00; !important ; }
171   -.passCase { color: #6c6; }
172   -.failCase { color: #c60; font-weight: bold; }
173   -.errorCase { color: #c00; font-weight: bold; }
174   -.skipCase { color:#908e8e; font-weight: bold; }
175   -tr[id^=pt] td { background-color: rgba(73,204,144,.3) !important ; }
176   -tr[id^=ft] td { background-color: rgba(252,161,48,.3) !important; }
177   -tr[id^=et] td { background-color: rgba(249,62,62,.3) !important ; }
178   -tr[id^=st] td { background-color: #6f6f6fa1 !important ; }
179   -.hiddenRow { display: none; }
180   -.testcase { margin-left: 2em; }
181   -
182   -/* -- ending ---------------------------------------------------------------------- */
183   -#ending {
184   -}
185   -
186   -.detail_button {
187   - width: 130px;
188   - text-decoration: none;
189   - line-height: 38px;
190   - text-align: center;
191   - font-weight: bold;
192   - color: #ffff;
193   - border-radius: 6px;
194   - padding: 5px 10px 5px 10px;
195   - position: relative;
196   - overflow: hidden;
197   -}
198   -.detail_button.abstract{background-color: #4dbee8;}
199   -.detail_button.passed{ background-color: #66cc66;}
200   -.detail_button.failed{ background-color: #cc6600;}
201   -.detail_button.errored{ background-color: #f54f4f;}
202   -.detail_button.skiped{ background-color: gray;}
203   -.detail_button.all{ background-color: blue;}
204   -.piechart{
205   - width: 200px;
206   - float: left;
207   - display: inline;
208   -}
209   -
210   -
211   -</style>
212   -
213   -</head>
214   -<body>
215   -<script language="javascript" type="text/javascript">
216   -output_list = Array();
217   -
218   -/* level - 0:Summary; 1:Passed; 2:Failed; 3:Errored; 4:Skiped; 5:All */
219   -function showCase(level,channel) {
220   - trs = document.getElementsByTagName("tr");
221   - for (var i = 0; i < trs.length; i++) {
222   - tr = trs[i];
223   - id = tr.id;
224   - if (["ft","pt","et","st"].indexOf(id.substr(0,2))!=-1){
225   - if ( level ==0 && id.substr(2,1)==channel ) {
226   - tr.className = 'hiddenRow';
227   - }
228   - }
229   -
230   - if (id.substr(0,3) == 'pt'+channel) {
231   - if ( level==1){
232   - tr.className = '';
233   - }
234   - else if (level>4 && id.substr(2,1)==channel ){
235   - tr.className = '';
236   - }
237   - else {
238   - tr.className = 'hiddenRow';
239   - }
240   - }
241   - if (id.substr(0,3) == 'ft'+channel) {
242   - if (level ==2) {
243   - tr.className = '';
244   - }
245   - else if (level>4 && id.substr(2,1)==channel ){
246   - tr.className = '';
247   - }
248   - else {
249   - tr.className = 'hiddenRow';
250   - }
251   - }
252   - if (id.substr(0,3) == 'et'+channel) {
253   - if (level ==3) {
254   - tr.className = '';
255   - }
256   - else if (level>4 && id.substr(2,1)==channel ){
257   - tr.className = '';
258   - }
259   - else {
260   - tr.className = 'hiddenRow';
261   - }
262   - }
263   - if (id.substr(0,3) == 'st'+channel) {
264   - if (level ==4) {
265   - tr.className = '';
266   - }
267   - else if (level>4 && id.substr(2,1)==channel ){
268   - tr.className = '';
269   - }
270   - else {
271   - tr.className = 'hiddenRow';
272   - }
273   - }
274   -
275   - }
276   -}
277   -
278   -
279   -function showClassDetail(cid, count) {
280   - var id_list = Array(count);
281   - var toHide = 1;
282   - for (var i = 0; i < count; i++) {
283   - tid0 = 't' + cid.substr(1) + '.' + (i+1);
284   - tid = 'f' + tid0;
285   - tr = document.getElementById(tid);
286   - if (!tr) {
287   - tid = 'p' + tid0;
288   - tr = document.getElementById(tid);
289   - }
290   - if (!tr) {
291   - tid = 'e' + tid0;
292   - tr = document.getElementById(tid);
293   - }
294   - if (!tr) {
295   - tid = 's' + tid0;
296   - tr = document.getElementById(tid);
297   - }
298   - id_list[i] = tid;
299   - if (tr.className) {
300   - toHide = 0;
301   - }
302   - }
303   - for (var i = 0; i < count; i++) {
304   - tid = id_list[i];
305   - if (toHide) {
306   - document.getElementById(tid).className = 'hiddenRow';
307   - }
308   - else {
309   - document.getElementById(tid).className = '';
310   - }
311   - }
312   -}
313   -
314   -
315   -function showTestDetail(div_id){
316   - var details_div = document.getElementById(div_id)
317   - var displayState = details_div.style.display
318   - // alert(displayState)
319   - if (displayState != 'block' ) {
320   - displayState = 'block'
321   - details_div.style.display = 'block'
322   - }
323   - else {
324   - details_div.style.display = 'none'
325   - }
326   -}
327   -
328   -
329   -function html_escape(s) {
330   - s = s.replace(/&/g,'&amp;');
331   - s = s.replace(/</g,'&lt;');
332   - s = s.replace(/>/g,'&gt;');
333   - return s;
334   -}
335   -
336   -function drawCircle(circle,pass, fail, error){
337   - var color = ["#6c6","#c60","#c00"];
338   - var data = [pass,fail,error];
339   - var text_arr = ["Pass", "Fail", "Error"];
340   -
341   - var canvas = document.getElementById(circle);
342   - var ctx = canvas.getContext("2d");
343   - var startPoint=0;
344   - var width = 20, height = 10;
345   - var posX = 112 * 2 + 20, posY = 30;
346   - var textX = posX + width + 5, textY = posY + 10;
347   - for(var i=0;i<data.length;i++){
348   - ctx.fillStyle = color[i];
349   - ctx.beginPath();
350   - ctx.moveTo(112,84);
351   - ctx.arc(112,84,84,startPoint,startPoint+Math.PI*2*(data[i]/(data[0]+data[1]+data[2])),false);
352   - ctx.fill();
353   - startPoint += Math.PI*2*(data[i]/(data[0]+data[1]+data[2]));
354   - ctx.fillStyle = color[i];
355   - ctx.fillRect(posX, posY + 20 * i, width, height);
356   - ctx.moveTo(posX, posY + 20 * i);
357   - ctx.font = 'bold 14px';
358   - ctx.fillStyle = color[i];
359   - var percent = text_arr[i] + ":"+data[i];
360   - ctx.fillText(percent, textX, textY + 20 * i);
361   -
362   - }
363   -}
364   -
365   -
366   -function show_img(obj) {
367   - var obj1 = obj.nextElementSibling
368   - obj1.style.display='block'
369   - var index = 0;//每张图片的下标,
370   - var len = obj1.getElementsByTagName('img').length;
371   - var imgyuan = obj1.getElementsByClassName('imgyuan')[0]
372   - //var start=setInterval(autoPlay,500);
373   - obj1.onmouseover=function(){//当鼠标光标停在图片上,则停止轮播
374   - clearInterval(start);
375   - }
376   - obj1.onmouseout=function(){//当鼠标光标停在图片上,则开始轮播
377   - start=setInterval(autoPlay,1000);
378   - }
379   - for (var i = 0; i < len; i++) {
380   - var font = document.createElement('font')
381   - imgyuan.appendChild(font)
382   - }
383   - var lis = obj1.getElementsByTagName('font');//得到所有圆圈
384   - changeImg(0)
385   - var funny = function (i) {
386   - lis[i].onmouseover = function () {
387   - index=i
388   - changeImg(i)
389   - }
390   - }
391   - for (var i = 0; i < lis.length; i++) {
392   - funny(i);
393   - }
394   -
395   - function autoPlay(){
396   - if(index>len-1){
397   - index=0;
398   - clearInterval(start); //运行一轮后停止
399   - }
400   - changeImg(index++);
401   - }
402   - imgyuan.style.width= 25*len +"px";
403   - //对应圆圈和图片同步
404   - function changeImg(index) {
405   - var list = obj1.getElementsByTagName('img');
406   - var list1 = obj1.getElementsByTagName('font');
407   - for (i = 0; i < list.length; i++) {
408   - list[i].style.display = 'none';
409   - list1[i].style.backgroundColor = 'white';
410   - }
411   - list[index].style.display = 'block';
412   - list1[index].style.backgroundColor = 'blue';
413   - }
414   -
415   -}
416   -function hide_img(obj){
417   - obj.parentElement.style.display = "none";
418   - obj.parentElement.getElementsByClassName('imgyuan')[0].innerHTML = "";
419   -}
420   -</script>
421   -<div class='heading'>
422   -<h1>重构项目接口测试报告</h1>
423   -<p class='attribute'><strong>开始时间:</strong> 2021-07-13 17:43:09</p>
424   -<p class='attribute'><strong>耗时:</strong> 0:00:07.141812</p>
425   -<p class='attribute'><strong>状态:</strong> <span class="tj errorCase">Error</span>:1 <span class="tj skipCase">Skip</span>:19 <span class="tj">通过率</span>:0.0%</p>
426   -
427   -<p class='description'>用例简要执行情况如下:(注:报告详细信息需要下载report.html并用浏览器打开)</p>
428   -</div>
429   -
430   -
431   -<div class="piechart">
432   - <div>
433   - <canvas id="circle1" width="350" height="168" </canvas>
434   - </div>
435   -</div>
436   -
437   -<div id='show_detail_line' style=" float: left; width: 100%;">
438   -<a class="abstract detail_button" href='javascript:showCase(0,1)'>概要[0.00%]</a>
439   -<a class="passed detail_button" href='javascript:showCase(1,1)'>通过[0]</a>
440   -<a class="failed detail_button" href='javascript:showCase(2,1)'>失败[0]</a>
441   -<a class="errored detail_button" href='javascript:showCase(3,1)'>错误[1]</a>
442   -<a class="skiped detail_button" href='javascript:showCase(4,1)'>跳过[19]</a>
443   -<a class="all detail_button" href='javascript:showCase(5,1)'>所有[1]</a>
444   -</div>
445   -
446   -<table id='result_table'>
447   -<colgroup>
448   -<col align='left' />
449   -<col align='right' />
450   -<col align='right' />
451   -<col align='right' />
452   -<col align='right' />
453   -<col align='right' />
454   -<col align='right' />
455   -</colgroup>
456   -<tr id='header_row'>
457   - <th>测试组/测试用例</th>
458   - <th>总数</th>
459   - <th>通过</th>
460   - <th>失败</th>
461   - <th>错误</th>
462   - <th>视图</th>
463   - <th>错误截图</th>
464   -</tr>
465   -
466   -<tr class='errorClass'>
467   - <td>doAdd.test_doAdd.test_doAdd: 新增登记接口</td>
468   - <td>1</td>
469   - <td>0</td>
470   - <td>0</td>
471   - <td>1</td>
472   - <td><a href="javascript:showClassDetail('c1.1',1)">详情</a></td>
473   - <td>&nbsp;</td>
474   -</tr>
475   -
476   -<tr id='et1.1.1' class='none'>
477   - <td ><div class='testcase'>test_doAdd_01: 成功新增一个商品为大白菜的报备单,重量为111</div></td>
478   - <td colspan='5' align='center'>
479   -
480   - <!--css div popup start-->
481   - <span class='status errorCase'>
482   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_et1.1.1')" >
483   - 错误</a></span>
484   -
485   - <div id='div_et1.1.1' class="popup_window">
486   - <div style='text-align: right; color:red;cursor:pointer'>
487   - <a onfocus='this.blur();' onclick="document.getElementById('div_et1.1.1').style.display = 'none' " >
488   - [x]</a>
489   - </div>
490   - <pre>
491   -
492   -et1.1.1: Traceback (most recent call last):
493   - File "C:\Python367\lib\site-packages\urllib3\connectionpool.py", line 421, in _make_request
494   - six.raise_from(e, None)
495   - File "&lt;string&gt;", line 3, in raise_from
496   - File "C:\Python367\lib\site-packages\urllib3\connectionpool.py", line 416, in _make_request
497   - httplib_response = conn.getresponse()
498   - File "C:\Python367\lib\http\client.py", line 1331, in getresponse
499   - response.begin()
500   - File "C:\Python367\lib\http\client.py", line 297, in begin
501   - version, status, reason = self._read_status()
502   - File "C:\Python367\lib\http\client.py", line 258, in _read_status
503   - line = str(self.fp.readline(_MAXLINE + 1), "iso-8859-1")
504   - File "C:\Python367\lib\socket.py", line 586, in readinto
505   - return self._sock.recv_into(b)
506   -socket.timeout: timed out
507   -
508   -During handling of the above exception, another exception occurred:
509   -
510   -Traceback (most recent call last):
511   - File "C:\Python367\lib\site-packages\requests\adapters.py", line 449, in send
512   - timeout=timeout
513   - File "C:\Python367\lib\site-packages\urllib3\connectionpool.py", line 720, in urlopen
514   - method, url, error=e, _pool=self, _stacktrace=sys.exc_info()[2]
515   - File "C:\Python367\lib\site-packages\urllib3\util\retry.py", line 400, in increment
516   - raise six.reraise(type(error), error, _stacktrace)
517   - File "C:\Python367\lib\site-packages\urllib3\packages\six.py", line 735, in reraise
518   - raise value
519   - File "C:\Python367\lib\site-packages\urllib3\connectionpool.py", line 672, in urlopen
520   - chunked=chunked,
521   - File "C:\Python367\lib\site-packages\urllib3\connectionpool.py", line 423, in _make_request
522   - self._raise_timeout(err=e, url=url, timeout_value=read_timeout)
523   - File "C:\Python367\lib\site-packages\urllib3\connectionpool.py", line 331, in _raise_timeout
524   - self, url, "Read timed out. (read timeout=%s)" % timeout_value
525   -urllib3.exceptions.ReadTimeoutError: HTTPConnectionPool(host='test.trace.diligrp.com', port=8393): Read timed out. (read timeout=5)
526   -
527   -During handling of the above exception, another exception occurred:
528   -
529   -Traceback (most recent call last):
530   - File "E:\EclipseWorkspace\WorksapceDemo\Request-demo-dili\src\testcase\doAdd\test_doAdd.py", line 26, in test_doAdd_01
531   - re=my.post(url=do.url,headers=do.header,json=do.body)
532   - File "E:\EclipseWorkspace\WorksapceDemo\Request-demo-dili\src\commons\MySession.py", line 100, in post
533   - re=self.se.post(url, data=data, json=json,proxies=self.proxies, **kwargs,timeout=self.timeout)
534   - File "C:\Python367\lib\site-packages\requests\sessions.py", line 590, in post
535   - return self.request('POST', url, data=data, json=json, **kwargs)
536   - File "C:\Python367\lib\site-packages\requests\sessions.py", line 542, in request
537   - resp = self.send(prep, **send_kwargs)
538   - File "C:\Python367\lib\site-packages\requests\sessions.py", line 655, in send
539   - r = adapter.send(request, **kwargs)
540   - File "C:\Python367\lib\site-packages\requests\adapters.py", line 529, in send
541   - raise ReadTimeout(e, request=request)
542   -requests.exceptions.ReadTimeout: HTTPConnectionPool(host='test.trace.diligrp.com', port=8393): Read timed out. (read timeout=5)
543   -
544   -
545   - </pre>
546   - </div>
547   - <!--css div popup end-->
548   -
549   - </td>
550   - <td>无截图</td>
551   -</tr>
552   -
553   -<tr id='st1.1.2' class='none'>
554   - <td ><div class='testcase'>test_doAdd_02: 成功新增一个商品为鲜花生的报备单,重量为111</div></td>
555   - <td colspan='5' align='center'>
556   -
557   - <!--css div popup start-->
558   - <span class='status passCase'>
559   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.1.2')" >
560   - 跳过</a></span>
561   -
562   - <div id='div_st1.1.2' class="popup_window">
563   - <div style='text-align: right; color:red;cursor:pointer'>
564   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.1.2').style.display = 'none' " >
565   - [x]</a>
566   - </div>
567   - <pre>
568   -
569   -st1.1.2: mark_skip
570   -
571   - </pre>
572   - </div>
573   - <!--css div popup end-->
574   -
575   - </td>
576   - <td>无截图</td>
577   -</tr>
578   -
579   -<tr id='st1.1.3' class='none'>
580   - <td ><div class='testcase'>test_doAdd_03: 用错误的用户来新增,无法新增</div></td>
581   - <td colspan='5' align='center'>
582   -
583   - <!--css div popup start-->
584   - <span class='status passCase'>
585   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.1.3')" >
586   - 跳过</a></span>
587   -
588   - <div id='div_st1.1.3' class="popup_window">
589   - <div style='text-align: right; color:red;cursor:pointer'>
590   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.1.3').style.display = 'none' " >
591   - [x]</a>
592   - </div>
593   - <pre>
594   -
595   -st1.1.3: mark_skip
596   -
597   - </pre>
598   - </div>
599   - <!--css div popup end-->
600   -
601   - </td>
602   - <td>无截图</td>
603   -</tr>
604   -
605   -<tr id='st1.1.4' class='none'>
606   - <td ><div class='testcase'>test_doAdd_04: 成功新增一个商品为大白菜的报备单,重量为666</div></td>
607   - <td colspan='5' align='center'>
608   -
609   - <!--css div popup start-->
610   - <span class='status passCase'>
611   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.1.4')" >
612   - 跳过</a></span>
613   -
614   - <div id='div_st1.1.4' class="popup_window">
615   - <div style='text-align: right; color:red;cursor:pointer'>
616   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.1.4').style.display = 'none' " >
617   - [x]</a>
618   - </div>
619   - <pre>
620   -
621   -st1.1.4: mark_skip
622   -
623   - </pre>
624   - </div>
625   - <!--css div popup end-->
626   -
627   - </td>
628   - <td>无截图</td>
629   -</tr>
630   -
631   -<tr class='passClass'>
632   - <td>doAudit.test_doAudit.test_doAudit: 登记单审核接口</td>
633   - <td>0</td>
634   - <td>0</td>
635   - <td>0</td>
636   - <td>0</td>
637   - <td><a href="javascript:showClassDetail('c1.2',0)">详情</a></td>
638   - <td>&nbsp;</td>
639   -</tr>
640   -
641   -<tr id='st1.2.1' class='none'>
642   - <td ><div class='testcase'>test_doAudit_01: 审核通过</div></td>
643   - <td colspan='5' align='center'>
644   -
645   - <!--css div popup start-->
646   - <span class='status passCase'>
647   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.2.1')" >
648   - 跳过</a></span>
649   -
650   - <div id='div_st1.2.1' class="popup_window">
651   - <div style='text-align: right; color:red;cursor:pointer'>
652   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.2.1').style.display = 'none' " >
653   - [x]</a>
654   - </div>
655   - <pre>
656   -
657   -st1.2.1: mark_skip
658   -
659   - </pre>
660   - </div>
661   - <!--css div popup end-->
662   -
663   - </td>
664   - <td>无截图</td>
665   -</tr>
666   -
667   -<tr id='st1.2.2' class='none'>
668   - <td ><div class='testcase'>test_doAudit_02: 审核不通过</div></td>
669   - <td colspan='5' align='center'>
670   -
671   - <!--css div popup start-->
672   - <span class='status passCase'>
673   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.2.2')" >
674   - 跳过</a></span>
675   -
676   - <div id='div_st1.2.2' class="popup_window">
677   - <div style='text-align: right; color:red;cursor:pointer'>
678   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.2.2').style.display = 'none' " >
679   - [x]</a>
680   - </div>
681   - <pre>
682   -
683   -st1.2.2: mark_skip
684   -
685   - </pre>
686   - </div>
687   - <!--css div popup end-->
688   -
689   - </td>
690   - <td>无截图</td>
691   -</tr>
692   -
693   -<tr id='st1.2.3' class='none'>
694   - <td ><div class='testcase'>test_doAudit_03: 审核不通过</div></td>
695   - <td colspan='5' align='center'>
696   -
697   - <!--css div popup start-->
698   - <span class='status passCase'>
699   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.2.3')" >
700   - 跳过</a></span>
701   -
702   - <div id='div_st1.2.3' class="popup_window">
703   - <div style='text-align: right; color:red;cursor:pointer'>
704   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.2.3').style.display = 'none' " >
705   - [x]</a>
706   - </div>
707   - <pre>
708   -
709   -st1.2.3: mark_skip
710   -
711   - </pre>
712   - </div>
713   - <!--css div popup end-->
714   -
715   - </td>
716   - <td>无截图</td>
717   -</tr>
718   -
719   -<tr id='st1.2.4' class='none'>
720   - <td ><div class='testcase'>test_doAudit_04: 审核一个已经完成审核的登记单</div></td>
721   - <td colspan='5' align='center'>
722   -
723   - <!--css div popup start-->
724   - <span class='status passCase'>
725   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.2.4')" >
726   - 跳过</a></span>
727   -
728   - <div id='div_st1.2.4' class="popup_window">
729   - <div style='text-align: right; color:red;cursor:pointer'>
730   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.2.4').style.display = 'none' " >
731   - [x]</a>
732   - </div>
733   - <pre>
734   -
735   -st1.2.4: mark_skip
736   -
737   - </pre>
738   - </div>
739   - <!--css div popup end-->
740   -
741   - </td>
742   - <td>无截图</td>
743   -</tr>
744   -
745   -<tr class='passClass'>
746   - <td>doUndo.test_doUndo.test_doUndo: 登记单撤销接口</td>
747   - <td>0</td>
748   - <td>0</td>
749   - <td>0</td>
750   - <td>0</td>
751   - <td><a href="javascript:showClassDetail('c1.3',0)">详情</a></td>
752   - <td>&nbsp;</td>
753   -</tr>
754   -
755   -<tr id='st1.3.1' class='none'>
756   - <td ><div class='testcase'>test_doUndo_01: 成功删除新增的一个报备单</div></td>
757   - <td colspan='5' align='center'>
758   -
759   - <!--css div popup start-->
760   - <span class='status passCase'>
761   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.3.1')" >
762   - 跳过</a></span>
763   -
764   - <div id='div_st1.3.1' class="popup_window">
765   - <div style='text-align: right; color:red;cursor:pointer'>
766   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.3.1').style.display = 'none' " >
767   - [x]</a>
768   - </div>
769   - <pre>
770   -
771   -st1.3.1: mark_skip
772   -
773   - </pre>
774   - </div>
775   - <!--css div popup end-->
776   -
777   - </td>
778   - <td>无截图</td>
779   -</tr>
780   -
781   -<tr class='passClass'>
782   - <td>fieldConfig.test_fieldConfig.test_fieldConfig: Unittest用例结构的简单的认识</td>
783   - <td>0</td>
784   - <td>0</td>
785   - <td>0</td>
786   - <td>0</td>
787   - <td><a href="javascript:showClassDetail('c1.4',0)">详情</a></td>
788   - <td>&nbsp;</td>
789   -</tr>
790   -
791   -<tr id='st1.4.1' class='none'>
792   - <td ><div class='testcase'>test_fieldConfig_01: demo</div></td>
793   - <td colspan='5' align='center'>
794   -
795   - <!--css div popup start-->
796   - <span class='status passCase'>
797   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.4.1')" >
798   - 跳过</a></span>
799   -
800   - <div id='div_st1.4.1' class="popup_window">
801   - <div style='text-align: right; color:red;cursor:pointer'>
802   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.4.1').style.display = 'none' " >
803   - [x]</a>
804   - </div>
805   - <pre>
806   -
807   -st1.4.1: mark_skip
808   -
809   - </pre>
810   - </div>
811   - <!--css div popup end-->
812   -
813   - </td>
814   - <td>无截图</td>
815   -</tr>
816   -
817   -<tr id='st1.4.2' class='none'>
818   - <td ><div class='testcase'>test_fieldConfig_02: demo</div></td>
819   - <td colspan='5' align='center'>
820   -
821   - <!--css div popup start-->
822   - <span class='status passCase'>
823   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.4.2')" >
824   - 跳过</a></span>
825   -
826   - <div id='div_st1.4.2' class="popup_window">
827   - <div style='text-align: right; color:red;cursor:pointer'>
828   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.4.2').style.display = 'none' " >
829   - [x]</a>
830   - </div>
831   - <pre>
832   -
833   -st1.4.2: mark_skip
834   -
835   - </pre>
836   - </div>
837   - <!--css div popup end-->
838   -
839   - </td>
840   - <td>无截图</td>
841   -</tr>
842   -
843   -<tr id='st1.4.3' class='none'>
844   - <td ><div class='testcase'>test_fieldConfig_03: demo</div></td>
845   - <td colspan='5' align='center'>
846   -
847   - <!--css div popup start-->
848   - <span class='status passCase'>
849   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.4.3')" >
850   - 跳过</a></span>
851   -
852   - <div id='div_st1.4.3' class="popup_window">
853   - <div style='text-align: right; color:red;cursor:pointer'>
854   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.4.3').style.display = 'none' " >
855   - [x]</a>
856   - </div>
857   - <pre>
858   -
859   -st1.4.3: mark_skip
860   -
861   - </pre>
862   - </div>
863   - <!--css div popup end-->
864   -
865   - </td>
866   - <td>无截图</td>
867   -</tr>
868   -
869   -<tr id='st1.4.4' class='none'>
870   - <td ><div class='testcase'>test_fieldConfig_04</div></td>
871   - <td colspan='5' align='center'>
872   -
873   - <!--css div popup start-->
874   - <span class='status passCase'>
875   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.4.4')" >
876   - 跳过</a></span>
877   -
878   - <div id='div_st1.4.4' class="popup_window">
879   - <div style='text-align: right; color:red;cursor:pointer'>
880   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.4.4').style.display = 'none' " >
881   - [x]</a>
882   - </div>
883   - <pre>
884   -
885   -st1.4.4: 执行时强制跳过该用例
886   -
887   - </pre>
888   - </div>
889   - <!--css div popup end-->
890   -
891   - </td>
892   - <td>无截图</td>
893   -</tr>
894   -
895   -<tr class='passClass'>
896   - <td>login.test_login.test_login: 登录接口</td>
897   - <td>0</td>
898   - <td>0</td>
899   - <td>0</td>
900   - <td>0</td>
901   - <td><a href="javascript:showClassDetail('c1.5',0)">详情</a></td>
902   - <td>&nbsp;</td>
903   -</tr>
904   -
905   -<tr id='st1.5.1' class='none'>
906   - <td ><div class='testcase'>test_login_01: 账户密码都正确</div></td>
907   - <td colspan='5' align='center'>
908   -
909   - <!--css div popup start-->
910   - <span class='status passCase'>
911   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.5.1')" >
912   - 跳过</a></span>
913   -
914   - <div id='div_st1.5.1' class="popup_window">
915   - <div style='text-align: right; color:red;cursor:pointer'>
916   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.5.1').style.display = 'none' " >
917   - [x]</a>
918   - </div>
919   - <pre>
920   -
921   -st1.5.1: mark_skip
922   -
923   - </pre>
924   - </div>
925   - <!--css div popup end-->
926   -
927   - </td>
928   - <td>无截图</td>
929   -</tr>
930   -
931   -<tr id='st1.5.2' class='none'>
932   - <td ><div class='testcase'>test_login_02: 密码错误</div></td>
933   - <td colspan='5' align='center'>
934   -
935   - <!--css div popup start-->
936   - <span class='status passCase'>
937   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.5.2')" >
938   - 跳过</a></span>
939   -
940   - <div id='div_st1.5.2' class="popup_window">
941   - <div style='text-align: right; color:red;cursor:pointer'>
942   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.5.2').style.display = 'none' " >
943   - [x]</a>
944   - </div>
945   - <pre>
946   -
947   -st1.5.2: mark_skip
948   -
949   - </pre>
950   - </div>
951   - <!--css div popup end-->
952   -
953   - </td>
954   - <td>无截图</td>
955   -</tr>
956   -
957   -<tr id='st1.5.3' class='none'>
958   - <td ><div class='testcase'>test_login_03: 账户错误</div></td>
959   - <td colspan='5' align='center'>
960   -
961   - <!--css div popup start-->
962   - <span class='status passCase'>
963   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.5.3')" >
964   - 跳过</a></span>
965   -
966   - <div id='div_st1.5.3' class="popup_window">
967   - <div style='text-align: right; color:red;cursor:pointer'>
968   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.5.3').style.display = 'none' " >
969   - [x]</a>
970   - </div>
971   - <pre>
972   -
973   -st1.5.3: mark_skip
974   -
975   - </pre>
976   - </div>
977   - <!--css div popup end-->
978   -
979   - </td>
980   - <td>无截图</td>
981   -</tr>
982   -
983   -<tr id='st1.5.4' class='none'>
984   - <td ><div class='testcase'>test_login_04: 账户错误</div></td>
985   - <td colspan='5' align='center'>
986   -
987   - <!--css div popup start-->
988   - <span class='status passCase'>
989   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.5.4')" >
990   - 跳过</a></span>
991   -
992   - <div id='div_st1.5.4' class="popup_window">
993   - <div style='text-align: right; color:red;cursor:pointer'>
994   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.5.4').style.display = 'none' " >
995   - [x]</a>
996   - </div>
997   - <pre>
998   -
999   -st1.5.4: mark_skip
1000   -
1001   - </pre>
1002   - </div>
1003   - <!--css div popup end-->
1004   -
1005   - </td>
1006   - <td>无截图</td>
1007   -</tr>
1008   -
1009   -<tr class='passClass'>
1010   - <td>logout.test_logout.test_logout: 新增登记接口</td>
1011   - <td>0</td>
1012   - <td>0</td>
1013   - <td>0</td>
1014   - <td>0</td>
1015   - <td><a href="javascript:showClassDetail('c1.6',0)">详情</a></td>
1016   - <td>&nbsp;</td>
1017   -</tr>
1018   -
1019   -<tr id='st1.6.1' class='none'>
1020   - <td ><div class='testcase'>test_logout_01: 成功登出账户</div></td>
1021   - <td colspan='5' align='center'>
1022   -
1023   - <!--css div popup start-->
1024   - <span class='status passCase'>
1025   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.6.1')" >
1026   - 跳过</a></span>
1027   -
1028   - <div id='div_st1.6.1' class="popup_window">
1029   - <div style='text-align: right; color:red;cursor:pointer'>
1030   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.6.1').style.display = 'none' " >
1031   - [x]</a>
1032   - </div>
1033   - <pre>
1034   -
1035   -st1.6.1: mark_skip
1036   -
1037   - </pre>
1038   - </div>
1039   - <!--css div popup end-->
1040   -
1041   - </td>
1042   - <td>无截图</td>
1043   -</tr>
1044   -
1045   -<tr class='passClass'>
1046   - <td>upStream.test_upStream.test_upStream: 上游企业列表查询接口</td>
1047   - <td>0</td>
1048   - <td>0</td>
1049   - <td>0</td>
1050   - <td>0</td>
1051   - <td><a href="javascript:showClassDetail('c1.7',0)">详情</a></td>
1052   - <td>&nbsp;</td>
1053   -</tr>
1054   -
1055   -<tr id='st1.7.1' class='none'>
1056   - <td ><div class='testcase'>test_upStream_01: 成功查询上下游企业,无过滤条件</div></td>
1057   - <td colspan='5' align='center'>
1058   -
1059   - <!--css div popup start-->
1060   - <span class='status passCase'>
1061   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.7.1')" >
1062   - 跳过</a></span>
1063   -
1064   - <div id='div_st1.7.1' class="popup_window">
1065   - <div style='text-align: right; color:red;cursor:pointer'>
1066   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.7.1').style.display = 'none' " >
1067   - [x]</a>
1068   - </div>
1069   - <pre>
1070   -
1071   -st1.7.1: mark_skip
1072   -
1073   - </pre>
1074   - </div>
1075   - <!--css div popup end-->
1076   -
1077   - </td>
1078   - <td>无截图</td>
1079   -</tr>
1080   -
1081   -<tr id='st1.7.2' class='none'>
1082   - <td ><div class='testcase'>test_upStream_02: 成功查询上下游企业,加入企业/个人名称过滤条件</div></td>
1083   - <td colspan='5' align='center'>
1084   -
1085   - <!--css div popup start-->
1086   - <span class='status passCase'>
1087   - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_st1.7.2')" >
1088   - 跳过</a></span>
1089   -
1090   - <div id='div_st1.7.2' class="popup_window">
1091   - <div style='text-align: right; color:red;cursor:pointer'>
1092   - <a onfocus='this.blur();' onclick="document.getElementById('div_st1.7.2').style.display = 'none' " >
1093   - [x]</a>
1094   - </div>
1095   - <pre>
1096   -
1097   -st1.7.2: mark_skip
1098   -
1099   - </pre>
1100   - </div>
1101   - <!--css div popup end-->
1102   -
1103   - </td>
1104   - <td>无截图</td>
1105   -</tr>
1106   -
1107   -<tr id='total_row'>
1108   - <th>统计</th>
1109   - <th>1</th>
1110   - <th>0</th>
1111   - <th>0</th>
1112   - <th>1</th>
1113   - <th>&nbsp;</th>
1114   - <th>&nbsp;</th>
1115   -</tr>
1116   -</table>
1117   -<script>
1118   - showCase(0,1);
1119   - drawCircle('circle1',0, 0, 1);
1120   -</script>
1121   -
1122   -<div id='ending'>&nbsp;</div>
1123   -
1124   -</body>
1125   -</html>
src/report/__init__.py deleted 100644 → 0
src/report/test.log deleted 100644 → 0
1   -[2021-07-13 17:43:09] [INFO] : ======================================================================================
2   -[2021-07-13 17:43:09] [INFO] : http://test.trace.diligrp.com:8393/fieldConfig/doUpdate.action
3   -None
4   -{'moduleType': '1', 'marketId': '8', 'fieldConfigDetailList': [{'fieldName': 'unitPrice', 'jsonPath': '$.unitPrice', 'defaultId': '3', 'displayed': '1', 'required': '0'}, {'fieldName': 'arrivalTallynos', 'jsonPath': '$.arrivalTallynos', 'defaultId': '10', 'displayed': '1', 'required': '0'}, {'fieldName': 'brandName', 'jsonPath': '$.brandName', 'defaultId': '5', 'displayed': '1', 'required': '0'}, {'fieldName': 'truckTareWeight', 'jsonPath': '$.truckTareWeight', 'defaultId': '1', 'displayed': '1', 'required': '0'}, {'fieldName': 'originId', 'jsonPath': '$.originId', 'defaultId': '7', 'displayed': '1', 'required': '0'}, {'fieldName': 'specName', 'jsonPath': '$.specName', 'defaultId': '4', 'displayed': '1', 'required': '0'}, {'fieldName': 'truckType', 'jsonPath': '$.truckType', 'defaultId': '2', 'displayed': '1', 'required': '1', 'availableValueList': ['10', '20']}, {'fieldName': 'imageCertList', 'jsonPath': '$.imageCertList[*]certType', 'defaultId': '11', 'displayed': '1', 'required': '0', 'availableValueList': ['2', '3']}, {'fieldName': 'arrivalDatetime', 'jsonPath': '$.arrivalDatetime', 'defaultId': '9', 'displayed': '1', 'required': '0'}, {'fieldName': 'remark', 'jsonPath': '$.remark', 'defaultId': '8', 'displayed': '1', 'required': '0'}, {'fieldName': 'remark', 'jsonPath': '$.remark', 'defaultId': '6', 'displayed': '1', 'required': '0'}, {'fieldName': 'measureType', 'jsonPath': '$.measureType', 'defaultId': '12', 'displayed': '1', 'required': '1', 'availableValueList': ['10', '20']}]}
5   -{'headers': {'Host': 'test.trace.diligrp.com:8393', 'Connection': 'keep-alive', 'Content-Length': '1378', 'Accept': 'application/json,text/javascript,*/*;q=0.01', 'X-Requested-With': 'XMLHttpRequest', 'User-Agent': 'Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/91.0.4472.77Safari/537.36', 'Content-Type': 'application/json', 'Origin': 'http://test.trace.diligrp.com:8393', 'Referer': 'http://test.trace.diligrp.com:8393/fieldConfig/bill.html', 'Accept-Encoding': 'gzip,deflate', 'Accept-Language': 'zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7'}}
6   -[2021-07-13 17:43:10] [INFO] : ======================================================================================
7   -[2021-07-13 17:43:10] [INFO] : http://test.trace.diligrp.com:8393/newRegisterBill/doAdd.action
8   -None
9   -{'registerHeadWeight': '0', 'registerHeadRemainWeight': '0', 'imageCertList': [], 'measureType': 20, 'registType': 10, 'userId': 516, 'arrivalTallynos': [], 'arrivalDatetime': '', 'truckType': 10, 'weight': '111', 'weightUnit': 1, 'productName': '大白菜', 'productId': 2190, 'originName': '', 'originId': '', 'unitPrice': '', 'truckTareWeight': '', 'remark': '', 'specName': '', 'brandName': '', 'plate': '川A123456'}
10   -{'headers': {'Host': 'test.trace.diligrp.com', 'Connection': 'keep-alive', 'Content-Length': '325', 'Accept': 'application/json,text/javascript,*/*;q=0.01', 'User-Agent': 'Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.212Safari/537.36', 'Content-Type': 'application/json', 'Origin': 'http://test.trace.diligrp.com:8393', 'Referer': 'http://test.trace.diligrp.com:8393/newRegisterBill/add.html', 'Accept-Encoding': 'gzip,deflate', 'Accept-Language': 'zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7'}}
11   -[2021-07-13 17:43:15] [INFO] : ======================================================================================
12   -[2021-07-13 17:43:15] [INFO] : http://test.trace.diligrp.com:8393/fieldConfig/doUpdate.action
13   -None
14   -{'moduleType': '1', 'marketId': '8', 'fieldConfigDetailList': [{'fieldName': 'unitPrice', 'jsonPath': '$.unitPrice', 'defaultId': '3', 'displayed': '1', 'required': '0'}, {'fieldName': 'arrivalTallynos', 'jsonPath': '$.arrivalTallynos', 'defaultId': '10', 'displayed': '1', 'required': '0'}, {'fieldName': 'brandName', 'jsonPath': '$.brandName', 'defaultId': '5', 'displayed': '1', 'required': '0'}, {'fieldName': 'truckTareWeight', 'jsonPath': '$.truckTareWeight', 'defaultId': '1', 'displayed': '1', 'required': '0'}, {'fieldName': 'originId', 'jsonPath': '$.originId', 'defaultId': '7', 'displayed': '1', 'required': '0'}, {'fieldName': 'specName', 'jsonPath': '$.specName', 'defaultId': '4', 'displayed': '1', 'required': '0'}, {'fieldName': 'truckType', 'jsonPath': '$.truckType', 'defaultId': '2', 'displayed': '1', 'required': '1', 'availableValueList': ['10', '20']}, {'fieldName': 'imageCertList', 'jsonPath': '$.imageCertList[*]certType', 'defaultId': '11', 'displayed': '1', 'required': '0', 'availableValueList': ['2', '3']}, {'fieldName': 'arrivalDatetime', 'jsonPath': '$.arrivalDatetime', 'defaultId': '9', 'displayed': '1', 'required': '0'}, {'fieldName': 'remark', 'jsonPath': '$.remark', 'defaultId': '8', 'displayed': '1', 'required': '0'}, {'fieldName': 'remark', 'jsonPath': '$.remark', 'defaultId': '6', 'displayed': '1', 'required': '0'}, {'fieldName': 'measureType', 'jsonPath': '$.measureType', 'defaultId': '12', 'displayed': '1', 'required': '1', 'availableValueList': ['10', '20']}]}
15   -{'headers': {'Host': 'test.trace.diligrp.com:8393', 'Connection': 'keep-alive', 'Content-Length': '1378', 'Accept': 'application/json,text/javascript,*/*;q=0.01', 'X-Requested-With': 'XMLHttpRequest', 'User-Agent': 'Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/91.0.4472.77Safari/537.36', 'Content-Type': 'application/json', 'Origin': 'http://test.trace.diligrp.com:8393', 'Referer': 'http://test.trace.diligrp.com:8393/fieldConfig/bill.html', 'Accept-Encoding': 'gzip,deflate', 'Accept-Language': 'zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7'}}
16   -[2021-07-13 17:43:15] [INFO] : ======================================================================================
17   -[2021-07-13 17:43:15] [INFO] : http://test.trace.diligrp.com:8393/fieldConfig/doUpdate.action
18   -None
19   -{'moduleType': '1', 'marketId': '8', 'fieldConfigDetailList': [{'fieldName': 'unitPrice', 'jsonPath': '$.unitPrice', 'defaultId': '3', 'displayed': '1', 'required': '0'}, {'fieldName': 'arrivalTallynos', 'jsonPath': '$.arrivalTallynos', 'defaultId': '10', 'displayed': '1', 'required': '0'}, {'fieldName': 'brandName', 'jsonPath': '$.brandName', 'defaultId': '5', 'displayed': '1', 'required': '0'}, {'fieldName': 'truckTareWeight', 'jsonPath': '$.truckTareWeight', 'defaultId': '1', 'displayed': '1', 'required': '0'}, {'fieldName': 'originId', 'jsonPath': '$.originId', 'defaultId': '7', 'displayed': '1', 'required': '0'}, {'fieldName': 'specName', 'jsonPath': '$.specName', 'defaultId': '4', 'displayed': '1', 'required': '0'}, {'fieldName': 'truckType', 'jsonPath': '$.truckType', 'defaultId': '2', 'displayed': '1', 'required': '1', 'availableValueList': ['10', '20']}, {'fieldName': 'imageCertList', 'jsonPath': '$.imageCertList[*]certType', 'defaultId': '11', 'displayed': '1', 'required': '0', 'availableValueList': ['2', '3']}, {'fieldName': 'arrivalDatetime', 'jsonPath': '$.arrivalDatetime', 'defaultId': '9', 'displayed': '1', 'required': '0'}, {'fieldName': 'remark', 'jsonPath': '$.remark', 'defaultId': '8', 'displayed': '1', 'required': '0'}, {'fieldName': 'remark', 'jsonPath': '$.remark', 'defaultId': '6', 'displayed': '1', 'required': '0'}, {'fieldName': 'measureType', 'jsonPath': '$.measureType', 'defaultId': '12', 'displayed': '1', 'required': '1', 'availableValueList': ['10', '20']}]}
20   -{'headers': {'Host': 'test.trace.diligrp.com:8393', 'Connection': 'keep-alive', 'Content-Length': '1378', 'Accept': 'application/json,text/javascript,*/*;q=0.01', 'X-Requested-With': 'XMLHttpRequest', 'User-Agent': 'Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/91.0.4472.77Safari/537.36', 'Content-Type': 'application/json', 'Origin': 'http://test.trace.diligrp.com:8393', 'Referer': 'http://test.trace.diligrp.com:8393/fieldConfig/bill.html', 'Accept-Encoding': 'gzip,deflate', 'Accept-Language': 'zh-CN,zh-TW;q=0.9,zh;q=0.8,en;q=0.7'}}
21   -[2021-07-13 17:43:16] [INFO] : 发送邮件
22   -[2021-07-13 17:43:19] [INFO] : 邮件发送完毕
src/testcase/.gitignore deleted 100644 → 0
1   -/__init__.pyc
src/testcase/__init__.py deleted 100644 → 0
1   -# -*- coding:utf-8 -*-
2   -import binascii
3   -import base64
4   -import requests,json
5   -import time
6   -# import sys
7   -# reload(sys)
8   -# sys.setdefaultencoding('utf8')
9 0 \ No newline at end of file
src/testcase/doAdd/.gitignore deleted 100644 → 0
1   -/__init__.pyc
src/testcase/doAdd/__init__.py deleted 100644 → 0
1   -# -*- coding:utf-8 -*-
2   -import binascii
3   -import base64
4   -import requests,json
5   -import time
6   -# import sys
7   -# reload(sys)
8   -# sys.setdefaultencoding('utf8')
9 0 \ No newline at end of file
src/testcase/doAdd/test_doAdd.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import unittest
4   -import urllib3
5   -from commons import common as com
6   -from commons.MySession import my
7   -from commons.api.fieldConfig import fieldConfig
8   -from commons.api.doAdd import doAdd
9   -urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
10   -do=doAdd()
11   -field=fieldConfig()
12   -
13   -
14   -class test_doAdd(unittest.TestCase):
15   - "新增登记接口"
16   -
17   - @classmethod
18   - def setUpClass(cls):
19   - #通过字段配置接口提前配置新增页的字段配置
20   - my.post(url=field.url,headers=field.header,json=field.body)
21   -
22   - @unittest.case_mark(my.mark("test"))
23   - def test_doAdd_01(self):
24   - "成功新增一个商品为大白菜的报备单,重量为111"
25   - #请求数据不需要修改,直接POST请求
26   - re=my.post(url=do.url,headers=do.header,json=do.body)
27   - print(re.json())
28   - #响应断言
29   - self.assertEqual(re.status_code, 200)
30   - self.assertTrue("'code':'200'" in str(re.json()).replace(" ",""))
31   -
32   -
33   - @unittest.case_mark(my.mark())
34   - def test_doAdd_02(self):
35   - "成功新增一个商品为鲜花生的报备单,重量为111"
36   - #请求数据需要修改
37   - body=do.body.copy()
38   - body["productName"]="鲜花生"
39   - body["productId"]="3496"
40   - #POST请求
41   - re=my.post(url=do.url,headers=do.header,json=body)
42   - print(re.json())
43   - #响应断言
44   - self.assertEqual(re.status_code, 200)
45   - self.assertTrue("'code':'200'" in str(re.json()).replace(" ",""))
46   -
47   - @unittest.case_mark(my.mark())
48   - def test_doAdd_03(self):
49   - "用错误的用户来新增,无法新增"
50   - #请求数据需要修改
51   - body=do.body.copy()
52   - body["userId"]="516111"
53   - #POST请求
54   - re=my.post(url=do.url,headers=do.header,json=body)
55   - print(re.json())
56   - #响应断言
57   - self.assertEqual(re.status_code, 200)
58   - self.assertTrue("查询客户信息失败" in str(re.json()).replace(" ",""))
59   -
60   - @unittest.case_mark(my.mark())
61   - def test_doAdd_04(self):
62   - "成功新增一个商品为大白菜的报备单,重量为666"
63   - #请求数据不需要修改,直接POST请求
64   - body=do.body.copy()
65   - body["weight"]="666"
66   - re=my.post(url=do.url,headers=do.header,json=body)
67   - print(re.json())
68   - #响应断言
69   - self.assertEqual(re.status_code, 200)
70   - self.assertTrue("'code':'200'" in str(re.json()).replace(" ",""))
71   -
72   -
73   - @classmethod
74   - def tearDownClass(cls):
75   - pass
76   -
77   -
78   -if __name__ == "__main__":
79   -# unittest.main(verbosity=2)
80   -
81   - com.run_one(test_doAdd("test_doAdd_03"))
82 0 \ No newline at end of file
src/testcase/doAudit/.gitignore deleted 100644 → 0
1   -/__init__.pyc
src/testcase/doAudit/__init__.py deleted 100644 → 0
1   -# -*- coding:utf-8 -*-
2   -import binascii
3   -import base64
4   -import requests,json
5   -import time
6   -# import sys
7   -# reload(sys)
8   -# sys.setdefaultencoding('utf8')
9 0 \ No newline at end of file
src/testcase/doAudit/test_doAudit.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import unittest
4   -import urllib3
5   -import commons.ConfigDB as db
6   -from commons import common as com
7   -from commons.MySession import my
8   -from commons.api.fieldConfig import fieldConfig
9   -from commons.api.doAudit import doAudit
10   -from commons.api.doAdd import doAdd
11   -#作用为禁用请求安全提示,平时默认加上上面的urllib3语句就行
12   -urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
13   -ad=doAdd()
14   -au=doAudit()
15   -field=fieldConfig()
16   -
17   -
18   -
19   -class test_doAudit(unittest.TestCase):
20   -
21   - "登记单审核接口"
22   - @classmethod
23   - def setUpClass(cls):
24   - #通过字段配置接口提前配置新增页的字段配置
25   - my.post(url=field.url,headers=field.header,json=field.body)
26   -
27   - def setUp(self):
28   - #准备数据:新增一条登记单
29   - my.post(url=ad.url,headers=ad.header,json=ad.body)
30   - #获取数据:从MYSQL获取新增登记单的id号--因为响应没有id,需要数据库查询
31   - self.code=db.mysql_selectOne("SELECT id FROM `dili_trace`.register_bill ORDER BY id DESC LIMIT 1")[0]
32   - print("db id",self.code)
33   -
34   - @unittest.case_mark(my.mark())
35   - def test_doAudit_01(self):
36   - "审核通过"
37   - #请求url中的需要替换为新增登记单的id
38   - url=au.url.replace("5888", str(self.code))
39   - print("数据处理后的url",url)
40   - #进行GET请求
41   - re=my.get(url=url,headers=au.header)
42   - #打印请求结果(可删除该代码,一般只在调试时使用)
43   - print(re.json())
44   - #断言请求过程是否成功
45   - self.assertEqual(re.status_code, 200)
46   - #断言响应数据中是否存在期望字符串
47   - self.assertTrue("'result':'操作成功'" in str(re.json()).replace(" ",""))
48   -
49   -
50   - @unittest.case_mark(my.mark())
51   - def test_doAudit_02(self):
52   - "审核不通过"
53   - #请求url中的需要替换为新增登记单的id
54   - url=au.url.replace("5888", str(self.code)).replace("verifyStatus=20", "verifyStatus=30")
55   - #进行GET请求
56   - re=my.get(url=url,headers=au.header)
57   - #打印请求结果(可删除该代码,一般只在调试时使用)
58   - print(re.json())
59   - #断言请求过程是否成功
60   - self.assertEqual(re.status_code, 200)
61   - #断言响应数据中是否存在期望字符串
62   - self.assertTrue("'result':'操作成功'" in str(re.json()).replace(" ",""))
63   -
64   -
65   - @unittest.case_mark(my.mark())
66   - def test_doAudit_03(self):
67   - "审核不通过"
68   - #请求url中的需要替换为新增登记单的id
69   - url=au.url.replace("5888", str(self.code)).replace("verifyStatus=20", "verifyStatus=10")
70   - #进行GET请求
71   - re=my.get(url=url,headers=au.header)
72   - #打印请求结果(可删除该代码,一般只在调试时使用)
73   - print(re.json())
74   - #断言请求过程是否成功
75   - self.assertEqual(re.status_code, 200)
76   - #断言响应数据中是否存在期望字符串
77   - self.assertTrue("'result':'操作成功'" in str(re.json()).replace(" ",""))
78   -
79   - @unittest.case_mark(my.mark())
80   - def test_doAudit_04(self):
81   - "审核一个已经完成审核的登记单"
82   - #进行GET请求
83   - re=my.get(url=au.url,headers=au.header)
84   - #打印请求结果(可删除该代码,一般只在调试时使用)
85   - print(re.json())
86   - #断言请求过程是否成功
87   - self.assertEqual(re.status_code, 200)
88   - #断言响应数据中是否存在期望字符串
89   - self.assertTrue("'result':'操作失败,数据状态已改变'" in str(re.json()).replace(" ",""))
90   -
91   - @classmethod
92   - def tearDownClass(cls):
93   - pass
94   -
95   -
96   -if __name__ == "__main__":
97   -
98   - unittest.main(verbosity=2)
99   -
100   -# com.run_one(test_doAudit("test_doAudit_02"))
101 0 \ No newline at end of file
src/testcase/doUndo/.gitignore deleted 100644 → 0
1   -/__init__.pyc
src/testcase/doUndo/__init__.py deleted 100644 → 0
1   -# -*- coding:utf-8 -*-
2   -import binascii
3   -import base64
4   -import requests,json
5   -import time
6   -# import sys
7   -# reload(sys)
8   -# sys.setdefaultencoding('utf8')
9 0 \ No newline at end of file
src/testcase/doUndo/test_doUndo.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import unittest
4   -import urllib3
5   -import commons.ConfigDB as db
6   -from commons import common as com
7   -from commons.MySession import my
8   -from commons.api.fieldConfig import fieldConfig
9   -from commons.api.doAdd import doAdd
10   -from commons.api.doUndo import doUndo
11   -urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
12   -field=fieldConfig()
13   -ad=doAdd()
14   -un=doUndo()
15   -
16   -
17   -
18   -class test_doUndo(unittest.TestCase):
19   - "登记单撤销接口"
20   - @classmethod
21   - def setUpClass(cls):
22   - #通过字段配置接口提前配置新增页的字段配置
23   - my.post(url=field.url,headers=field.header,json=field.body)
24   -
25   - def setUp(self):
26   - #准备数据:新增一条登记单
27   - my.post(url=ad.url,headers=ad.header,json=ad.body)
28   - #获取数据:从MYSQL获取新增登记单的id号--因为响应没有id,需要数据库查询
29   - self.code=db.mysql_selectOne("SELECT id FROM `dili_trace`.register_bill ORDER BY id DESC LIMIT 1")[0]
30   -
31   - @unittest.case_mark(my.mark())
32   - def test_doUndo_01(self):
33   - "成功删除新增的一个报备单"
34   - #请求数据不需要修改,直接POST请求
35   - url=un.url.replace("6668",str(self.code))
36   - re=my.get(url=url,headers=un.header)
37   - print(re.json())
38   - #响应断言
39   - self.assertEqual(re.status_code, 200)
40   - self.assertTrue("'code':'200'" in str(re.json()).replace(" ",""))
41   -
42   - @classmethod
43   - def tearDownClass(cls):
44   - pass
45   -
46   -
47   -if __name__ == "__main__":
48   -# unittest.main(verbosity=2)
49   -
50   - com.run_one(test_doUndo("test_doUndo_01"))
51 0 \ No newline at end of file
src/testcase/fieldConfig/.gitignore deleted 100644 → 0
1   -/__init__.pyc
2   -/test_setup_teardown.pyc
src/testcase/fieldConfig/__init__.py deleted 100644 → 0
1   -# -*- coding:utf-8 -*-
2   -import binascii
3   -import base64
4   -import requests,json
5   -import time
6   -# import sys
7   -# reload(sys)
8   -# sys.setdefaultencoding('utf8')
9 0 \ No newline at end of file
src/testcase/fieldConfig/test_fieldConfig.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import unittest
4   -from commons import common as com
5   -from commons.MySession import my
6   -
7   -class test_fieldConfig(unittest.TestCase):
8   - "Unittest用例结构的简单的认识"
9   - @classmethod
10   - def setUpClass(cls):
11   - #初始化工作:该类的所有用例执行前会执行一次,且只执行一次,优先级高于setup,非必要代码
12   - print("setUpClass")
13   -
14   - def setUp(self):
15   - #初始化工作:每个用例执行前都会执行一次,N个用例就执行N次,非必要代码
16   - print("setUp")
17   -
18   - @unittest.case_mark(my.mark())
19   - def test_fieldConfig_01(self):
20   - "demo"
21   - print("test_01_fieldConfig")
22   -
23   - @unittest.case_mark(my.mark())
24   - def test_fieldConfig_02(self):
25   - "demo"
26   - print("test_02_fieldConfig")
27   -
28   - @unittest.case_mark(my.mark())
29   - def test_fieldConfig_03(self):
30   - "demo"
31   - print("test_03_fieldConfig")
32   - self.assertEqual(200, 200, "测试使用")
33   -
34   - @unittest.skip("执行时强制跳过该用例")
35   - def test_fieldConfig_04(self):
36   - print("test_04_fieldConfig")
37   -
38   -# @unittest.skipIf(test_fieldConfig.TT, "测试使用")
39   -# def test_05_fieldConfig(self):
40   -# print(test_fieldConfig.TT)
41   - def tearDown(self):
42   - #清理工作:每个用例执行后都会执行一次,N个用例就执行N次,非必要代码
43   - print("tearDown")
44   -
45   - @classmethod
46   - def tearDownClass(cls):
47   - #清理工作:该类的所有用例执行完成后会执行一次,且只执行一次,非必要代码
48   - print("tearDownClass")
49   -
50   -
51   -if __name__ == "__main__":
52   -#上述函数为引导执行代码,当模块被直接运行时,以下代码块将被运行,当模块是被导入时,代码块不被运行
53   -# unittest.main(verbosity=2)
54   - #unittest.main()为运行的入口/初始化函数,方法会搜索该模块文件下所有以test开头的测试用例方法,并自动执行它们。
55   - # verbosity是一个选项,表示测试结果的信息复杂度,有0、1、2 三个值
56   - # 0 (静默模式): 你只能获得总的测试用例数和总的结果 比如 总共10个 失败2 成功8
57   - # 1 (默认模式): 非常类似静默模式 只是在每个成功的用例前面有个“.” 每个失败的用例前面有个 “F”
58   - # 2 (详细模式):测试结果会显示每个测试用例的所有相关的信息
59   -
60   - com.run_one(test_fieldConfig("test_fieldConfig_03"))
61   -# com.run_list([test_fieldConfig("test_01_fieldConfig"),test_fieldConfig("test_02_fieldConfig")])
62   -# com.run_class(test_fieldConfig)
63   -
src/testcase/login/.gitignore deleted 100644 → 0
1   -/__init__.pyc
src/testcase/login/__init__.py deleted 100644 → 0
1   -# -*- coding:utf-8 -*-
2   -import binascii
3   -import base64
4   -import requests,json
5   -import time
6   -# import sys
7   -# reload(sys)
8   -# sys.setdefaultencoding('utf8')
9 0 \ No newline at end of file
src/testcase/login/test_login.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import unittest
4   -import urllib3
5   -from commons.api.login import login
6   -from commons import common as com
7   -from commons.MySession import my
8   -urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
9   -li=login()
10   -
11   -class test_login(unittest.TestCase):
12   - "登录接口"
13   -
14   - @unittest.case_mark(my.mark())
15   - def test_login_01(self):
16   - "账户密码都正确"
17   - #进行POST请求
18   - re=li.post("sg_wenze", "111111")
19   - print(re.headers)
20   - #断言响应
21   - self.assertTrue("Set-Cookie" in re.headers.keys())
22   -
23   - @unittest.case_mark(my.mark())
24   - def test_login_02(self):
25   - "密码错误"
26   - #进行POST请求
27   - re=li.post("sg_wenze", "111111111111")
28   - print(re.text)
29   - #断言响应
30   - self.assertTrue("用户名或密码错误" in re.text)
31   -
32   - @unittest.case_mark(my.mark())
33   - def test_login_03(self):
34   - "账户错误"
35   - #进行POST请求
36   - re=li.post("sg_wenze11111111", "11111")
37   - #print(re.text)
38   - #断言响应
39   - self.assertTrue("用户名或密码错误" in re.text)
40   -
41   - @unittest.case_mark(my.mark())
42   - def test_login_04(self):
43   - "账户错误"
44   - #进行POST请求
45   - re=li.post("sg_wenze11111111", "1111111111111")
46   - #print(re.text)
47   - #断言响应
48   - self.assertTrue("用户名或密码错误" in re.text)
49   -
50   -if __name__ == "__main__":
51   -
52   - unittest.main(verbosity=2)
53   -
54   -# com.run_one(test_login("test_01_login"))
src/testcase/logout/.gitignore deleted 100644 → 0
1   -/__init__.pyc
src/testcase/logout/__init__.py deleted 100644 → 0
1   -# -*- coding:utf-8 -*-
2   -import binascii
3   -import base64
4   -import requests,json
5   -import time
6   -# import sys
7   -# reload(sys)
8   -# sys.setdefaultencoding('utf8')
9 0 \ No newline at end of file
src/testcase/logout/test_logout.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import unittest
4   -import urllib3
5   -from commons.api.login import login
6   -from commons.api.logout import logout
7   -from commons import common as com
8   -from commons.MySession import my
9   -urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
10   -li=login()
11   -lo=logout()
12   -
13   -class test_logout(unittest.TestCase):
14   - "新增登记接口"
15   - @classmethod
16   - def setUpClass(cls):
17   - #通过登录接口获取session
18   - cls.se=li.login_session("hz_wenze", "111111")
19   -
20   - @unittest.case_mark(my.mark())
21   - def test_logout_01(self):
22   - "成功登出账户"
23   - re=lo.post(self.se, "user03")
24   - print(re.json())
25   - #响应断言
26   - self.assertEqual(re.status_code, 200)
27   - self.assertTrue("'code':'200'" in str(re.json()).replace(" ",""))
28   -
29   - @classmethod
30   - def tearDownClass(cls):
31   - cls.se.close()
32   -
33   -
34   -
35   -if __name__ == "__main__":
36   - unittest.main(verbosity=2)
37   -
38   -# com.run_one(test_logout("test_01_logout"))
39 0 \ No newline at end of file
src/testcase/upStream/.gitignore deleted 100644 → 0
1   -/__init__.pyc
src/testcase/upStream/__init__.py deleted 100644 → 0
1   -# -*- coding:utf-8 -*-
2   -import binascii
3   -import base64
4   -import requests,json
5   -import time
6   -# import sys
7   -# reload(sys)
8   -# sys.setdefaultencoding('utf8')
9 0 \ No newline at end of file
src/testcase/upStream/test_upStream.py deleted 100644 → 0
1   -#!/usr/bin/python
2   -# -*- coding: UTF-8 -*-
3   -import unittest
4   -import urllib3
5   -from commons.MySession import my
6   -from commons.api.upStream import upStream
7   -from commons import common as com
8   -urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
9   -uu=upStream()
10   -
11   -
12   -class test_upStream(unittest.TestCase):
13   - "上游企业列表查询接口"
14   -
15   - @unittest.case_mark(my.mark())
16   - def test_upStream_01(self):
17   - "成功查询上下游企业,无过滤条件"
18   - #请求数据不需要修改,直接POST请求
19   - re=my.post(url=uu.url,headers=uu.header,json=uu.body)
20   - print(re.json())
21   - #响应断言
22   - self.assertEqual(re.status_code, 200)
23   - self.assertTrue("total" in re.json().keys())
24   - self.assertTrue("上游" in str(re.json()).replace(" ",""))
25   -
26   -
27   - @unittest.skipDepend(depend="test_upStream_01")
28   - @unittest.case_mark(my.mark(1))
29   - def test_upStream_02(self):
30   - "成功查询上下游企业,加入企业/个人名称过滤条件"
31   - #请求数据需要修改
32   - body=uu.body.copy()
33   - body["likeName"]="111"
34   - #POST请求
35   - re=my.post(url=uu.url,headers=uu.header,json=body)
36   - print(re.json())
37   - #响应断言
38   - self.assertEqual(re.status_code, 200)
39   - self.assertTrue("legalPerson':'哈哈哈'" in str(re.json()).replace(" ",""))
40   -
41   - @classmethod
42   - def tearDownClass(cls):
43   - pass
44   -
45   -if __name__ == "__main__":
46   - unittest.main(verbosity=2)
47   -
48   -# com.run_one(test_upStream("test_01_upStream"))
49 0 \ No newline at end of file
testcase/doAdd/test_doAdd.py
... ... @@ -19,7 +19,7 @@ class test_doAdd(unittest.TestCase):
19 19 #通过字段配置接口提前配置新增页的字段配置
20 20 my.post(url=field.url,headers=field.header,json=field.body)
21 21  
22   - @unittest.case_mark(my.mark("test"))
  22 + # @unittest.case_mark(my.mark("test"))
23 23 def test_doAdd_01(self):
24 24 "成功新增一个商品为大白菜的报备单,重量为111"
25 25 #请求数据不需要修改,直接POST请求
... ... @@ -29,7 +29,7 @@ class test_doAdd(unittest.TestCase):
29 29 self.assertEqual(re.status_code, 200)
30 30 self.assertTrue("'code':'200'" in str(re.json()).replace(" ",""))
31 31  
32   -
  32 +
33 33 @unittest.case_mark(my.mark())
34 34 def test_doAdd_02(self):
35 35 "成功新增一个商品为鲜花生的报备单,重量为111"
... ...