软件质量与测试——WordCount编码实现及测试
1.GitHub地址
https://github.com/noblegongzi/WordCount
2.PSP表格
| PSP2.1 | PSP 阶段 | 预估耗时 (分钟) | 实际耗时 (分钟) |
|---|---|---|---|
| Planning | 计划 | 30 | 50 |
| · Estimate | · 估计这个任务需要多少时间 | 600 | 840 |
| Development | 开发 | 600 | 840 |
| · Analysis | · 需求分析 | 30 | 40 |
| · Design Spec | · 生成设计文档 | 20 | 30 |
| · Design Review | · 设计复审 | 10 | 20 |
| · Coding Standard | · 代码规范 | 300 | 360 |
| · Design | · 具体设计 | 20 | 90 |
| · Coding | · 具体编码 | 300 | 720 |
| · Code Review | · 代码复审 | 60 | 120 |
| · Test | · 测试 | 20 | 30 |
| Reporting | 报告 | 30 | 60 |
| · Test Report | · 测试报告 | 20 | 20 |
| · Size Measurement | · 计算工作量 | 5 | 10 |
| · Postmortem & Process Improvement Plan | · 事后总结, 并提出过程改进计划 | 10 | 10 |
| 合计 | 600 | 840 |
3.解题思路
这个项目需要解决的是几大问题,第一是对文档的操作,我在学习编码时对这一块没有上心,所以拿到任务后先自己复习了下C++对文档的操作方法。其次是该问题最重要的部分,即如何将一连串字符串分解成单个单词,并对其计数,这个通过if语句对字符串中的字符进行甄别,看是否是特殊的几个分词符就行了。但是我听同学说可以用正则表达式,代码书写更简单,有机会我会改进。
还有个最难的问题是我在谋划之初没有想到的,就是对输入的命令进行分析,首先要判断输入的命令是否正确,因为有了前面把字符串分成一个一个单词的经验,所以这里我是采取依次甄别每个单词的方法,用编译原理所学的自顶向下的分析方法来判断命令的正确性,顺便得到命令的结果组成,从而轻易判断用户输入的文件名是什么。在确定命令正确之后,进而分析命令的要求。由于确定了命令的正确性,这里对命令的分析就简单些,只要找到命令的关键字眼,就可以判定命令的意图,从而执行相关的操作。这里使用C++中String类的find()函数,查找诸如-c,-w,-l,-o等关键词汇。
4.程序实现过程
首先我先完成对文档的输入输出,通过编译程序写好file.c文件,做好实现程序的准备工作。
其次,我实现了程序的基本功能,即对现有的file.c文件进行字符单词行数计数。
再则,我实现对命令的正确性判断,确保程序的正常运行。
然后,我对命令的内容进行分析,从而根据各项命令完善程序功能,使前后台对接。
最后是对程序输出的排版进行规范,及代码复审。
5.关键代码展示
1)对命令行进行分析确保命令正确,并识别出用户提供的文件名。
if (order1.find("wc.exe")!=string::npos)
{
if (order2.find("-c") != string::npos || order2.find("-w") != string::npos || order2.find("-l") != string::npos )
if (order3.find("-c") != string::npos || order3.find("-w") != string::npos || order3.find("-l") != string::npos )
if (order4.find("-c") != string::npos || order4.find("-w") != string::npos || order4.find("-l") != string::npos)
{
filename = order5;
if (order6.find("-o") != string::npos)
outputfilename = order7;
}
else
{
filename = order4;
if (order5.find("-o") != string::npos)
outputfilename = order6;
}
else
{
filename = order3;
if (order4.find("-o") != string::npos)
outputfilename = order5;
}
else
{
cout << "命令错误,请重新输入:\n";
}
}
else
{
cout << "命令错误,请重新输入:\n";
}//确定命令输入无误。
2)对用户提供的文件进行统计,得到关键数据
fin.open(filename);
cout << "文件中内容如下:"<<endl;
while (fin.get(ch))
{
cout << ch;
charnumber++;
if (ch == ' ' || ch == ',' || ch == '\n' || ch == '\t'&&prech != && prech != ','&&prech != '\n'&&prech != '\t')
{
wordnumber++;
}
if (ch == '\n')
{
linenumber++;
}
prech = ch;
}
cout << endl;
if (charnumber == )
{
wordnumber = ;
linenumber = ;
}
//统计字符数,单词数,行数。 if (ch != ' ' || ch != ',' || ch != '\n' || ch != '\t')
{
wordnumber++;
}
fin.close();
3)对命令进行分析,确定程序具体实行哪些操作
if (order.find("-c") != string::npos)
{
coutchar(filename, charnumber);
}
if (order.find("-w") != string::npos)
{
coutword(filename, wordnumber);
}
if (order.find("-l") != string::npos)
{
coutline(filename, linenumber);
}
fin.open("result.txt");
while (fin.get(ch))
{
cout << ch;
}
fin.close();
if(order.find("-o") != string::npos)
{
output(outputfilename, charnumber, wordnumber, linenumber);
}
//执行命令
6.测试设计过程
测试用例:将所有可能的命令格式输入,分别测试。
1.wc.exe -c file.c

2.wc.exe -w file.c

3.wc.exe -l file.c

4.wc.exe -c -l file.c

5.wc.exe -c -w -l file.c

6.wc.exe -c file.c -o outputfile.txt


7.wc.exe -c -l file.c -o outputfile.txt


8.wc.exe -c -w -l file.c -o outputfile.txt


修改file.c文件内容再次进行测试。
9.wc.exe -c -w -l file.c

