• 1. 链接测试

       1.1 测试点:

  • 是否添加链接
  • 链接页面是否存在
  • 链接页面与需求是否一致:页面的正确性、打开方式 等      

       一般,该链接测试在集成测试阶段(页面均开发完成)的时候进行

       1.2 测试工具:

  • Xenu Link Sleuth 免费 绿色免安装软件

  • HTML Link Validator 共享(30天试用)

       1.3 延伸代码:

    测试工具在实际应用时,其实是挺受限的。有时候,需要自己写点小代码去验证,主要用于系统回归。

    比如:

    

 //        封装判断web链接返回状态是否为2开头的
public static void ReadUrl(String surl){
try {
URL url = new URL(surl);
URLConnection rulConnection = url.openConnection();
HttpURLConnection httpUrlConnection = (HttpURLConnection) rulConnection;
httpUrlConnection.setConnectTimeout(300000);
httpUrlConnection.setReadTimeout(300000);
httpUrlConnection.connect();
String code = new Integer(httpUrlConnection.getResponseCode()).toString();
String message = httpUrlConnection.getResponseMessage();
// System.out.println("getResponseCode code ="+ code);
// System.out.println("getResponseMessage message ="+ message);
if(!code.startsWith("2")){
throw new Exception(surl+"ResponseCode is not begin with 2,code="+code);
}
// 打印链接返回状态码
// System.out.println(getDateTime()+"连接"+surl+"正常");
}catch(Exception ex){
// System.out.println(surl+ex.getMessage());
}
} // 封装模拟发起post请求一
public static String sendPost(String strUrl, String content, String charset) {
URL httpurl = null;
HttpURLConnection httpConn = null;
String returnStr = "";
PrintWriter outs = null;
try {
httpurl = new URL(strUrl);
httpConn = (HttpURLConnection) httpurl.openConnection();
httpConn.setRequestMethod( "POST"); // 默认是post
// 设置是否向httpUrlConnection输出,因为这个是post请求,参数要放在 http正文内,因此需要设为true, 默认情况下是false;
httpConn.setDoOutput( true);
// 设置是否从httpUrlConnection读入,默认情况下是true;
httpConn.setDoInput( true);
httpConn.setRequestProperty( "Content-Type", "text/xml");
outs = new PrintWriter(httpConn.getOutputStream());
outs.print(content);
outs.flush();
outs.close();
// 字节流 读取全部内容 包括换行符
returnStr = inputStreamToString(httpConn.getInputStream(), charset);
} catch (Exception e) {
logger.error( "执行HTTP Post请求" + strUrl + "时,发生异常!" , e);
if(outs != null){
outs.close();
outs = null;
}
return returnStr;
} finally {
if (httpConn != null)
httpConn.disconnect();
if(outs != null){
outs.close();
outs = null;
}
}
return returnStr;
} // 封装读取请求响应的内容
public static String inputStreamToString(InputStream in,String encoding) throws Exception{
ByteArrayOutputStream outStream = new ByteArrayOutputStream();
byte[] data = new byte[1024];
int count = -1;
while((count = in.read(data,0, 1024)) != -1)
outStream.write(data, 0, count);
in.close();
data = null;
return new String(outStream.toByteArray(),encoding);
}
   void((function() {
var cars=new Array();//定义了数组,最终返回的是列表 cars=document.getElementsByTagName("a");//获取对应对象
/*cars=$("a")*/
for(var i =0;i<cars.length;i++){
var href_name;
item_name = cars[i].href; //获取对应url地址
if(item_name.indexOf("***")!=-1){
console.info(item_name);
}
} })())
var xmlhttp;
function loadXMLDoc(url)
{
xmlhttp=null;
if (window.XMLHttpRequest)
{// code for Firefox, Mozilla, IE7, etc.
xmlhttp=new XMLHttpRequest();
}
else if (window.ActiveXObject)
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
if (xmlhttp!=null)
{
xmlhttp.onreadystatechange=state_Change;
xmlhttp.open("GET",url,true);
xmlhttp.send(null);
}
else
{
alert("Your browser does not support XMLHTTP.");
}
} function state_Change()
{
if (xmlhttp.readyState==4)
{// 4 = "loaded"
if (xmlhttp.status==200)
{// 200 = "OK"
document.getElementById('p1').innerHTML=xmlhttp.getAllResponseHeaders();
}
else
{
alert("Problem retrieving data:" + xmlhttp.statusText);
}
}
}

  • 2. 表单测试

        2.1 测试点:

  • 默认值
  • 必输项
  •  输入验证:输入框的特殊文本控制(比如电话、邮箱、url地址等)、长字符、特殊字符、正负数、小数位数等。
  • 上传测试:大小、格式类型等
  •  表单操作:增删改查,完整性、正确性。

       一般,配合下面的数据校验等方面一起测试的,故这里的测试点可能不全。

       2.2  测试工具:

      WinRunner(QTP)等

