Commit 070ce285d7381a559203e66bef089e295f98dcec

Authored by lixi
1 parent 2bb52757

更新文件

commons/MySession.py
1 #!/usr/bin/python 1 #!/usr/bin/python
2 # -*- coding: UTF-8 -*- 2 # -*- coding: UTF-8 -*-
3 import requests 3 import requests
  4 +import re
4 from commons import common as com 5 from commons import common as com
5 from commons.Logging import log 6 from commons.Logging import log
6 from commons.clientSession import cliSession 7 from commons.clientSession import cliSession
@@ -36,16 +37,17 @@ class mysession(requests.Session): @@ -36,16 +37,17 @@ class mysession(requests.Session):
36 body = "userName=sg_wenze&password=111111" 37 body = "userName=sg_wenze&password=111111"
37 body_client= {"userName":"sg_wenze","password":"111111"} 38 body_client= {"userName":"sg_wenze","password":"111111"}
38 39
39 - def __init__(self): 40 + def __init__(self,host=None):
40 "如下代码,可以通过配置文件来控制测试环境和灰度环境,http和https" 41 "如下代码,可以通过配置文件来控制测试环境和灰度环境,http和https"
41 super().__init__() 42 super().__init__()
  43 + self.user={}
42 self.url = mysession.url.replace("http://test.", com.get_global_config("global_data", "environment", "en")) 44 self.url = mysession.url.replace("http://test.", com.get_global_config("global_data", "environment", "en"))
43 self.header = mysession.header 45 self.header = mysession.header
44 self.body = mysession.body 46 self.body = mysession.body
45 self.url_client = mysession.url_client.replace("http://test.", com.get_global_config("global_data", "environment", "en")) 47 self.url_client = mysession.url_client.replace("http://test.", com.get_global_config("global_data", "environment", "en"))
46 self.header_client = mysession.header_client 48 self.header_client = mysession.header_client
47 self.body_client = mysession.body_client 49 self.body_client = mysession.body_client
48 - self.timeout = (6,6) 50 + self.timeout = (10,10)
49 self.max_retries = 3 51 self.max_retries = 3
50 self.keep_alive = False 52 self.keep_alive = False
51 self.ssl_verify = False 53 self.ssl_verify = False
@@ -55,36 +57,48 @@ class mysession(requests.Session): @@ -55,36 +57,48 @@ class mysession(requests.Session):
55 self.allow_redirects = False 57 self.allow_redirects = False
56 self.firmid={"group":"1","hd":"2","cd":"3","qqhe":"4","mdj":"5","gy":"6","cc":"7","sg":"8","sy":"9"} 58 self.firmid={"group":"1","hd":"2","cd":"3","qqhe":"4","mdj":"5","gy":"6","cc":"7","sg":"8","sy":"9"}
57 self.market={"sy":"沈阳","heb":"哈尔滨","sg":"寿光","gy":"贵阳","cc":"长春","hs":"杭水","hg":"杭果"} 59 self.market={"sy":"沈阳","heb":"哈尔滨","sg":"寿光","gy":"贵阳","cc":"长春","hs":"杭水","hg":"杭果"}
58 - self.user={} 60 + self.host= None if host==None else eval(com.get_global_config("global_data", "host_ip", host))
  61 +
