~玉米糊~
慢慢来,也会很快。 非宁静无以志学,学什么都一样,慢慢打基础,找规律、认真、坚持,其余的交给时间。

构建选择Excute Windows batch command

 下面是python脚本,注意字符集 GBK

 

runtest.py

 1 #-*-coding:GBK -*- 
 2 import sys
 3 import time
 4 import pymysql
 5 import requests
 6 
 7 
 8 # print(sys.argv[1])
 9 
10 ids_out = []
11 # 用","分割,得到列表id_list
12 id_list = sys.argv[1].split(",")
13 for id_str in id_list:    
14     # 用~分割,1001这种会变成['1001'],其他会变成['1003', '1005'],因为range不包含后面的值,所以要加1,取[1003,10006)
15     for i in range(int(id_str.split("~")[0]), int(id_str.split("~")[-1]) + 1):
16         ids_out.append(i)
17         
18 print("需要执行的用例集:", ids_out)
19 
20 json = {"ids": ids_out}
21 
22 r = requests.post('http://10.138.60.185:9999/step_allexcute_data1/', json=json)
23 
24 print(r.status_code, r.text)
25 
26 
27 # 遍历列表,查询出用例名和执行时间在10分钟内的结果
28 print("\n")
29 print("序号   用例编号    用例名称            执行结果")
30 suc_num = 0
31 sum_num = 1
32 for id in ids_out:
33     try:
34         sql = "select step_name,api_result,actual_params,expect_params from vcredit_resultdetail where step_id = %s and create_time > DATE_SUB(NOW(), INTERVAL 10 MINUTE)" % id
35         # 执行第一次查询
36         conn = pymysql.connect(host="10.138.60.185", user="root", password="fyw554193", database="automate")
37         cursor = conn.cursor()
38         cursor.execute(sql)
39         data = cursor.fetchone()
40         cursor.close()
41         conn.close()
42         # 如果查询不到结果,则10秒后再查,执行100次,打印"id,用例名:用例正在执行,10秒后继续查询"
43         i = 0
44         while (not data) and (i < 100):
45             # print("%s: 未查到执行结果,10秒后继续查询。。。" % id)
46             time.sleep(10)
47             conn = pymysql.connect(host="10.138.60.185", user="root", password="fyw554193", database="automate")
48             cursor = conn.cursor()
49             cursor.execute(sql)
50             data = cursor.fetchone()
51             i += 1
52         # 查询到结果,则正常打印
53         if data[1] == 1:
54             suc_num += 1
55             print("%s      %s        %s            用例执行通过" % (sum_num,id, data[0]))
56         else:
57             print("%s      %s        %s            用例执行未通过,实际结果为%s,预期结果为%s" % (sum_num,id, data[0], data[1], data[2]))
58     # 失败则打印异常
59     except Exception:
60         print("%s      %s                      接口发生异常" % (sum_num,id))
61     sum_num += 1
62 print("\n")
63 print("总计运行%s个测试用例,成功%s个,失败%s个" %(len(ids_out), suc_num, len(ids_out)-suc_num))

 

record.py

复制代码
#-*-coding:GBK -*- 
import sys
import pymysql
import requests
import xml.dom.minidom
from requests.auth import HTTPBasicAuth

'''通过Jenkins API获取项目构建结果'''
auth = HTTPBasicAuth('admin', 'admin')
url = "http://10.138.60.82:8080/api/python?pretty=true"
r = requests.get(url=url, auth=auth)
print(r.text)

dic = eval(r.text)

for i in dic["jobs"]:
    if i["name"] == 'build':
        bu_color = i["color"]
    elif i["name"] == 'scanning':
        sc_color = i["color"]

print(bu_color, sc_color)

'''通过pom.xml获取版本信息'''
pom_path = sys.argv[1]
print(pom_path)
dom = xml.dom.minidom.parse(pom_path)
rootdata = dom.documentElement
itemlist = rootdata.getElementsByTagName('version')
version = itemlist[0].firstChild.data
print(version)

'''把结果转化并插入数据库'''
bu_status = 1 if bu_color == "blue" else 0
sc_status = 1 if sc_color == "blue" else 0

sql = "insert into vcredit_buildrecord(requireName,ProjectName,build,isCis,create_time) VALUE ('%s','%s',%s,%s,NOW())" \
      % (version, "ProjectName", bu_status, sc_status)

conn = pymysql.connect(host='10.138.30.104', user='root', password='080305', database='testquality', charset='UTF8')
cursor = conn.cursor()
cursor.execute(sql)
cursor.close()
conn.commit()
conn.close()
复制代码

 

codeLine.py

 1 #-*-coding:GBK -*- 
 2 import re
 3 import sys
 4 import xml.dom.minidom
 5 import pymysql
 6 
 7 with open("D:\\jenkins\\jobs\\git\\gitlog.txt") as f:
 8     txt = f.read()
 9 
10 print(txt)
11 
12 p1 = r"(?<= \| )\d+?(?= \+\+)"
13 pattern1 = re.compile(p1)
14 num = int(pattern1.findall(txt)[0])
15 
16 print(num)
17 
18 '''通过pom.xml获取版本信息'''
19 pom_path = sys.argv[1]
20 print(pom_path)
21 dom = xml.dom.minidom.parse(pom_path)
22 rootdata = dom.documentElement
23 itemlist = rootdata.getElementsByTagName('version')
24 version = itemlist[0].firstChild.data
25 print(version)
26 
27 '''更新数据库'''
28 sql = "UPDATE `vcredit_requirequality` SET `codeLine`=%s WHERE `requireName`='%s'" % (num, version)
29 
30 print(sql)
31 
32 conn = pymysql.connect(host='10.138.30.104', user='root', password='080305', database='testquality', charset='UTF8')
33 cursor = conn.cursor()
34 cursor.execute(sql)
35 cursor.close()
36 conn.commit()
37 conn.close()

 

posted on 2021-11-29 14:49  yuminhu  阅读(612)  评论(0编辑  收藏  举报