linkapi.py 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. from hytest import *
  2. from playwright.sync_api import sync_playwright
  3. from PIL import Image, ImageChops
  4. from bs4 import BeautifulSoup
  5. import requests
  6. class APILink():
  7. headers = {
  8. "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.0.0 Safari/537.36 Edg/114.0.1823.67;jy-test"
  9. }
  10. #headers设置为全局变量
  11. GSTORE['headers'] = headers
  12. # session对象设置为全局变量
  13. s = requests.Session()
  14. GSTORE['s'] = s
  15. #打开链接,返回title
  16. def obtain_url_title(self,url):
  17. headers=GSTORE['headers']
  18. s = GSTORE['s']
  19. response = s.get(url,headers=headers)
  20. response.encoding = 'utf-8' # 设置编码为utf-8
  21. soup = BeautifulSoup(response.text, 'html.parser')
  22. title = soup.title.string
  23. return title
  24. #打开链接,status=200,返回true
  25. def open_url_status(self,url):
  26. headers=GSTORE['headers']
  27. s = GSTORE['s']
  28. response = s.get(url,headers=headers)
  29. status_code = response.status_code
  30. if status_code==200:
  31. return True
  32. else:
  33. return False
  34. #打开链接,返回页面底部某个值
  35. def obtain_url_bottom(self,url,loc):
  36. response = requests.get(url)
  37. response.encoding = 'utf-8' # 设置编码为gbk
  38. soup = BeautifulSoup(response.text, 'html.parser')
  39. # 查找元素并获取值
  40. element = soup.find('div', attrs={'class': loc})
  41. # element = soup.find(loc)
  42. element_value = element.text
  43. return element_value
  44. def setup(self):
  45. # 初始化 Playwright
  46. self.playwright = sync_playwright().start()
  47. self.browser = self.playwright.chromium.launch(headless=True)
  48. self.page = self.browser.new_page()
  49. def teardown(self):
  50. # 关闭浏览器
  51. self.browser.close()
  52. self.playwright.stop()
  53. def obtain_element_text(self,url,element):
  54. self.page.goto(url)
  55. # 等待元素出现
  56. self.page.wait_for_selector(element)
  57. # 查找元素
  58. element_handle = self.page.locator(element)
  59. # 获取元素的文本或属性值
  60. element_text = element_handle.text_content()
  61. # element_attribute = element_handle.get_attribute('属性名')
  62. # 设置超时时间
  63. self.page.wait_for_timeout(3000)
  64. return element_text
  65. # print(f'元素的属性值: {element_attribute}')
  66. #网页截图模糊遮罩方法,适用于网页有动态元素,进行遮罩比较
  67. def save_screenshot_mask(self,url, output_path, elements, clip=None):
  68. locs = []
  69. self.page.goto(url)
  70. for element in elements:
  71. loc = self.page.locator(element)
  72. locs.append(loc)
  73. self.page.screenshot(path=output_path,mask=locs, clip=clip)
  74. #网页直接截图方法,适用于网页元素不变,可直接截图比较
  75. def save_screenshot(self,url, output_path, clip=None):
  76. self.page.goto(url)
  77. self.page.screenshot(path=output_path, clip=clip)
  78. def compare_images(self, image1_path, image2_path):
  79. image1 = Image.open(image1_path)
  80. image2 = Image.open(image2_path)
  81. diff = ImageChops.difference(image1, image2)
  82. if diff.getbbox() is None:
  83. INFO("两张图片完全相同")
  84. return True
  85. else:
  86. INFO("两张图片存在差异")
  87. return False
  88. #对比样本快照与当前快照
  89. def contrast_snapshot(self,url,expected_screenshot,current_screenshot,clip):
  90. # 如果不存在样本照片,生成样本照片
  91. if not os.path.exists(expected_screenshot):
  92. self.save_screenshot(url, expected_screenshot,clip)
  93. INFO(f"样本快照已保存:{expected_screenshot}")
  94. #生成对比照片
  95. apilink.save_screenshot(url, current_screenshot,clip)
  96. INFO(f"对比快照已保存:{expected_screenshot}")
  97. #返回对比结果
  98. result = apilink.compare_images(current_screenshot, expected_screenshot)
  99. return result
  100. #对比样本快照与当前快照2
  101. def contrast_snapshot_mask(self,url,expected_screenshot,current_screenshot,element,clip):
  102. # 如果不存在样本照片,生成样本照片
  103. if not os.path.exists(expected_screenshot):
  104. self.save_screenshot_mask(url, expected_screenshot,element,clip)
  105. INFO(f"样本快照已保存:{expected_screenshot}")
  106. #生成对比照片
  107. apilink.save_screenshot_mask(url, current_screenshot,element,clip)
  108. INFO(f"对比快照已保存:{expected_screenshot}")
  109. #返回对比结果
  110. result = apilink.compare_images(current_screenshot, expected_screenshot)
  111. return result
  112. apilink = APILink()