python自动化之BeautifulReport显示异常的解决方案

简介: 早起,开心的来到公司,批量运行着我那闪耀的IOS设备,一切正常,非常完美。我愉快的点开测试报告,出现了以下另我痛彻心扉的一幕~

python自动化之BeautifulReport显示异常的解决方案

1、显示异常

早起,开心的来到公司,批量运行着我那闪耀的IOS设备,一切正常,非常完美。

我愉快的点开测试报告,出现了以下另我痛彻心扉的一幕~

请添加图片描述

真的,大家相信我,领导也要相信我,昨天下午我下班前运行之后报告还是很完美的,非常好的。

我点开昨天的报告,令我瞠目结舌的一幕出现了,竟然和上图显示的完全一致,我是,失忆了?

注:我的版本是BeautifulReport-0.1.3,镜像源是 http://pypi.douban.com/simple

我委屈,我惶恐,我羞恼啊!

西克秀,我堂堂一名,一名,点王!对,就是点王,我就不信我结局不了这个小问题,无非是上天让我再水一篇文罢了(不是)!

2、解决过程

(不想看解决过程的小伙伴可以直接拉到最后的总结哦,直接搬运即可!)

(1)问题分析

首先,它在前端页面显示不正常,并且我的数据,也都显示不出来,右侧的饼图也是没有显示出来。

其次,看过BeautifulReport源码的小伙伴们都知道,它的报告是以template下的template.html文件作为模板生成的,数据是由我们测试用例里面运行传输过去的。

最后,由于我昨天的报告显示是正常的,今天打开却显示不正常,故,我大胆推断,是前端资源加载出了问题!

(2)推断验证

既然我们推断出,是前端资源加载出现了问题,那这个事情就好办了,打开页面,直接按F12,ctrl+r强制刷新,看下Network即可发现端倪。

请添加图片描述

原来是资源404了,找不着了(一般可能由于cdn有波动导致的,过几个小时或者等一天就会恢复,但正常来说,不知道是这个原因的,肯定头都裂开,再说,万一今天领导就要看报告呢?)

(3)解决方案

既然是资源加载的问题,那我们找到template.html的所有href和src,把它们都修改掉

template.html所在的目录为Lib\site-packages\BeautifulReport\template\template.html

修改源头,一劳永逸。如果是你当前的报告看不了,那也是找到所有的link进行修改。
请添加图片描述
请添加图片描述

为什么修改的是这两个呢?

前面我们的分析和验证结果就是,资源加载出错,你可以根据前端的报错,把对应的资源换掉,当报错太多,懒得一个个去看去核对,那可以直接找准这些引用了外部资源的代码,宁可错杀一千,不可放过一个!

这时候,问题又来了,我知道是它出了问题,那我怎么改???

① cdnjs

这篇文章的第一个重点来了,讲了这么多就是为了引出它,cdnjs,网址为https://cdnjs.com/libraries

请添加图片描述

那么如何找我们需要的资源呢?举个例子

<link href="https://cdn.bootcss.com/bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet">

这条使我们template.html里面找不到资源的一条,那我们如何找到可替代它的呢?

直接搜索bootstrap,找到我们需要的那一个

请添加图片描述

https://cdnjs.cloudflare.com/ajax/libs/bootstrap/5.2.0/css/bootstrap.min.css

其他的以此类推。

href替换cdnjs的如下:

<link href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap/5.2.0/css/bootstrap.min.css" rel="stylesheet">
<link href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.1.2/css/fontawesome.min.css" rel="stylesheet">
<link href="https://cdnjs.cloudflare.com/ajax/libs/animate.css/4.1.1/animate.min.css" rel="stylesheet">
<link href="https://cdnjs.cloudflare.com/ajax/libs/chosen/1.8.7/chosen.css" rel="stylesheet">

scr替换cdnjs的如下:

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap/5.2.0/js/bootstrap.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/echarts/5.3.3/echarts.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/chosen/1.8.7/chosen.jquery.js"></script>

但是有个问题,cdnjs是国外的,我们网络如果不能访问外网,加载则会很慢,甚至一直转圈圈加载不出来,所以这里引出第二个重点,国内cdn加速。

② 国内加速

上面一节说道,cdnjs.cloudflare.com是使用的国外的,现在需要改成国内的,修改方式也非常简单,只需要将所有链接中的cdnjs.cloudflare.com替换成cdn.bootcdn.net即可。

href替换cdnjs的如下:

<link href="https://cdn.bootcdn.net/ajax/libs/bootstrap/5.2.0/css/bootstrap.min.css" rel="stylesheet">
<link href="https://cdn.bootcdn.net/ajax/libs/font-awesome/6.1.2/css/fontawesome.min.css" rel="stylesheet">
<link href="https://cdn.bootcdn.net/ajax/libs/animate.css/4.1.1/animate.min.css" rel="stylesheet">
<link href="https://cdn.bootcdn.net/ajax/libs/chosen/1.8.7/chosen.css" rel="stylesheet">