59 62
60 def cliLogin(self,user="sy_userName_01"): 63 def cliLogin(self,user="sy_userName_01"):
61 self.webHeaders, self.clientHeaders, self.userInfo = cliSession().loginUser(user=user) 64 self.webHeaders, self.clientHeaders, self.userInfo = cliSession().loginUser(user=user)
62 return self 65 return self
63 66
64 - def get_session(self, account, **kwargs):  
65 - "如下代码,可以通过配置文件来控制登录的账户session"  
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",  
69 - com.get_global_config("global_data", "account", account).split("&")[1])  
70 - self.se = requests.session()  
71 - co = requests.cookies.RequestsCookieJar()  
72 - #加入UAP_firmId属性  
73 - firm=account.split("_")[0]  
74 - co.set("UAP_firmId", self.firmid[firm])  
75 - self.se.cookies.update(co)  
76 - # 进行登录请求  
77 - re = self.se.post(url=self.url, headers=self.header, data=self.body, proxies=self.proxies, **kwargs)  
78 - self.UAP_accessToken=self.se.cookies["UAP_accessToken"]  
79 - self.UAP_refreshToken=self.se.cookies["UAP_refreshToken"]  
80 - return self.se 67 + # def get_session(self, account, **kwargs):
  68 + # "如下代码,可以通过配置文件来控制登录的账户session"
  69 + # self.body = self.body.replace("sg_wenze",
  70 + # com.get_global_config("global_data", "account", account).split("&")[0])
  71 + # self.body = self.body.replace("111111",
  72 + # com.get_global_config("global_data", "account", account).split("&")[1])
  73 + # self.se = requests.session()
  74 + # co = requests.cookies.RequestsCookieJar()
  75 + # #加入UAP_firmId属性
  76 + # firm=account.split("_")[0]
  77 + # co.set("UAP_firmId", self.firmid[firm])
  78 + # self.se.cookies.update(co)
  79 + # # 进行登录请求
  80 + # re = self.se.post(url=self.url, headers=self.header, data=self.body, proxies=self.proxies, **kwargs)
  81 + # self.UAP_accessToken=self.se.cookies["UAP_accessToken"]
  82 + # self.UAP_refreshToken=self.se.cookies["UAP_refreshToken"]
  83 + # return self.se
  84 + #
  85 + # def get_login_info(self, account, **kwargs):
  86 + # "用于获取用户信息"
  87 + # self.body_client.update({"userName":com.get_global_config("global_data", "account", account).split("&")[0]})
  88 + # self.body_client.update({"password":pwdCry(com.get_global_config("global_data", "account", account).split("&")[1])})
  89 + # tmp = requests.post(url=self.url_client, headers=self.header_client, json=self.body_client, proxies=self.proxies, **kwargs)
  90 + # return tmp
81 91
82 - def get_login_info(self, account, **kwargs):  
83 - "用于获取用户信息"  
84 - self.body_client.update({"userName":com.get_global_config("global_data", "account", account).split("&")[0]})  
85 - self.body_client.update({"password":pwdCry(com.get_global_config("global_data", "account", account).split("&")[1])})  
86 - tmp = requests.post(url=self.url_client, headers=self.header_client, json=self.body_client, proxies=self.proxies, **kwargs)  
87 - return tmp 92 + def url_pro(self, url, host):
  93 + # url = url.replace(" ", "")
  94 + if host!=None:
  95 + if "http:" in url:
  96 + d1 = re.match(r"http://(.+?)/", url).group(1).split(":")[0]
  97 + url = re.sub(r"http://(.+?)/", r"http://" + host[d1] + "/", url)
  98 + elif "https:" in url:
  99 + d1 = re.match(r"https://(.+?)/", url).group(1).split(":")[0]
  100 + url = re.sub(r"https://(.+?)/", r"https://" + host[d1] + "/", url)
  101 + return url
88 102
89 def get_session_client(self, account, **kwargs): 103 def get_session_client(self, account, **kwargs):
90 "get_session和get_session_client的方法只能用一个" 104 "get_session和get_session_client的方法只能用一个"
@@ -151,6 +165,8 @@ class mysession(requests.Session): @@ -151,6 +165,8 @@ class mysession(requests.Session):
151 """ 165 """
152 # 记录日志 166 # 记录日志
153 log.info("{0:=^86}".format('')) 167 log.info("{0:=^86}".format(''))
  168 + log.info(url)
  169 + url=self.url_pro(url,self.host)
