前言
一直想学习自动化测试,但是都没行动,业余时间学习零零碎碎并记录20210421。
7、为项目添加日志
- logging模块介绍
- logging格式输出
logging四大组件:Logger,Handler,Filter,Formatter
- 为项目添加log日志
用户登录代码加日志打印
from time import sleep
from util import util
import pytest
from selenium import webdriver
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.support.wait import WebDriverWait
class TestUserLogin(object):
def setup(cls):
cls.driver = webdriver.Chrome()
cls.driver.get('http://localhost:8080/jpress/user/login')
cls.driver.maximize_window()
# 初始化日志方法
cls.logger = util.get_logger()
cls.logger.propagate = 0
cls.logger.info('_____________________________')
cls.logger.info('测试用户登录')
def teardown(cls):
cls.driver.quit()
# 测试用户登录,用户名错误
def test01_user_login_userError(self):
# 用户名为空
user = '' #实际正确的是amdin
pwd = 'admin'
expected = '账号不能为空'
# 输入用户名
self.driver.find_element_by_name('user').send_keys(user)
self.logger.debug('输入用户名称:%s',user)
# 输入密码
self.driver.find_element_by_name('pwd').send_keys(pwd)
self.logger.debug('输入用户密码:%s',pwd)
# 点击登录
self.driver.find_element_by_xpath('/html/body/div/div/div/form/div[3]/div/button').click() #千万别忘记click
self.logger.debug('点击登录')
# 因为有弹窗所以需要切换到弹窗上,并等待弹窗
WebDriverWait(self.driver, 5).until(EC.alert_is_present())
alert = self.driver.switch_to.alert
# python 的断言
# 获取弹窗上的文字来比较
# assert alert.text == expected
sleep(3)
# 验证不通过肯定执行后面的日志
try:
assert alert.text == expected + 'test'
except AssertionError as ae:
self.logger.error("小慌慌,快看:%s这里", "报错了", exc_info=1)
alert.accept()
# 测试用户登录成功
def test02_user_login_ok(self):
# 用户名为空
user = 'admin'
pwd = 'admin'
expected = '用户中心'
# 输入用户名
self.driver.find_element_by_name('user').clear() # 为了把上面案例输入的值清空
self.driver.find_element_by_name('user').send_keys(user)
self.logger.debug('输入用户名称:%s',user)
# 输入密码
self.driver.find_element_by_name('pwd').clear()
self.driver.find_element_by_name('pwd').send_keys(pwd)
self.logger.debug('输入用户密码:%s',pwd)
# 点击登录
# self.driver.find_element_by_xpath('/html/body/div/div/div/form/div[3]/div/button').click()
self.driver.find_element_by_css_selector('body > div > div > div > form > div.row > div > button').click()
self.logger.debug('登录中...请等待')
# 等待标题
WebDriverWait(self.driver, 5).until(EC.title_is(expected))
sleep(3)
#验证 因为没有错误弹窗 所以用到了title断言判断
assert self.driver.title == expected
self.logger.debug('登录中成功')
# if __name__ == '__main__':
# # unittest.main()
# pytest.main(['-sv', 'test_user_login.py'])
运行结果:
all.log
2021-04-21 17:23:00,002 - INFO - _____________________________
2021-04-21 17:23:00,002 - INFO - 测试用户登录
2021-04-21 17:23:00,130 - DEBUG - 输入用户名称:
2021-04-21 17:23:00,269 - DEBUG - 输入用户密码:admin
2021-04-21 17:23:00,370 - DEBUG - 点击登录
2021-04-21 17:23:03,381 - ERROR - 小慌慌,快看:报错了这里
Traceback (most recent call last):
File "/Users/ff/PycharmProjects_py3/Selenium_project/log/test_user_login.py", line 52, in test01_user_login_userError
assert alert.text == expected + 'test'
AssertionError: assert '账号不能为空' == '账号不能为空test'
- 账号不能为空test
? ----
+ 账号不能为空
2021-04-21 17:23:06,262 - INFO - _____________________________
2021-04-21 17:23:06,262 - INFO - _____________________________
2021-04-21 17:23:06,263 - INFO - 测试用户登录
2021-04-21 17:23:06,263 - INFO - 测试用户登录
2021-04-21 17:23:06,531 - DEBUG - 输入用户名称:admin
2021-04-21 17:23:06,531 - DEBUG - 输入用户名称:admin
2021-04-21 17:23:06,610 - DEBUG - 输入用户密码:admin
2021-04-21 17:23:06,610 - DEBUG - 输入用户密码:admin
2021-04-21 17:23:06,790 - DEBUG - 登录中...请等待
2021-04-21 17:23:06,790 - DEBUG - 登录中...请等待
2021-04-21 17:23:09,806 - DEBUG - 登录中成功
2021-04-21 17:23:09,806 - DEBUG - 登录中成功
error.log
2021-04-21 17:23:03,381 - ERROR - test_user_login.py[:54] - 小慌慌,快看:报错了这里
Traceback (most recent call last):
File "/Users/ff/PycharmProjects_py3/Selenium_project/log/test_user_login.py", line 52, in test01_user_login_userError
assert alert.text == expected + 'test'
AssertionError: assert '账号不能为空' == '账号不能为空test'
- 账号不能为空test
? ----
+ 账号不能为空
打印到具体路径改造:更新到util.py文件
def get_logger():
import os
import logging.handlers
import datetime
import time
logger = logging.getLogger('mylogger')
logger.setLevel(logging.DEBUG)
path = os.path.dirname(os.path.dirname(__file__)) + '/logs'
data = time.strftime('%Y%m%d%H%M', time.localtime(time.time()))
print(path)
rf_handler = logging.handlers.TimedRotatingFileHandler(path+'/all_'+data+'.log', when='midnight', interval=1, backupCount=7,
atTime=datetime.time(0, 0, 0, 0))
rf_handler.setFormatter(logging.Formatter("%(asctime)s - %(levelname)s - %(message)s"))
f_handler = logging.FileHandler(path+'/error_'+data+'.log')
f_handler.setLevel(logging.ERROR)
f_handler.setFormatter(logging.Formatter("%(asctime)s - %(levelname)s - %(filename)s[:%(lineno)d] - %(message)s"))
logger.addHandler(rf_handler)
logger.addHandler(f_handler)
return logger
再次运行用户登录代码加日志打印,查看结果
但是不知道为啥会登录成功的all会打印出2行一样的日志,待解决!