教学文库网 - 权威文档分享云平台
您的当前位置:首页 > 文库大全 > 小学教育 >

前端单元测试基础介绍

来源:网络收集 时间:2026-04-27
导读: 前端单元测试 入门与实践 一个实例 在一个统计客户端信息的js中,写一个方法, 从userAgent字符串获取浏览器引擎,名称, 版本号等信息,要求能处理最常用的一些 浏览器 function _getBrowserInfo(ua) { …… …… return oBrowser; } 最后采用的形式 这个方

前端单元测试

入门与实践

一个实例

在一个统计客户端信息的js中,写一个方法,

从userAgent字符串获取浏览器引擎,名称,

版本号等信息,要求能处理最常用的一些

浏览器

function _getBrowserInfo(ua) { …… …… return oBrowser; }

最后采用的形式

这个方法的测试用例

YUI().use("test", function (Y) { window.Y = Y; var testCaseBrowser = new Y.Test.Case({ setUp: function () { this.testFun = window._getBrowserInfo; }, testBrowserName: function () { for (var i = 0; i < testData.length; i++) { var ua = testData[i][0].toLowerCase(); oResult = this.testFun(ua); Y.Assert.areEqual( testData[i][1], oResult['navName'], ua); } }, …… }) //add the test cases and suites suite.add(testCaseGetInfo); ………… //run all tests Y.Test.Runner.add(suite); Y.Test.Runner.run(); });

执行测试

多浏览器自动执行测试用 例

代码的演化过程

从最开始的需求,到现在最后的成品代码+测试

用例,中间是如何演化的?

原始需求

在一个统计客户端信息的js中,写一个方法, 从userAgent字符串获取浏览器引擎,名称, 版本号等信息,要求能处理最常用的一些 浏览器

我们开始设想和编写 代码 if (!window['analizer']) {

window['analizer'] = new function () { var ua=erAgent; …… self._getBrowserInfo = function { /** * code to process useragent string */ …… return oBrowser; } }

我们需要支持常用各 大浏览器 于是我们刻苦钻研,甚至找了曾哥写出了超简一

行正则出结果的代码

function _getBrowserInfo(ua) { var oBrowser = {}; var match = ua.match(/(opera|ie|firefox|chrome|version)[\s\/:]([\w\d\.]+)?.*?(safari|version[\s\/:]([\w\d\.]+)|$)/) || [null, 'unknown', 0]; var mode = match[1] == 'ie' && document.documentMode; oBrowser['browserName'] = (match[1] == 'version') ? match[3] : match[1]; oBrowser['browserVersion'] = mode || ((match[1] == 'opera' && match[4]) ? match[4] : match[2]); oBrowser['browserLanguage'] = (navigator['browserLanguage'] || navigator['language']).toLowerCase(); return oBrowser; }

一行正则检测五大浏览器名字,版本号,语言

然后我们来验证

依次打开各大浏览器,逐个检验,ok啦~

接着要获取操作系统 信息

我们刻苦钻研,甚至找了曾哥写出了简洁获取系

统信息的代码。

function _getOSInfo() { var oOS = {}; ………… return oOS; }

然后我们来验证

打开目前使用的系统上各大浏览器验证一下 打开虚拟机跑xp验证一下 打开虚拟机跑Linux验证一下 打开mac验证一下

发现了一个bug!

修改代码,本例中代码互不影响,如果

有时候进行了抽象和提取,修改基础方 法还需要回归所有功能 下

验证:打开当前系统五大浏览器验证一 打开虚拟机跑xp验证一下 打开虚拟机跑linux验证一下 打开mac验证

…… 此处隐藏:23字,全部文档内容请下载后查看。喜欢就下载吧 ……
前端单元测试基础介绍.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.jiaowen.net/wenku/40691.html(转载请注明文章来源)
Copyright © 2020-2025 教文网 版权所有
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:78024566 邮箱:78024566@qq.com
苏ICP备19068818号-2
Top
× 游客快捷下载通道(下载后可以自由复制和排版)
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能出现无法下载或内容有问题,请联系客服协助您处理。
× 常见问题(客服时间:周一到周五 9:30-18:00)