154 log.info("{}\n{}\n".format(url, kwargs)) 170 log.info("{}\n{}\n".format(url, kwargs))
155 # 进行请求 171 # 进行请求
156 re = super().request(method , url, **kwargs,timeout=self.timeout) 172 re = super().request(method , url, **kwargs,timeout=self.timeout)
@@ -262,16 +278,15 @@ class mysession(requests.Session): @@ -262,16 +278,15 @@ class mysession(requests.Session):
262 278
263 my = mysession() 279 my = mysession()
264 my.set_mark() 280 my.set_mark()
265 -  
266 # 沈阳客户端session 281 # 沈阳客户端session
267 -sessionSy = mysession().cliLogin("sy_userName_01") 282 +# sessionSy = mysession().cliLogin("sy_userName_01")
268 # 哈尔滨客户端session 283 # 哈尔滨客户端session
269 -sessionHeb = mysession().cliLogin("hd_userName_01")  
270 -# print(sessionSy.userInfo)  
271 -# print(sessionHeb.userInfo)  
272 -  
273 -# sy1=mysession().get_session_client("sy_user01")  
274 -# heb=mysession().get_session_client("heb_user01")  
275 -hg = mysession().get_session_client("hg_user01")  
276 -# sg=mysession().get_session_client("sg_user01")  
277 - 284 +# sessionHeb = mysession().cliLogin("hd_userName_01")
  285 +#获取对应市场session
  286 +# sy1=mysession("host1").get_session_client("sy_user01")
  287 +# heb=mysession("host1").get_session_client("heb_user01")
  288 +hg=mysession("host2").get_session_client("hg_user01")
  289 +# 检测登录接口
  290 +# sy1.check_login("sy_user01")
  291 +# 检测登录接口
  292 +hg.check_login("hg_user01")
278 \ No newline at end of file 293 \ No newline at end of file
config/global_data.conf
@@ -24,8 +24,8 @@ user03=256 @@ -24,8 +24,8 @@ user03=256
24 24
25 [email] 25 [email]
26 #为空时[]不发邮件,若要发邮件,参考demo 26 #为空时[]不发邮件,若要发邮件,参考demo
27 -to_list=["lixi@diligrp.com","liujiqiang@diligrp.com","wenleiming@diligrp.com"]  
28 -cc_list=["demo@diligrp.com"] 27 +to_list=["wenleiming@diligrp.com"]
  28 +cc_list=["lixi@diligrp.com","liujiqiang@diligrp.com","wenleiming@diligrp.com"]
