软件测试第2周个人作业:WordCount编码测试
一、Github地址
https://github.com/zhouyubei/WordCount
二、PSP表格
PSP2.1 |
PSP阶段 |
预估耗时 (分钟) |
实际耗时 (分钟) |
Planning |
计划 |
20 | 20 |
· Estimate |
· 估计这个任务需要多少时间 |
20 | 20 |
Development |
开发 |
1天 | 1.5天 |
· Analysis |
· 需求分析 (包括学习新技术) |
30 | 30 |
· Design Spec |
· 生成设计文档 |
- | - |
· Design Review |
· 设计复审 (和同事审核设计文档) |
- | - |
· Coding Standard |
· 代码规范 (为目前的开发制定合适的规范) |
- | - |
· Design |
· 具体设计 |
30 | 30 |
· Coding |
· 具体编码 |
1天 | 1.5天 |
· Code Review |
· 代码复审 |
60 | 60 |
· Test |
· 测试(自我测试,修改代码,提交修改) |
60 | 120 |
Reporting |
报告 |
140 | 140 |
· Test Report |
· 测试报告 |
60 | 60 |
· Size Measurement |
· 计算工作量 |
20 | 20 |
· Postmortem & Process Improvement Plan |
· 事后总结, 并提出过程改进计划 |
60 | 60 |
合计 |
2天 | 3天 |
三、解题思路
- 先实现基本功能,再实现扩展功能
- 由于java的知识忘得差不多了,先百度了一下java如何统计一个文件的字符数,单词数,行数,在此基础上做修改,详见参考文献1
- 实现命令行参数解析,参考2
- 实现统计空行、代码行、注释行和停用词表,参考3、4
- 未能实现递归处理目录文件
四、程序设计实现过程
由于程序较小,就仅使用了一个类main,有三个函数,主函数main(),参数解析函数getopt(),功能实现函数count(),主函数接收从命令行传来的参数,调用getopt()进行参数解析,并传给count()进行相应功能的实现并输出到文件中。
五、代码说明
1、参数解析函数getopt():
- 接收主函数传过来的参数数组args,创建一个Vector向量类optString用于存放解析后的参数。
- for循环体内判断args中的字符串与指定参数是否相等,若相等则加进optString中,若为-o或-e,则将后一字符串存进输出文件路径outPath或停用词表路径stopWordPath。
//参数解析
public static void getopt(String[] args) {
optString = new Vector<String>();
outPath = "result.txt";
for (int i = 0; i < args.length; i++) {
if (args[i].equals("-o")) {
if (++i == args.length) {
System.out.println("未输入输出文件路径名");
return;
}
outPath = args[i];
}
else if (args[i].equals("-e")) {
if (++i == args.length) {
System.out.println("未输入停用词表路径名");
return;
}
optString.addElement(args[i-1]);
stopWordPath = args[i];
}
else if (args[i].equals("-c") || args[i].equals("-w") || args[i].equals("-l")|| args[i].equals("-a"))
optString.addElement(args[i]);
else if (args[i].equals("-s"))
System.out.println("尚未实现-s功能");
else
inPath = args[i];
}
}
2、统计函数count()
- 读入文件并调用readLine()函数循环读入每一行。
- 统计字符个数和行数较为简单。
- 统计单词个数:运用split() 方法把一个字符串分割成字符串数组strArray。若不需过滤停用词,字符串数组的长度,就是单词个数。若启用停用词表,初始化停用词表时创建Vector向量类stopWord存放停用词,创建动态数组strList,运用contains()函数判断字符串数组strArray中的词是否存在于停用词表,若不存在则加入动态数组strList,单词个数即为strList长度。
- 运用正则表达式匹配判断代码行,空白行,注释行。若全为空或仅有一个字符为空白行,若注释符号“//”前没有或仅有一个字符为注释行,其余为代码行。
while((str = br.readLine()) != null)
{
charNum += str.length();//-c 字符个数就是字符长度
lineNum++;//-l 因为是按行读取,所以每次增加一即可计算出行的数目
//-w
if(!str.equals("")){//防止空行也会增加一个字符串
String[] strArray = str.split(" |,|\\t");//split() 方法用于把一个字符串分割成字符串数组,字符串数组的长度,就是单词个数
//-e 过滤停用词
if (optString.contains("-e")){
ArrayList<String> strList = new ArrayList<String>();
strList.clear();
for(int i = 0; i<strArray.length; i++){
if(!stopWord.contains(strArray[i]))
strList.add(strArray[i]);
}
wordNum += strList.size();
}
else
wordNum += strArray.length;
}
//-a 代码行,空白行,注释行
if (Pattern.matches("\\s*.?\\s*", str))
blankLineNum++;
else if(Pattern.matches("\\s*.?\\s*//.*", str))
commentLineNum++;
else
codeLineNum++;
}
六、测试设计过程
1、未能写出测试脚本,均是在cmd控制台测试。语句覆盖就是要保证设计的测试用例应至少覆盖函数中所有的可执行语句,为此,我针对main类中的getopt方法,使用语句覆盖指标设计测试用例,共产生如下10个测试用例。
1、wc.exe -c file.c -o output.txt:结果会输出到output.txt中
2、wc.exe -c file.c -o:提示未输入输出文件路径名
3、wc.exe -w file.c -e stop.txt:启用停用词表,计算单词数时停用词表中的词不计入在内
4、wc.exe -w file.c -e:提示未输入停用词表路径名
5、wc.exe -w file.c -e stop1.txt:该停用词表文件不存在,会提示系统找不到指定的文件
6、wc.exe -c:提示空指针
7、wc.exe -c file1.c:该源文件不存在,会提示系统找不到指定的文件
8、wc.exe -s:提示尚未实现-s功能
9、wc.exe -c -w -l -a file.c:统计字符数、单词数、行数,结果输出到默认文件result.txt
10、wc.exe -a file.c:统计空白行数、代码行数、空白行数,结果输出到默认文件result.txt
2、针对main类中的count方法,使用语句覆盖指标设计测试用例,共产生如下7个测试用例,为源文件file.c中内容。停用词表中内容为“a”。
int a
a,b
}
c d //gg
}//
3、评价:语句覆盖被认为是“最弱的覆盖”,原因是它仅仅考虑对代码中的执行语句进行覆盖而没有考虑各种条件和分支,优点是可以很直观地从源代码得到测试用例,无须细分每条判定表达式。缺点是由于这种测试方法仅仅针对程序逻辑中显式存在的语句(即可执行语句),但对于隐藏的条件和可能到达的隐式逻辑分支,是无法测试的。所以满足程序测试要求还需更多测试。
七、参考文献
- http://blog.csdn.net/ycy0706/article/details/45457311
- http://blog.csdn.net/ksu99/article/details/157602
- http://blog.csdn.net/u013930303/article/details/44872155
- http://blog.csdn.net/javaniuniu/article/details/53454749
- 参照同学:https://github.com/Asfalas/WordCount
- 参照同学:https://github.com/Wegnery/WordCount
软件测试第2周个人作业:WordCount编码测试的更多相关文章
- 软件测试第4周小组作业:WordCount优化
一.基本任务:代码编写+单元测试 1.Github地址: https://github.com/Wegnery/New_WordCount 2.PSP2.1表格 PSP2.1 PSP阶段 预估耗时 ( ...
- 第二周个人作业WordCount
1.Github地址 https://github.com/JingzheWu/WordCount 2.PSP表格 PSP2.1 PSP阶段 预估耗时 (分钟) 实际耗时 (分钟) Planning ...
- 软件测试作业——WordCount的测试
一.代码提交 1.代码地址:https://gitee.com/zst1978805482/WordCount 2.作业地址:https://edu.cnblogs.com/campus/xnsy/T ...
- WordCount编码测试
Github项目地址:https://github.com/LantyrLYL/WordCount PSP表格: PSP2.1 PSP阶段 预估耗时 (分钟) 实际耗时 (分钟) Planning 计 ...
- 软件测试第二周个人作业:WordCount
github地址:https:/github.com/muzhailong/wc.git 第一次写博客很不容易,也算是一个好的开始吧. 1. 个人作业要求 作业简述:根据WordCount的需求描 ...
- 实验十一 团队作业7—团队项目设计完善&编码测试
实验十一 团队作业7—团队项目设计完善&编码测试 实验时间 2018-6-8 Deadline: 2018-6-20 10:00,以团队随笔博文提交至班级博客的时间为准. 评分标准: 按时交 ...
- 结队第二次作业——WordCount进阶需求
结队第二次作业--WordCount进阶需求 博客地址 051601135 岳冠宇 博客地址 051604103 陈思孝 博客地址 Github地址 具体分工 队友实现了爬虫功能,我实现了wordco ...
- c++ 西安交通大学 mooc 第十三周基础练习&第十三周编程作业
做题记录 风影影,景色明明,淡淡云雾中,小鸟轻灵. c++的文件操作已经好玩起来了,不过掌握好控制结构显得更为重要了. 我这也不做啥题目分析了,直接就题干-代码. 总结--留着自己看 1. 流是指从一 ...
- 软件测试第六周学习笔记之“Win8 APP应用程序的白盒测试”
这周的学习笔记我想写点自己关于实验中碰到的问题和感想. 因为这次做的是白盒测试,所以我决定去测试一下上回测试的app的功能函数. 这次我用的是单元测试项目来做的白盒测试: 创建单元测试的步骤: 1.点 ...
随机推荐
- 前端小白页面开发注意事项及小工具(html\css\js)
技术一直在向前发展.但是有一些是相通的,要找准重点,将80%的时间放在提升基础问题上,余下的20%再去学习框架,库和工具. HTML 1. HTML 属性应当按照以下给出的顺序依次排列,确保代码的易读 ...
- 19-SQLServer定期自动导入数据的dtsx部署
一.注意点 1.登录Integration Service必须使用windows用户,并且只能在本地服务器登录. 2.SQLServer2000以前,叫dts,全程Data Transformatio ...
- bzoj1497: [NOI2006]最大获利(最小割)
传送门 第一眼看去:好难 第二眼:不就是个裸的最大权闭合子图么…… 我们从源点向所有用户连边,容量为收益,用户向自己的中转站连边,容量为INF,中转站向汇点连边,容量为费用 那么总收益-最小割就是答案 ...
- 牛客国庆集训派对Day6 && CCPC-WannaFly-Camp #1 F. kingdom(DP)
题目链接:https://www.nowcoder.com/acm/contest/206/F 题意:一棵 n 个点的树,根为 1,重儿子到父亲的费用为 0,其余为 1,问所有点到 1 的最大总费用是 ...
- MySQL索引-B+树(看完你就明白了)
索引是一种数据结构,用于帮助我们在大量数据中快速定位到我们想要查找的数据.索引最形象的比喻就是图书的目录了.注意这里的大量,数据量大了索引才显得有意义,如果我想要在 [1,2,3,4] 中找到 4 这 ...
- laravel事件监听器
在EventServiceProvide文件里注册事件和监听 protected $listen = [ 'App\Events\SendPhoneCodeEvent' => [ 'App\Li ...
- @WebServlet @WebListener @WebListener
- Java实现浏览器大文件分片上传
上周遇到这样一个问题,客户上传高清视频(1G以上)的时候上传失败. 一开始以为是session过期或者文件大小受系统限制,导致的错误. 查看了系统的配置文件没有看到文件大小限制, web.xml中s ...
- luogu 4047 [JSOI2010]部落划分 最小生成树
最小生成树或者二分都行,但是最小生成树会好写一些~ Code: #include <bits/stdc++.h> #define ll long long #define N 100000 ...
- dup2函数
将当前系统中的进程信息打印到文件中 命令行:ps aux > out 将ps得到的信息重定向到out文件中 使用dup2文件在程序中完成. int dup2(int oldfd,int newf ...