A. 前端自动化测试框架Jest 基础入门-
一、引言
前端这几年发展的非常迅速,我们的系统的功能正在变的越来越复杂,这对我们的前端工程化能力提出了更高的要求,听到工程化,大家的第一反应肯定是高质量的代码设计和高质量的代码实现。
但实际上,前端 自动化测试 也是前端工程化里面非常重要的一个环节。
二、 Jest 基础入门
一个普通前端听到自动化测试,第一反应可能是:我工作这么多年也没写过测试,这个东西有用吗?
答:非常有用
如果你打开GitHub,去看一下流行的开源库或者框架的源码,你会发现,在这些源码里面,全部都包含了大量的自动化测试的代码。比如antd、lodash、再比如vue、react、echarts、rex等等……
开源的工具需要稳定性,而引入前端自动化测试为开源项目提供稳定性,是再好不过的选择了。
三、学习前提
阅读这篇 文章 需要以下知识储备:
·js、es6 基础语法
·node、npm 相关知识
·git 的相关操作
·react或者vue,至少了解一个
·状态管理工具,至少了解一个
四、背景及原理
首先在任意目录下创建一个math.js文件,假设这个文件是一个数学库,里面定义两个函数,分别是加法和减法:
// math.js
function add(a, b) {
return a + b;
}
function minus(a, b) {
return a - b;
}
这时候我们可以在业务代码里去使用这个数学库。
但是,假如,上面的minus函数我们不小心写错了,把减法写成了乘法,如果直接在业务代码中使用这个方法,就会带来无法预期的bug。
所以这时候,我们就需要对math.js这个公共库进行自动化测试,确保没问题之后,再让业务组件去调用,这样就会保证不会出特别多的bug了。
我们可以这样做:
在该目录下创建一个math.test.js文件,然后写一点测试代码:
const result = add(3, 7);
const expect = 10;
if (result !== expect) {
throw new Error(`3 + 7 应该等于${expect},结果却是${result}`);
}
const result = minus(3, 3);
const expect = 0;
if (result !== expect) {
throw new Error(`3 - 3 应该等于${expect},结果却是${result}`);
}
这时候我们运行这段代码,会发现没有抛出任何异常,说明这两个 测试用例 都通过了。
这就是自动化测试最原始的雏形。
然后我们思考一个问题,如何将这堆代码进行简化,做成一个公用的函数,比如这样:
// 测试 3 + 3 是否等于 6
expect(add(3, 3)).toBe(6);
// 测试 3 - 3 是否等于 0
expect(minus(3, 3)).toBe(0);
expect 方法实现:
function expect(result) {
return {
toBe(actual) {
if (result !== actual) {
throw new Error("预期值和实际值不相等");
}
},
};
}
这时候我们运行这段代码,会发现没有抛出任何异常,说明这两个测试用例都通过了。
虽然实现了 expect 函数,但是报错的内容始终是一样的,我们不知道是具体哪个方法出现了问题,这时候我们就会想到,我们需要将这个 expect 方法进一步做改良,我们如果能在 expect 方法外部再包装一层,就可以多传递一些额外的内容,比如创造这样的写法:
test("测试加法 3 + 3", () => {
expect(add(3, 3)).toBe(6);
});
test("测试减法 3 - 3", () => {
expect(minus(3, 3)).toBe(0);
});
这样封装之后,我们既能进行测试,又能得到测试的描述。
test 方法实现:
function test(desc, fn) {
try {
fn();
console.log(`${desc} 通过测试`);
} catch {
console.log(`${desc} 没有通过测试`);
}
}
所以前端自动化测试到底是什么?
答:实际上就是写了一段其它的用来测试的js代码,通过测试代码去运行业务代码,判断实际结果是否满足预期结果,如果满足,就是没有问题,如果不满足,就是有问题。
上面实现的 expect 方法 和 test 方法 实际上和主流的前端自动化测试框架 jest 里面的语法是完全一致的。所以上面的示例代码可以理解为 jest 的底层实现原理。
B. 前端网站常规优化方案
1、减少请求次数
2、减小资源大小
3、提高响应和加载速度
4、优化资源加载时机
5、优化加载方式
1、合并、压缩、混淆html/css/js文件(webpack实现,减小资源大小)
2、Nginx开启Gzip,进一步压缩资源(减小资源大小)
3、图片资源使用CDN加速(提高加载速度)
4、符合条件的图标做base64处理(减小资源大小)
5、样式表放首部,JS放尾部(JS单线程,会阻塞页面;资源加载方式)
6、设置缓存(强缓存和协商缓存,提高加载速度)
7、link或者src添加rel属性,设置prefetch或preload可预加载资源。(加载时机)
8、如果使用了UI组件库,采用按需加载(减小资源大小)
9、SPA项目,通过import或者require做路由按需(减小资源大小)加载
10、服务端渲染SSR,加快首屏渲染,利于SEO
11、页面使用骨架屏,提高首页加载速度(提高加载速度)
12、使用 JPEG 2000, JPEG XR, and WebP 的图片格式来代替现有的jpeg和png,当页面图片较多时,这点作用非常明显
13、使用图片懒加载-lazyload
C. 前端测试有哪几种类型
目前在软件系统开发中,测试是一个非常重要的环节,特别是前端测试,有几种类型的测试被认为是前端测试所必需的,让我们简单了解一下。
01
单元测试
在修复bug或添加一点功能时,软件的其他部分可能会停止工作。为了处理这种情况,单元测试将代码的各个部分分开,以单独检查其准确性。跳过或最小化单元测试可能会导致修复缺陷的成本增加。Javascript单元测试包括一个套件中有组织的测试数量,这些测试彼此不冲突,并且相互之间的依赖性更少。
02
端到端测试
端到端测试涵盖了应用程序从头到尾的流程,结束测试跟踪用户的旅程,如打开浏览器、导航,并体验完整的生产场景。端到端测试验证互连系统和软件系统,它包括一个完整的前端和后端系统。
03
集成测试
集成测试的目的是使模块/组件按预期运行。集成测试技术应用于许多模块紧密耦合的大型应用中,模块被单独测试,一旦集成,组合行为被验证,它是与开发并行进行的。在集成测试中,您需要更多的逻辑技能,因为在测试期间,某些模块可能尚未准备就绪或正在构建中。
集成时使用测试存根和驱动程序,集成测试将分析开发人员实现的逻辑是否遵循规定的标准。当模块与第三方API交互时,查看响应非常重要。当开发人员跳过单元测试时,集成测试就不可避免了。
04
功能测试
功能测试,用于验证应用程序或网站对目标用户能正确工作。使用适当的平台、浏览器和测试脚本,以保证目标用户的体验将足够好。功能测试是为了确保程序以期望的方式运行而按功能要求对软件进行的测试,通过对一个系统的所有的特性和功能都进行测试确保符合需求和规范。
05
可视化/用户界面测试
视觉/UI测试包括屏幕截图的验证。这是一项质量保证活动,旨在确保屏幕在任何设备、屏幕分辨率、浏览器和操作系统上的外观与预期一致。通过无头浏览器中捕获的不同屏幕截图比较渲染版本的结果,可视化回归测试允许您检测偏差。
在构建应用程序时,事情会变得过载和复杂,这种情况很容易破坏现有的功能并引入新的bug—单元、行为和集成测试将到位,以使应用程序稳定。
06
性能/压力测试
性能测试是一种非功能性技术,它在各种工作负载下检查软件的稳定性、响应性、速度、可靠性和资源使用等系统参数。
压力测试:应用程序被重载以检查意外行为并了解其承受能力。
为网站执行一个高质量的前端测试将提高生产力,并增加客户对您的服务的依赖。了解趋势通用模式并结合专家经验来定义质量测试套装是很重要的。
07
跨浏览器测试
Web端应用测试主要障碍之一就是在不同的浏览器上“测试他们的网站/应用程序”,也称为“跨浏览器测试”或者“兼容性测试”。浏览器和浏览器版本很多(Google Chrome,Mozilla Firefox,Internet Explorer,Microsoft Edge,Opera,Yandex等),可以通过多种设备(通过台式机,笔记本,智能手机,平板电脑等)访问网站/应用。)以及可能用于访问网站的多种操作系统(Windows,MacOS,Linux,Android,iOS等)。
要确保网站的UI/UX及其功能正常运行,并且在“浏览器+浏览器版本+操作系统+设备配置”的组合上没有任何BUG,则将需要大量的开发,测试和维护工作。
D. 前端(6)开发自己的组件库+初步测试
使用vue的脚手架来搭建项目,这里使用webpack-simple模板
出现提示直接Enter确认即可
然后根据提示,运行上面后三行的命令,开始运行项目
根据下图所示修改目录结构,主要有两处
这是一个最基本的Element-ui的入口文件,返回一个带有install方法的对象
在按照 Element-ui 的目录结构编写完一套最基本的框架后,现在开始配置打包发布的文件 webpack.config.js 。我们需要修改项目的入口文件以及输出配置
如果你想在发布之前简单测试一下组件库,可以进行如下操作:
1. 搭建自己的 vue 组件库(三)—— npm 上面发布自己的组件库
E. 前端如何提升开发效率
来具体聊一聊提高前端工程师开发效率的那些方法!
当然除了以上5点,对于前端来说需要提高开发效率的地方还有很多,可谓任重而道远。希望以上几点能够给初识前端的同学带来启发并能够亲自实践。
F. 常用的前端性能优化方法有哪些
常用的优化有两部分
第一:面向内容的优化
1. 减少 HTTP 请求
2. 减少 DNS 查找
3. 避免重定向
4. 使用 Ajax 缓存
5. 延迟载入组件
6. 预先载入组件
7. 减少 DOM 元素数量
8. 切分组件到多个域
9. 最小化 iframe 的数量
10. 不要出现http 404 错误
第二:面向 Server
1. 缩小 Cookie
2. 针对 Web 组件使用域名无关性的
G. 前端怎么优化大数据页面
来源:前端的性能优化都有哪些东西?作者:野次前端性能优化是个巨大的课题,如果要面面俱到的