功能测试框架可以包括:界面友好性测试、功能测试、链接测试、容错测试、稳定性测试、常规性能测试、配置测试、算法测试等等。
风格、样式、颜色是否协调;
界面布局是否整齐、协调(保证全部显示出来的,尽量不要使用滚动条;
界面操作、标题描述是否恰当(描述有歧义、注意是否有错别字);
操作是否符合人们的常规习惯(有没有把相似的功能的控件放在一起,方便操作);
提示界面是否符合规范(不应该显示英文的cancel、ok,应该显示中文的确定等);
界面中各个控件是否对齐;
日期控件是否可编辑;
日期控件的长度是否合理,以修改时可以把时间全部显示出来为准;
查询结果列表列宽是否合理、标签描述是否合理;
查询结果列表太宽没有横向滚动提示;
对于信息比较长的文本,文本框有没有提供自动竖直滚动条;
数据录入控件是否方便;
有没有支持Tab键,键的顺序要有条理,不乱跳;
有没有提供相关的热键;
控件的提示语描述是否正确;
模块调用是否统一,相同的模块是否调用同一个界面;
用滚动条移动页面时,页面的控件是否显示正常;
日期的正确格式应该是XXXX-XX-XX或XXXX-XX-XXXX:XX:XX;
页面是否有多余按钮或标签;
窗口标题或图标是否与菜单栏的统一;
窗口的最大化、最小化是否能正确切换;
对于正常的功能,用户可以不必阅读用户手册就能使用;
执行风险操作时,有确认、删除等提示吗;
操作顺序是否合理;
正确性检查:检查页面上的form,button,table,header,footer,提示信息,还有其他文字拼写,句子的语法等是否正确;
系统应该在用户执行错误的操作之前提出警告,提示信息;
页面分辨率检查,在各种分辨率浏览系统检查系统界面友好性;
合理性检查:做delete,update,add,cancel,back等操作后,查看信息回到的页面是否合理;
检查本地化是否通过:英文版不应该有中文信息,英文翻译准确,专业;
背景灰度冻结。
使用所有默认值进行测试;
根据所有产品文档、帮助文档中描述的内容要进行遍历测试;
输入判断;
所有界面出现是和否的逻辑,要测试;
异常处理;
敏感词;
根据需求文档的流程图遍历所有流程图路径;
根据程序内容,遍历ifelifelseswitch的逻辑点要遍历;
界面各种控件测试。
如对于输入框测试:
1、字符型输入框:
字符型输入框:英文全角、英文半角、数字、空或者空格、特殊字符“~!@#¥%……&*?[]{}”特别要注意单引号和&符号。禁止直接输入特殊字符时,使用“粘贴、拷贝”功能尝试输入;
长度检查:最小长度、最大长度、最小长度-1、最大长度+1、输入超工字符比如把整个文章拷贝过去。
空格检查:输入的字符间有空格、字符前有空格、字符后有空格、字符前后有空格;
多行文本框输入:允许回车换行、保存后再显示能够保存输入的格式、仅输入回车换行,检查能否正确保存(若能,检查保存结果,若不能,查看是否有正常提示);
安全性检查:输入特殊字符串。
(null,NULL,,javascript,<script>,</script>,<title>,<html>,<td>)、输入脚本函数(<script>alert("abc")</script>)、doucment.write("abc")、<b>hello</b>)
2、数值型输入框:
边界值:最大值、最小值、最大值+1、最小值-1;
位数:最小位数、最大位数、最小位数-1最大位数+1、输入超长值、输入整数;
异常值、特殊字符:输入空白(NULL)、空格或"~!@#$%^&*()_+{}|[]\:"<>?;',./?;:'-=等可能导致系统错误的字符、禁止直接输入特殊字符时,尝试使用粘贴拷贝查看是否能正常提交、word中的特殊功能,通过剪贴板拷贝到输入框,分页符,分节符类似公式的上下标等、数值的特殊符号如∑,㏒,㏑,∏,+,-等、
输入负整数、负小数、分数、输入字母或汉字、小数(小数前0点舍去的情况,多个小数点的情况)、首位为0的数字如01、02、科学计数法是否支持1.0E2、全角数字与半角数字、数字与字母混合、16进制,8进制数值、货币型输入(允许小数点后面几位);
安全性检查:不能直接输入就copy。
3、日期型输入框:
合法性检查:(输入0日、1日、32日)、月输入[1、3、5、7、8、10、12]、日输入[31]、月输入[4、6、9、11]、日输入[30][31]、输入非闰年,月输入[2],日期输入[28、29]、输入闰年,月输入[2]、日期输入[29、30]、月输入[0、1、12、13]考虑开始日期与结束日历的比较,特别是在查询的时候;
异常值、特殊字符:输入空白或NULL、输入~!@#¥%……&*(){}[]等可能导致系统错误的字符;
安全性检查:不能直接输入,就copy,是否数据检验出错。
业务流程,一般会涉及到多个模块的数据,所以在对业务流程测试时,首先要保证单个模块功能的正确性,其次就要对各个模块间传递的数据进行测试,这往往是容易出现问题的地方,测试时一定要设计不同的数据进行测试。
如某一功能模块具有最基本的增删改查功能,则需要进行以下测试:
单项功能测试(增加、修改、查询、删除)
增加——>增加——>增加(连续增加测试)
增加——>删除
增加——>删除——>增加(新增加的内容与删除内容一致)
增加——>修改——>删除
修改——>修改——>修改(连续修改测试)
修改——>增加(新增加的内容与修改前内容一致)
修改——>删除
修改——>删除——>增加(新增加的内容与删除内容一致)
删除——>删除——>删除(连续删除测试)
主要是保证链接的可用性和正确性,它也是网站测试中比较重要的一个方面。
可以使用特定的工具如XENU来进行链接测试。
输入系统不允许的数据作为输入;
把某个相关模块或者子系统停掉,验证对当前系统的影响;
配置文件删除或者配置错误;
数据库注入错误数据。
系统不间断运行(7*24),验证是否内存泄露、系统其他资源是否存在泄露;
如果很紧急上线,可以跑一晚上或者周末跑两天。
一般压力很大的情况下,数据库连接数问题、内存泄露问题会曝露的比较快但是死锁可能不能体现,所以要看系统重要性,如12306稳定性则最好7*24小时。
连接速度测试
用户连接到Web应用系统的速度根据上网方式的变化而变化,他们或许是电话拨号,或是宽带上网。当下载一个程序时,用户可以等较长的时间,但如果仅仅访问一个页面就不会这样。如果Web系统响应时间太长(例如超过5秒钟),用户就会因没有耐心等待而离开。
另外,有些页面有超时的限制,如果响应速度太慢,用户可能还没来得及浏览内容,就需要重新登陆了。而且,连接速度太慢,还可能引起数据丢失,使用户得不到真实的页面。
负载测试
负载测试是为了测量Web系统在某一负载级别上的性能,以保证Web系统在需求范围内能正常工作。负载级别可以是某个时刻同时访问Web系统的用户数量,也可以是在线数据处理的数量。例如:Web应用系统能允许多少个用户同时在线?如果超过了这个数量,会出现什么现象?Web应用系统能否处理大量用户对同一个页面的请求?
压力测试
负载测试应该安排在Web系统发布以后,在实际的网络环境中进行测试。因为一个企业内部员工,特别是项目组人员总是有限的,而一个Web系统能同时处理的请求数量将远远超出这个限度,所以,只有放在Internet上,接受负载测试,其结果才是正确可信的。
进行压力测试是指实际破坏一个Web应用系统,测试系统的反映。压力测试是测试系统的限制和故障恢复能力,也就是测试Web应用系统会不会崩溃,在什么情况下会崩溃。黑客常常提供错误的数据负载,直到Web应用系统崩溃,接着当系统重新启动时获得存取权。
压力测试的区域包括表单、登陆和其他信息传输页面等
系统界面的控件是否可以通过tab键遍历,并且顺序合理;
主要功能的入口和操作是否易于理解;
界面是否布局合理,功能是否易于查找和使用;
操作步骤;
操作习惯;
有足够的提示信息,且信息文字描述准确。
兼容性测试不只是指界面在不同操作系统或浏览器下的兼容,有些功能方面的测试,也要考虑到兼容性,包括操作系统兼容和应用软件兼容,可能还包括硬件兼容,比如涉及到ajax、jquery、javascript等技术的,都要考虑到不同浏览器下的兼容性问题。
除了上面所说的这些测试以外,还有算法测试、配置测试、安全性测试等等,在工作中不断总结和分析,形成自己的功能测试框架,当你把这份工作做起来以后,对于你自己对于测试团队而言都是一份很有价值的事情,你的测试思路也会变得更全面。
作者:bcbxhome
原文链接:http://blog.itpub.net/69985967/viewspace-2738414/