定义类级别的初始化和清除,在执行下面三个用例的时候,第二个用例会失败,不知道咋回事,知道原因的求请教
from pageobjects.byhy_sms_login_page import Byhy_SMS_Login
from common.logger import Logger
from common.browser_engine import BrowserEngine
import time
logger = Logger('test_错误登录').get_log()
class TestLogin:
driver = None
def setup_class(cls):
cls.driver = BrowserEngine().open_browser()
def teardown_class(cls):
cls.driver.quit()
def test_case01(self):
byhy_page = Byhy_SMS_Login(self.driver)
byhy_page.name_input('')
byhy_page.passwd_input('88888888')
byhy_page.click_submit_btn()
try:
assert self.driver.switch_to.alert.text == '请输入用户名'
logger.info('用户名为空执行成功')
time.sleep(2)
except Exception as e:
logger.info('用户名为空执行失败', format(e))
def test_case02(self):
byhy_page = Byhy_SMS_Login(self.driver)
byhy_page.name_input('byhy')
byhy_page.passwd_input('')
byhy_page.click_submit_btn()
try:
assert self.driver.switch_to.alert.text == '请输入密码'
logger.info('密码为空执行成功')
time.sleep(2)
except Exception as e:
logger.info('密码为空执行失败')
def test_case03(self):
byhy_page = Byhy_SMS_Login(self.driver)
byhy_page.name_input('byhy')
byhy_page.passwd_input('00000000')
byhy_page.click_submit_btn()
try:
assert self.driver.switch_to.alert.text == '登录失败 : 用户名或者密码错误'
logger.info('密码错误执行成功')
time.sleep(2)
except Exception as e:
logger.info('密码错误执行失败', format(e))
所以我把类级别变成方法级别,每执行一次用例就初始化清除一次,就通过了,但是时间比之前长
def setup_method(self):
self.driver = BrowserEngine().open_browser()
def teardown_method(self):
self.driver.quit()