10.wc.exe -c -w -l file.c -o outputfile.txt


程序高风险:输入文件名过长会导致string超出范围,程序崩溃。
7.参考文献
《C++ Primer Plus》。
软件质量与测试——WordCount编码实现及测试的更多相关文章
- WordCount编码和测试
WordCount编码和测试 项目地址:https://github.com/handsomesnail/WordCount PSP表格 PSP2.1 PSP阶段 预估耗时(分钟) 实际耗时(分钟) ...
- WordCount 编码与测试
word count github 项目地址:https://github.com/liuqiang666/wordCount PSP表格 PSP2.1 PSP阶段 预估耗时(小时) 实际耗时( ...
- 编码的UI测试项目——Visual Studio 2013
今天实现了一次编码的UI测试项目,以下是我进行测试的过程: 1.新建测试项目 在visual studio中(我用的版本是2013 update2)点击文件->新建->项目,选择“编码的U ...
- 使用Visual Studio 2013对windows应用商店应用进行编码的UI测试
之前进行了一次实验,实验内容是对windows应用商店应用进行编码的UI测试,下面对实验步骤进行详细说明: 1.为 Windows 应用商店应用创建新编码的 UI 测试项目,选择Visual C##→ ...
- 关于VS2013的编码的UI测试。
1. 打开VS2013,选择文件→新建→项目 2. 弹出的选项左侧选择visual C#中的测试,中间选择框选择编码的UI测试项目,确定后就产生的测试项目. 3. 弹出框选择默认的录制操作巴拉巴 ...
- python函数式编程,性能,测试,编码规范
这篇文章主要是对我收集的一些文章的摘要.因为已经有很多比我有才华的人写出了大量关于如何成为优秀Python程序员的好文章. 我的总结主要集中在四个基本题目上:函数式编程,性能,测试,编码规范.如果一个 ...
- 为Visual Studio添加一个“编码的UI测试生成器”的快捷方式
在添加CodedUI测试用例时,经常需要查看捕获控件的属性.按照常规的方式,只有在添加一个全新的CodedUI编码测试时才能查看捕获控件的属性,这样很不方便. 下面介绍在Visual Studio工具 ...
- Assignment5: 使用Visual Studio 进行可编码的UI测试
一.实验目的: 使用Visual Studio 可编码的UI测试功能创作自动化测试 二.实验原理:黑盒测试 三.实验需求:win8 app.Visual Studio Ultimate 2012/20 ...
- Pytest权威教程11-模块及测试文件中集成doctest测试
目录 模块及测试文件中集成doctest测试 编码 使用doctest选项 输出格式 pytest-specific 特性 返回: Pytest权威教程 模块及测试文件中集成doctest测试 编码 ...
随机推荐
- UVA - 11270 轮廓线DP
其实这题还能用状压DP解决,可是时间达到2000ms只能过掉POJ2411.状压DP解法详见状压DP解POJ2411 贴上POJ2411AC代码 : 2000ms 时间复杂度h*w*(2^w)*(2^ ...
- HDU - 1067 Gap (bfs + hash) [kuangbin带你飞]专题二
题意: 起初定28张卡牌的排列,把其中11, 21, 31, 41移动到第一列,然后就出现四个空白,每个空白可以用它的前面一个数的下一个数填充,例如43后面的空格可以用44填充,但是47后面即 ...
- Kaggle新手入门之路
学完了Coursera上Andrew Ng的Machine Learning后,迫不及待地想去参加一场Kaggle的比赛,却发现从理论到实践的转变实在是太困难了,在此记录学习过程. 一:安装Anaco ...
- 关联规则—频繁项集Apriori算法
频繁模式和对应的关联或相关规则在一定程度上刻画了属性条件与类标号之间的有趣联系,因此将关联规则挖掘用于分类也会产生比较好的效果.关联规则就是在给定训练项集上频繁出现的项集与项集之间的一种紧密的联系.其 ...
- Centos7 上安装配置 RabbitMQ
前言: 最近服务器上搭建了一下rabbitmq, 网上找了很多教程, 采了灰常灰常多的坑. 现在终于从坑里面爬出来了.赶紧写下来,避免下次掉坑里面 好了,废话不多说,下面步入正题 一.安装Erl ...
- JLINK 10针J和20针JTAG接口连接方法
我的JLINK终于用上了,哈哈,好开心,终于不用考虑是不是要借用别人的PC机了,昨天到城隍庙电子市场忙活了一下午,终于算是满载而归,呵呵,好了,下面说一下接法,其实根本不需要什么转接板什么的,直接把相 ...
- Windows 7 蓝屏原因
Windows 7 蓝屏 Microsoft (R) Windows Debugger Version 6.11.0001.404 X86 Copyright (c) Microsoft Corpor ...
- AXI总线简介
AXI全称Advanced eXtensible Interface,是Xilinx从6系列的FPGA开始引入的一个接口协议,主要描述了主设备和从设备之间的数据传输方式.在ZYNQ中继续使用,版本是A ...
- linux虚拟机中安装mongodb
今天在linux虚拟机中安装了mongodb数据库,安装过程主要参照了网上的一片文档,大部分地方都没有多大区别,只是在某些细节上有所改变. 我参考的文档是:http://my.oschina.net/ ...
- httpclient的主要业务代码逻辑(图解)
一,主要代码逻辑(图解) 二,两个案例的对比(图解) 三,详细案例 3.1,博文一 httppost的用法(NameValuePair(简单名称值对节点类型)核心对象) 3.2,博文二 httpcli ...