scr替换cdnjs的如下:

<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<script src="https://cdn.bootcdn.net/ajax/libs/bootstrap/5.2.0/js/bootstrap.min.js"></script>
<script src="https://cdn.bootcdn.net/ajax/libs/echarts/5.3.3/echarts.min.js"></script>
<script src="https://cdn.bootcdn.net/ajax/libs/chosen/1.8.7/chosen.jquery.js"></script>

③ 新问题,页面数据有,排版有问题

请添加图片描述

F12检查,资源没有任何问题,控制台有个看不懂的报错

请添加图片描述

我们一个一个排查,去报告里面锁定这一行

请添加图片描述

按住ctrl+鼠标左键进入这个tooltip,我们发现跳转到了一个bootstrap.min.js文件

请添加图片描述

那现在问题很显然,我们的cdn里面的bootstrap.min.js是问题的,我们把这两个犯错的孩子伶出来批斗!

你们两个怎么回事?

<link href="https://cdn.bootcdn.net/ajax/libs/bootstrap/5.2.0/css/bootstrap.min.css" rel="stylesheet">

<script src="https://cdn.bootcdn.net/ajax/libs/bootstrap/5.2.0/js/bootstrap.min.js"></script>    

所以,这又该如何解决呢?这里就引出我们第二个重点——BootCDN - Bootstrap 中文网开源项目免费 CDN 加速服务,网址https://www.bootcdn.cn/

④ BootCDN

请添加图片描述

直接搜索我们需要找的bootstrap,点击进入

请添加图片描述

请添加图片描述

找到我们需要的,这里我找出来了

<link href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/5.2.0/css/bootstrap.min.css" rel="stylesheet">
    
<script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/5.2.0/js/bootstrap.min.js"></script>

但由于BeautifulReport这个项目是2019年的,可能会存在兼容方面的问题,故我们需要将大版本保持一致,回到cdnjs中查找发现是有3.3.5这个版本,于是乎我再次替换。(保持大版本一致即可,3开头就行,如3.3.7)。

另外href和src的bootstrap版本也需要一致哦。其他的同理。

最后再去我们报告或者是template.html里面替换掉。

(4)最终替换链接

href替换的如下:

<link href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet">
<link href="https://cdn.bootcdn.net/ajax/libs/font-awesome/6.1.2/css/fontawesome.min.css" rel="stylesheet">
<link href="https://cdn.bootcdn.net/ajax/libs/animate.css/4.1.1/animate.min.css" rel="stylesheet">
<link href="https://cdn.bootcdn.net/ajax/libs/chosen/1.8.7/chosen.css" rel="stylesheet">

scr替换的如下:

<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.3.5/js/bootstrap.min.js"></script>
<script src="https://cdn.bootcdn.net/ajax/libs/echarts/5.3.3/echarts.min.js"></script>
<script src="https://cdn.bootcdn.net/ajax/libs/chosen/1.8.7/chosen.jquery.js"></script>

3、伪一劳永逸的方法

把这次我们的这些链接一个个去浏览器中打开,右键全选复制,自己再创建一个文件夹,创建对应名字的文件,把内容粘贴过去,这样,就再也不用担心访问出错的问题了。

弊端

1.需要绝对路径,如果是相对路径,你还需要在生成报告的地方将文件夹再次复制到同等的相对路径下

2.发给别人,别人看不了,因为别人本地没有。

3.不能做永远的懒汉。

总结

解决方案一

在html报告或者BeautifulReport下的template.html文件中:

href替换的如下:

<link href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet">
<link href="https://cdn.bootcdn.net/ajax/libs/font-awesome/6.1.2/css/fontawesome.min.css" rel="stylesheet">
<link href="https://cdn.bootcdn.net/ajax/libs/animate.css/4.1.1/animate.min.css" rel="stylesheet">
<link href="https://cdn.bootcdn.net/ajax/libs/chosen/1.8.7/chosen.css" rel="stylesheet">

scr替换的如下:

<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.3.5/js/bootstrap.min.js"></script>
<script src="https://cdn.bootcdn.net/ajax/libs/echarts/5.3.3/echarts.min.js"></script>
<script src="https://cdn.bootcdn.net/ajax/libs/chosen/1.8.7/chosen.jquery.js"></script>

解决方案二

把这次我们的这些链接一个个去浏览器中打开,右键全选复制,自己再创建一个文件夹,创建对应名字的文件,把内容粘贴过去,这样,就再也不用担心访问出错的问题了。

弊端

1.需要绝对路径,如果是相对路径,你还需要在生成报告的地方将文件夹再次复制到同等的相对路径下

2.发给别人,别人看不了,因为别人本地没有。

3.不能做永远的懒汉。

