zl程序教程

您现在的位置是:首页 >  其他

当前栏目

【为项目添加日志】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行一样的日志,待解决!

 

 

“永不放弃,总有希望在前面等待!”送给自己,也送给正在阅读文章的博友们~