【为项目添加日志】logging日志加到之前项目中运用,并优化日志打印到自定义路径
2023-09-11 14:17:00 时间
前言
一直想学习自动化测试,但是都没行动,业余时间学习零零碎碎并记录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行一样的日志,待解决!
“永不放弃,总有希望在前面等待!”送给自己,也送给正在阅读文章的博友们~
相关文章
- (六)Net Core项目使用Controller之一 c# log4net 不输出日志 .NET Standard库引用导致的FileNotFoundException探究 获取json串里的某个属性值 common.js 如何调用common.js js 筛选数据 Join 具体用法
- 项目期复习总结1:背景图合并,hack,浏览器内核前缀,伪类after before
- 六家入围国家机关采购项目供应商-国产Linux操作系统
- sell 项目 商品表 设计 及 创建
- 微服务轮子项目(15) -审计日志
- 【Java】Spring boot、Mysql项目部署到Linux中后启动日志慢8小时(时区不对/时区错误)
- 【为项目添加日志】logging的四大组件:Logger、Handler、Filter和Formatter
- 【快应用】Win7系统使用华为IDE无法运行和调试项目
- 《嵌入式系统开发之道——菜鸟成长日志与项目经理的私房菜》——02-07 项目质量(Quality)管理
- NVIDIA公司的半成品项目cule——GPU端运行的Atari2600游戏环境——已经废弃的项目
- Tomcat日志、项目中的log4j日志、控制台——我的日志最后到底跑哪去了?
- C#使用log4net记录日志(项目中用的此方法,在类库里面写的)
- 项目中遇到的问题
- Vuex内容解析和vue cli项目中使用状态管理模式Vuex
- 审计系统---堡垒机项目之用户交互+session日志写入数据库[完整版]
- 信息系统项目文档及其管理
- windows開始菜单和任务栏图标显示空白而且点击时候显示项目已被移动或删除
- 关于web项目,可以利用相关的jar包快速构建,实现数据同步、内网穿透、消息推送、日志监听等功能,快速实现web通用功能,专注与业务代码的实现即可,主要技术aop、netty、jdbc、Socket
- Android项目的目录结构
- git项目代码一次push,同时上传到多个git仓库地址,并保证多个仓库代码同步一致