相关实践学习
Serverless极速搭建Hexo博客
本场景介绍如何使用阿里云函数计算服务命令行工具快速搭建一个Hexo博客。
相关文章
|
12天前
|
Java 测试技术 持续交付
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
本文重点讲解如何搭建App自动化测试框架的思路,而非完整源码。主要内容包括实现目的、框架设计、环境依赖和框架的主要组成部分。适用于初学者,旨在帮助其快速掌握App自动化测试的基本技能。文中详细介绍了从需求分析到技术栈选择,再到具体模块的封装与实现,包括登录、截图、日志、测试报告和邮件服务等。同时提供了运行效果的展示,便于理解和实践。
48 4
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
|
7天前
|
存储 Python
Python自动化脚本编写指南
【10月更文挑战第38天】本文旨在为初学者提供一条清晰的路径,通过Python实现日常任务的自动化。我们将从基础语法讲起,逐步引导读者理解如何将代码块组合成有效脚本,并探讨常见错误及调试技巧。文章不仅涉及理论知识,还包括实际案例分析,帮助读者快速入门并提升编程能力。
27 2
|
9天前
|
运维 监控 Python
自动化运维:使用Python脚本简化日常任务
【10月更文挑战第36天】在数字化时代,运维工作的效率和准确性成为企业竞争力的关键。本文将介绍如何通过编写Python脚本来自动化日常的运维任务,不仅提高工作效率,还能降低人为错误的风险。从基础的文件操作到进阶的网络管理,我们将一步步展示Python在自动化运维中的应用,并分享实用的代码示例,帮助读者快速掌握自动化运维的核心技能。
23 3
|
8天前
|
数据采集 IDE 测试技术
Python实现自动化办公:从基础到实践###
【10月更文挑战第21天】 本文将探讨如何利用Python编程语言实现自动化办公,从基础概念到实际操作,涵盖常用库、脚本编写技巧及实战案例。通过本文,读者将掌握使用Python提升工作效率的方法,减少重复性劳动,提高工作质量。 ###
22 1
|
15天前
|
运维 监控 应用服务中间件
自动化运维:如何利用Python脚本提升工作效率
【10月更文挑战第30天】在快节奏的IT行业中,自动化运维已成为提升工作效率和减少人为错误的关键技术。本文将介绍如何使用Python编写简单的自动化脚本,以实现日常运维任务的自动化。通过实际案例,我们将展示如何用Python脚本简化服务器管理、批量配置更新以及监控系统性能等任务。文章不仅提供代码示例,还将深入探讨自动化运维背后的理念,帮助读者理解并应用这一技术来优化他们的工作流程。
|
13天前
|
Web App开发 测试技术 数据安全/隐私保护
自动化测试的魔法:使用Python进行Web应用测试
【10月更文挑战第32天】本文将带你走进自动化测试的世界,通过Python和Selenium库的力量,展示如何轻松对Web应用进行自动化测试。我们将一起探索编写简单而强大的测试脚本的秘诀,并理解如何利用这些脚本来确保我们的软件质量。无论你是测试新手还是希望提升自动化测试技能的开发者,这篇文章都将为你打开一扇门,让你看到自动化测试不仅可行,而且充满乐趣。
|
6天前
|
机器学习/深度学习 人工智能 TensorFlow
人工智能浪潮下的自我修养:从Python编程入门到深度学习实践
【10月更文挑战第39天】本文旨在为初学者提供一条清晰的道路,从Python基础语法的掌握到深度学习领域的探索。我们将通过简明扼要的语言和实际代码示例,引导读者逐步构建起对人工智能技术的理解和应用能力。文章不仅涵盖Python编程的基础,还将深入探讨深度学习的核心概念、工具和实战技巧,帮助读者在AI的浪潮中找到自己的位置。
|
6天前
|
机器学习/深度学习 数据挖掘 Python
Python编程入门——从零开始构建你的第一个程序
【10月更文挑战第39天】本文将带你走进Python的世界,通过简单易懂的语言和实际的代码示例,让你快速掌握Python的基础语法。无论你是编程新手还是想学习新语言的老手,这篇文章都能为你提供有价值的信息。我们将从变量、数据类型、控制结构等基本概念入手,逐步过渡到函数、模块等高级特性,最后通过一个综合示例来巩固所学知识。让我们一起开启Python编程之旅吧!
|
6天前
|
存储 Python
Python编程入门:打造你的第一个程序
【10月更文挑战第39天】在数字时代的浪潮中,掌握编程技能如同掌握了一门新时代的语言。本文将引导你步入Python编程的奇妙世界,从零基础出发,一步步构建你的第一个程序。我们将探索编程的基本概念,通过简单示例理解变量、数据类型和控制结构,最终实现一个简单的猜数字游戏。这不仅是一段代码的旅程,更是逻辑思维和问题解决能力的锻炼之旅。准备好了吗?让我们开始吧!