先手动检查,后可以用该工具回归了。

      2.3 延伸代码:

    可以写个简单的js实现

    

 void((function(){
var select = document.getElementsByTagName('select');
for(var jj=0;jj<select.length;jj++){
selectedNode = select[jj].options;
/*取出select的所有选项值*/
for (var i=0;i<selectedNode.length;i++){
selectoption=selectedNode[i].innerHTML;
// console.info(selectoption); }
/*随机赋值*/
/*随机赋值*/
$(select[jj]).get(0).selectedIndex=1;
var checkText= $(select[jj]).find("option:selected").text();
console.info(checkText);
$(select[jj]).click; }
})()) //一般的文本框任意赋值
void((function() {
var i = document.getElementsByTagName('input');
for (var jj = 1; jj <= i.length-4; jj++) {
i[jj].value = "cs";
}
})())

也可以使用代码等,比如selenium等。


  • 3. 数据校验

      3.1 测试点:

  •  配合2的测试,验证表单数据的正确及完整性:单页面、单系统或多系统。
  •  数据的增删改查:比如代码任务的计算等

      该方面的测试,与每个系统特异性有关,故不全。

      3.2 测试工具:同上

      3.3 代码延伸


  • 4. cookies测试

      4.1 测试点:

  •  是否使用cookies:根据需求设计,确定是否使用了cookies。比如说需求需要将选择的类目保存到cookie,关闭浏览器然后再试;或者某些不能使用cookie等。
  •  cookies其他使用需求验证:比如使用 cookie 来统计次数,需要验证次数累计正确。

      该方面的测试,与每个系统特异性有关,故不全。

      4.2 测试工具:

      IECookiesView v1.50

Cookies Manager v1.1

     


  • 5. 数据库测试

5.1 测试点

我目前测试接触到的数据是oracle、mysql。

主要测试数据库的经历是oracle,哎呀,但是换了工作后,好几年不碰了,下次整理了。

  • sql语句的性能及优化

5.2 测试工具

使用及测试的工具可能是1个,可能是多个联合

TOAD for Oracle(Mysql)


  • 6. 应用程序特定的功能需求

    深刻理解需求说明文档

    比如

  •  与第三平台之间的交互等
  •  session测试:同个浏览器打开两个页面,一个页面权限失效后,另一个页面是否可操作成功等。

  • 7. 控件等技术应用测试

       7.1 测试点

  • 是否满足使用需求
  • 界面显示是否正常
  • 控件的正确性:多种操作后是否正常等

      

WEB测试—功能测试的更多相关文章

  1. Web测试——功能测试

    由于本人工作接触Web测试,所以我从网上找的资料,学习了解web测试哪些内容,然后自己整理汇总的随笔,如文章中有不足的地方,请大家多多指教:或者文章内容与他人相似,望见谅. 功能测试: 1.链接测试: ...

  2. 关于web端功能测试的测试方向

    一.功能测试 1.1链接测试 链接是web应用系统的一个很重要的特征,主要是用于页面之间切换跳转,指导用户去一些不知道地址的页面的主要手段,链接测试一般关注三点: 1)链接是否按照既定指示那样,确实链 ...

  3. (转载)关于web端功能测试的测试方向

    一.功能测试 1.1链接测试 链接是web应用系统的一个很重要的特征,主要是用于页面之间切换跳转,指导用户去一些不知道地址的页面的主要手段,链接测试一般关注三点: 1)链接是否按照既定指示那样,确实链 ...

  4. Web测试的常用测试用例与知识

    1. Web测试中关于登录的测试 2. 搜索功能测试用例设计 3. 翻页功能测试用例 4. 输入框的测试 5. Web测试的常用的检查点 6. 用户及权限管理功能常规测试方法 7. Web测试之兼容性 ...

  5. web测试常用的用例及知识

      1.      Web测试中关于登录的测试... 1 2.      搜索功能测试用例设计... 2 3.      翻页功能测试用例... 3 4.      输入框的测试... 5 5.    ...

  6. app测试与web测试的区别

    1.从功能测试的来讲的话,在流程和功能测试上是没有区别的.系统测试和一些细节可能会不一样. 那么我们就要先来了解,web和app的区别. web项目,一般都是b/s架构,基于浏览器的,而app则是c/ ...

  7. 关于web测试

    关于web测试1页面部分(1) 页面清单是否完整(是否已经将所需要的页面全部都列出来了)(2) 页面是否显示(在不同分辨率下页面是否存在,在不同浏览器版本中页面是是否显示)(3) 页面在窗口中的显示是 ...

  8. Web 测试经验总结

    Web功能测试常用方法 1.页面链接检查每一个链接是否都有对应的页面,并且页面之间切换正确: 2.相关性检查删除/增加一项会不会对其他项产生影响,如果产生影响,这些影响是否都正确. 3.检查按钮的功能 ...

  9. 【转】web测试内容及工具经典总结

    基于Web的系统测试在基于Web的系统开发中,如果缺乏严格的过程,我们在开发.发布.实施和维护Web的过程中,可能就会碰到一些严重的问题,失败的可能性很大.而且,随着基于Web的系统变得越来越复杂,一 ...