29 demo=["lixi@diligrp.com","liujiqiang@diligrp.com","wenleiming@diligrp.com","tg@diligrp.com"] 29 demo=["lixi@diligrp.com","liujiqiang@diligrp.com","wenleiming@diligrp.com","tg@diligrp.com"]
30 30
31 [mark] 31 [mark]
@@ -35,7 +35,7 @@ demo=["heb1","P3","v1.6","沈阳",None] @@ -35,7 +35,7 @@ demo=["heb1","P3","v1.6","沈阳",None]
35 35
36 36
37 [environment] 37 [environment]
38 -#格式只能为一下几种 38 +#格式只能为一下几种,用于区分环境
39 #http://test. 39 #http://test.
40 #https://test. 40 #https://test.
41 #http:// 41 #http://
@@ -57,8 +57,54 @@ gateway=test.gateway.diligrp.com:8285 @@ -57,8 +57,54 @@ gateway=test.gateway.diligrp.com:8285
57 57
58 58
59 59
60 -  
61 -  
62 -  
63 - 60 +[host_ip]
  61 +#重构host
  62 +host1={
  63 + "test.customer.diligrp.com": "10.35.100.45:8382",
  64 + "test.bd.diligrp.com": "10.35.100.45:8384",
  65 + "test.jmsf.diligrp.com": "10.35.100.44:8385",
  66 + "test.account.diligrp.com": "10.35.100.44:8186",
  67 + "test.card.diligrp.com": "10.35.100.44:8386",
  68 + "test.trading.diligrp.com": "10.35.100.47:8387",
  69 + "test.logger.diligrp.com": "10.35.100.47:8283",
  70 + "test.orders.diligrp.com": "10.35.100.47:8185",
  71 + "test.rule.diligrp.com": "10.35.100.54:8284",
  72 + "test.gateway.diligrp.com": "10.35.100.54:8285",
  73 + "test.message.diligrp.com": "10.35.100.54:8289",
  74 + "test.dfs.diligrp.com": "10.35.100.55:9527",
  75 + "test.report.diligrp.com": "10.35.100.56:8388",
  76 + "test.exporter.diligrp.com": "10.35.100.56:8288",
  77 + "test.appmanager.diligrp.com": "10.35.100.56:9000",
  78 + "test.uid.diligrp.com": "10.35.100.56:8282",
  79 + "test.nacos.diligrp.com": "10.35.100.37:8848",
  80 + "test.scheduler.diligrp.com": "10.35.100.47:8281",
  81 + "test.bpmc.diligrp.com": "10.35.100.54:8617",
  82 + "test.route.diligrp.com": "10.35.100.54:8286",
  83 + "test.uap.diligrp.com": "10.35.100.55:80",
  84 + "test.trace.diligrp.com": "10.35.100.55:8082",
  85 + "test.xorder.diligrp.com": "10.35.100.56:8090"}
  86 +
  87 +#杭果host
  88 +host2={
  89 + "test.uap.diligrp.com": "10.28.12.150:80",
  90 + "test.bpmc.diligrp.com": "10.28.12.150:8617",
  91 + "test.as.diligrp.com": "10.28.12.150",
  92 + "test.logger.diligrp.com": "10.28.11.149:8283",
  93 + "test.scheduler.diligrp.com": "10.28.11.149",
  94 + "test.account.diligrp.com": "10.28.11.149:8186",
  95 + "test.rule.diligrp.com": "10.28.10.127:8284",
  96 + "test.bd.diligrp.com": "10.28.10.127",
  97 + "test.customer.diligrp.com": "10.28.10.127:8384",
  98 + "test.report.diligrp.com": "10.28.10.127:8388",
  99 + "test.jmsf.diligrp.com": "10.28.10.127:8385",
  100 + "test.uid.diligrp.com": "10.28.11.180:8282",
  101 + "test.message.diligrp.com": "10.28.11.190:8289",
  102 + "test.dfs.diligrp.com": "10.28.11.190:9527",
  103 + "test.gateway.diligrp.com": "10.28.10.159:8285",
  104 + "test.route.diligrp.com": "10.28.10.159:8286",
  105 + "test.card.diligrp.com": "10.28.10.159:8386",
  106 + "test.exporter.diligrp.com": "10.28.11.183",
  107 + "test.ia.diligrp.com": "10.28.11.183",
  108 + "test.settlement.diligrp.com": "10.28.11.183:8383",
  109 + "test.hg.diligrp.com": "10.28.12.239"}
64 110
@@ -16,69 +16,67 @@ from commons.scripts import delReport @@ -16,69 +16,67 @@ from commons.scripts import delReport
16 16
17 def Create_Testcase_suite(path=""): 17 def Create_Testcase_suite(path=""):
18 '''创建测试套件''' 18 '''创建测试套件'''
19 - if path!="":  
20 - path+="/" 19 + if path != "":
  20 + path += "/"
21 print(path) 21 print(path)
22 - testunit=unittest.TestSuite() 22 + testunit = unittest.TestSuite()
23 test_Loader = DiscoveringTestLoader() 23 test_Loader = DiscoveringTestLoader()
24 - discover=test_Loader.discover("./testcase/{}".format(path),pattern='test_*.py',top_level_dir=None) 24 + discover = test_Loader.discover("./testcase/{}".format(path), pattern='test_*.py', top_level_dir=None)
25 # print(discover) 25 # print(discover)
26 for test_suite in discover: 26 for test_suite in discover:
27 testunit.addTests(test_suite) 27 testunit.addTests(test_suite)
28 -# print(testunit) 28 + # print(testunit)
29 return testunit 29 return testunit
30 30
31 -  
32 -def Run_Testcase(testsuit,head=""): 31 +
  32 +def Run_Testcase(testsuit, head=""):
