1.Libs下放了一个HTMLTestRunner.py文件:C:\Users\demi.zhou\AppData\Local\Programs\Python\Python37\libs
贴这段代码:
import unittest
from HTMLTestRunner import HTMLTestRunner
import time
discover = unittest.defaultTestLoader.discover("./","test*.py",top_level_dir=None)
if __name__=='__main__':
times =time.strftime("%Y-%m-%d-%H-%M-%S")
file_name="report/"+times+".html"
f=open(file_name,"wb")
runner=HTMLTestRunner(stream=f,title="自动化测试报告",description="crm测试结果")
runner.run(discover)
2.继承一个类(带有init函数)后,继承的类如果写了init函数会覆盖别继承类的init函数
3.调用一个类里面的init函数
比如A类:__init__(self,x,y)
B类调用时:A(x,y)里面不要再加self,否则会出现参数错误。因为self已经默认传过去了。
4.selenium.common.exceptions.WebDriverException: Message: unknown error: Element <span class="nav-menu-item__login-text login-text">...</span> is not clickable at point (1173, 20). Other element would receive the click: <a class="global-navigation__nav-menu-link load-gigya-screenset cta cta-icon--left cta-icon__H-D-Profile cta-link" data-dropdown="dev-login-dropdown" href="#" data-signin="Sign In" data-salutation="Hi," role="presentation">...</a>
(Session info: chrome=71.0.3578.98)
提示:元素无法点击,其他的元素会接受此点击行为。
分析原因,首先肯定不是因为页面元素不存在而无法点击。实际上这个页面元素是存在的,而是被另外一个弹层挡住了。
解决方法:在自己实践的项目中,取上一层(覆盖的弹层)的xpath,再sleep(2)获取text文本。
5.cssselector不支持带空格属性,空格用点 . 替换
6.class定位有空格时,可以选择其中一个
7.用JS滚动到目标元素:
target = self.driver.find_element(By.XPATH, '//*[@id="gigya-register-form"]/div[1]/label[1]/p[7]')
self.driver.execute_script("arguments[0].scrollIntoView();", target)
8.下拉框随机选择一个选项:
from selenium.webdriver.support.ui import Select
import random
Select(self.driver.find_element(*self.country_element)).select_by_index(random.randint(1,249))
注:select_by_index()是从0开始计数的。
9.新页面第一个元素用显示等待查找会报错,而用sleep后去查找没有报错。
猜想原因:刚打开一个新的页面,用显示等待会在之前页面上查找元素???