随机推荐

  1. jquery ui dialog弹出窗 清空缓存Cache或强制刷新

    我用jquery ui 弹出一个购物车的对话,通过AJAX加载的数据.发现购物车被缓存,一直看到是旧数据.为了刷新购物车更新,我必须去加一个刷新按钮,点击后更新购物车页面.有没有一种方法来自动刷新加载 ...

  2. ngnix优化【转】

    nginx的优化 1. gzip压缩优化 2. expires缓存有还 3. 网络IO事件模型优化 4. 隐藏软件名称和版本号 5. 防盗链优化 6. 禁止恶意域名解析 7. 禁止通过IP地址访问网站 ...

  3. Springboot简单整合Rabbit

    两个项目.分别是生产者和消费者项目 .首先引入依赖.两边pom都一样 第一次练习,启动生产者后,再启动消费者,一直报找不到 队列的声明. 后排查发现是  需要现在生产者这边浏览器访问一次生产消息的方法 ...

  4. MyBaits_查询缓存02_Ehcache二级缓存

    一.Ehcache二级缓存的开启 导入jar(https://github.com/mybatis/ehcache-cache/releases) <cache type="org.m ...

  5. java.lang.NullPointerException: Attempt to invoke virtual method 'java.util.List com.yunweather.app.db.YunWeatherDB.loadProvinces()' on a null object reference

    NullPointerException:查看自己的什么地方是否对空指针进行了操作 Attempt to invoke virtual method 'java.util.List com.yunwe ...

  6. websocket 和 dwr 做web端即时通信

    一.WebSocket是HTML5出的东西(协议),也就是说HTTP协议没有变化,或者说没关系,但HTTP是不支持持久连接的(长连接,循环连接的不算) 首先HTTP有1.1和1.0之说,也就是所谓的k ...

  7. div居中方式

    1. position: absolute; top:50%:left: 50%; margin-top: -高度的一半; margin-left: -宽度的一半(此方法适用于固定宽高的元素) 注: ...

  8. 【转载】从创业者角度看《印度合伙人 Padman》后的一点感受

    ***************************** 这部电影看简介是真实事件改编的,当时除了电影本身的精彩和主角宠妻狂魔之外,印象最深的就是感觉到主角的创业者心态是一步步在生活中被培养的.特别 ...

  9. 实现移动端touch事件的横向滑动列表效果

    要实现手机端横向滑动效果并不难,了解实现的原理及业务逻辑就很容易实现.原理:touchstart(手指按下瞬间获取相对于页面的位置)——>touchmove(手指移动多少,元素相应移动多少). ...

  10. linux 的 磁盘管理

    1. 查看信息 1.1 查看磁盘信息 在linux中如果需要查看磁盘信息,需要使用df和du命令. df: 列出文件系统中整个磁盘的使用量 du:评估文件系统中磁盘的使用量,经常用来推算目录所占的容量 ...