33 '''运行测试用例并生成报告''' 33 '''运行测试用例并生成报告'''
34 if (head in my.market.keys()): 34 if (head in my.market.keys()):
35 - head="["+ my.market[head] + "]"  
36 - now = time.strftime("%Y-%m-%d %H_%M_%S",time.localtime())  
37 - path=os.path.dirname(os.path.abspath(sys.argv[0]))  
38 - report_file=path+"/report/"+now+"_result.html"  
39 - #创建报告文件  
40 - fp=open(report_file,'wb') 35 + head = "[" + my.market[head] + "]"
  36 + now = time.strftime("%Y-%m-%d %H_%M_%S", time.localtime())
  37 + path = os.path.dirname(os.path.abspath(sys.argv[0]))
  38 + report_file = path + "/report/" + now + "_result.html"
  39 + # 创建报告文件
  40 + fp = open(report_file, 'wb')
41 41
42 - runner=HTMLTestRunner_cn.HTMLTestRunner( 42 + runner = HTMLTestRunner_cn.HTMLTestRunner(
43 stream=fp, 43 stream=fp,
44 title=u'进门收费{}--接口测试报告'.format(head), 44 title=u'进门收费{}--接口测试报告'.format(head),
45 description=u'用例简要执行情况如下:(注:报告详细信息需要下载report.html并用浏览器打开)', 45 description=u'用例简要执行情况如下:(注:报告详细信息需要下载report.html并用浏览器打开)',
46 - verbosity = 2)  
47 - #执行用例 46 + verbosity=2)
  47 + # 执行用例
48 runner.run(testsuit) 48 runner.run(testsuit)
49 - #关闭文件 49 + # 关闭文件
50 fp.close() 50 fp.close()
51 delReport.delReport(path) 51 delReport.delReport(path)
52 return report_file 52 return report_file
53 - 53 +
  54 +
54 def Send_email(filename): 55 def Send_email(filename):
55 '''判断邮件发送逻辑''' 56 '''判断邮件发送逻辑'''
56 - l=eval(com.get_global_config("global_data", "email","to_list").lower())  
57 - c=eval(com.get_global_config("global_data", "email","cc_list").lower())  
58 - if type(l)!=type([]): 57 + l = eval(com.get_global_config("global_data", "email", "to_list").lower())
  58 + c = eval(com.get_global_config("global_data", "email", "cc_list").lower())
  59 + if type(l) != type([]):
59 raise Exception("error,pls input list type send-email address") 60 raise Exception("error,pls input list type send-email address")
60 - elif len(l)==0: 61 + elif len(l) == 0:
61 print("\n To_list of send-email is null,won't send email!") 62 print("\n To_list of send-email is null,won't send email!")
62 - elif len(l)!=0: 63 + elif len(l) != 0:
63 for i in l: 64 for i in l:
64 print("\n check send-email format : {}".format(i)) 65 print("\n check send-email format : {}".format(i))
65 - if re.match(r'^[0-9a-zA-Z_]{1,19}@[0-9a-zA-Z]{1,13}\.[com,cn,net]{1,3}$',i): 66 + if re.match(r'^[0-9a-zA-Z_]{1,19}@[0-9a-zA-Z]{1,13}\.[com,cn,net]{1,3}$', i):
66 pass 67 pass
67 else: 68 else:
68 raise Exception("error,pls check your send-email format") 69 raise Exception("error,pls check your send-email format")
69 - #发送邮件  
70 - em.send_email(filename,send_to=l,cc_to=c) 70 + # 发送邮件
  71 + em.send_email(filename, send_to=l, cc_to=c)
71 else: 72 else:
72 print("\n Haven't sent the email,pls check send-email address!") 73 print("\n Haven't sent the email,pls check send-email address!")
73 -  
74 74
75 75
76 if __name__ == "__main__": 76 if __name__ == "__main__":
77 - #检测数据库 77 + # 检测数据库
78 db.mysql_conn_test() 78 db.mysql_conn_test()
79 - #检测登录接口  
80 - my.check_login("sy_user01")  
81 - #创建测试套,运行测试用例,生成报告  
82 - report=Run_Testcase(Create_Testcase_suite("sy"))  
83 - #发送邮件  
84 - Send_email(report) 79 + # 创建测试套,运行测试用例,生成报告
  80 + report = Run_Testcase(Create_Testcase_suite())
  81 + # 发送邮件
  82 + Send_email(report)
85 \ No newline at end of file 83 \ No newline at end of file