前端单元测试基础介绍
前端单元测试
入门与实践
一个实例
在一个统计客户端信息的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验证
相关推荐:
- [小学教育]四年级综合实践活动课《衣物的洗涤》教
- [小学教育]2014半年工作总结怎么写
- [小学教育]20世纪外国文学专题综合试题及答案
- [小学教育]TS_1循环使用催化丙烯环氧化反应研究
- [小学教育]最实用的考勤签到表(上下班签到表)
- [小学教育]气候与生态建筑——以新疆民居为例
- [小学教育]二人以上股东有限责任公司章程参考样本
- [小学教育]2014届第一轮复习资料4.1,3美好生活的
- [小学教育]土方开挖、降水方案
- [小学教育]手绘儿童绘本《秋天的图画》(蜡笔)
- [小学教育]2002级硕士研究生卫生统计学考试试题
- [小学教育]环保装备重点发展目录
- [小学教育]金蝶K3合并报表培训教材
- [小学教育]岩浆岩试题及参考答案
- [小学教育]知之深爱之切学习心得
- [小学教育]第十二章 蛋白质的生物合成
- [小学教育]Chapter 2-3 Solid structure and basi
- [小学教育]市政道路雨季专项施工方案
- [小学教育]中国海洋大学2012-2013学年第二学期天
- [小学教育]教育心理学第3章-学习迁移
- 浅谈深化国企改革中加强党管企业
- 2006年中国病理生理学会学术活动安排
- 设计投标工作大纲
- 基于ARP的网络攻击与防御
- 2016届湖北省七市(州)教科研协作体高三
- Google_学术搜索及其检索技巧
- 2019-2020学年七年级地理下册6.3美洲教
- 城市道路可研报告
- 【名师指津】2012高考英语 写作基础技
- 6级知识点培训北京师范大学《幼儿智趣
- 注册会计师会计知识点:金融资产
- 新安装 500 kV 变压器介损分析与判断
- PS2模拟器PCSX2设置及使用教程.
- 医院药事管理与药剂科管理组织机构
- {PPT背景素材}丹巴的醉人美景,免费,一
- NAS网络存储应用解决方案
- 青海省西宁市六年级上学期数学期末考试
- 测量管理体系手册依据ISO10012:2003
- 洞子小学培养骨干教师工作计划
- 浅谈《牛津初中英语》的教材特点及教学




