Visual Studio 单元测试的简单应用

写在前面

  笔者根据作业的介绍以及Visual Studio 2017 文档的相关说明,进行了Visual Studio 单元测试的简单应用。

Tips Link
课程链接 2019春季计算机学院软件工程(罗杰)(北京航空航天大学)
实验作业链接 [2019BUAA软工助教]第0次代码作业
实验成果连接 GitHub
参考文献 Visual Studio 2017 文档

单元测试代码

  单元测试从以下三方面展开:

  1. 四则运算正确性;
  2. 四则运算组合后计算的正确性;
  3. 要求范围内所有整数运算的正确性;
#include "stdafx.h"
#include "CppUnitTest.h"
#include "../Calculator/Calculator.h" using namespace Microsoft::VisualStudio::CppUnitTestFramework; namespace CalculatorUnitTest
{
TEST_CLASS(Test)
{
public:
Calculator* calc; TEST_METHOD_INITIALIZE(initCal)
{
calc = new Calculator();
} TEST_METHOD_CLEANUP(CleanCal)
{
delete calc;
calc = NULL;
} /*
简单测试
*/ TEST_METHOD(SimpleADD)
{
string ret = calc->Solve("11+22");
Assert::AreEqual(ret, (string)"11+22=33");
} TEST_METHOD(SimpleSUB)
{
string ret = calc->Solve("77-33");
Assert::AreEqual(ret, (string)"77-33=44");
} TEST_METHOD(SimpleMUL)
{
string ret = calc->Solve("55*66");
Assert::AreEqual(ret, (string)"55*66=3630");
} TEST_METHOD(SimpleDIV)
{
string ret = calc->Solve("99/33");
Assert::AreEqual(ret, (string)"99/33=3");
} /*
组合测试
*/ TEST_METHOD(ADD_ADD)
{
string ret = calc->Solve("22+33+11");
Assert::AreEqual(ret, (string)"22+33+11=66");
} TEST_METHOD(ADD_SUB)
{
string ret = calc->Solve("22+33-11");
Assert::AreEqual(ret, (string)"22+33-11=44");
} TEST_METHOD(ADD_MUL)
{
string ret = calc->Solve("22+33*11");
Assert::AreEqual(ret, (string)"22+33*11=385");
} TEST_METHOD(ADD_DIV)
{
string ret = calc->Solve("22+33/11");
Assert::AreEqual(ret, (string)"22+33/11=25");
} TEST_METHOD(SUB_ADD)
{
string ret = calc->Solve("99-66+77");
Assert::AreEqual(ret, (string)"99-66+77=110");
} TEST_METHOD(SUB_SUB)
{
string ret = calc->Solve("99-22-55");
Assert::AreEqual(ret, (string)"99-22-55=22");
} TEST_METHOD(SUB_MUL)
{
string ret = calc->Solve("77-6*11");
Assert::AreEqual(ret, (string)"77-6*11=11");
} TEST_METHOD(SUB_DIV)
{
string ret = calc->Solve("77-88/2");
Assert::AreEqual(ret, (string)"77-88/2=33");
} TEST_METHOD(MUL_ADD)
{
string ret = calc->Solve("22*33+11");
Assert::AreEqual(ret, (string)"22*33+11=737");
} TEST_METHOD(MUL_SUB)
{
string ret = calc->Solve("22*33-11");
Assert::AreEqual(ret, (string)"22*33-11=715");
} TEST_METHOD(MUL_MUL)
{
string ret = calc->Solve("22*33*99");
Assert::AreEqual(ret, (string)"22*33*99=71874");
} TEST_METHOD(MUL_DIV)
{
string ret = calc->Solve("22*33/11");
Assert::AreEqual(ret, (string)"22*33/11=66");
} TEST_METHOD(DIV_ADD)
{
string ret = calc->Solve("99/9+11");
Assert::AreEqual(ret, (string)"99/9+11=22");
} TEST_METHOD(DIV_SUB)
{
string ret = calc->Solve("99/9-10");
Assert::AreEqual(ret, (string)"99/9-10=1");
} TEST_METHOD(DIV_MUL)
{
string ret = calc->Solve("99/9*22");
Assert::AreEqual(ret, (string)"99/9*22=242");
} TEST_METHOD(DIV_DIV)
{
string ret = calc->Solve("99/9/11");
Assert::AreEqual(ret, (string)"99/9/11=1");
} /*
运算数长度
*/
TEST_METHOD(Length_1)
{
string ret = calc->Solve("9/3*2+8");
Assert::AreEqual(ret, (string)"9/3*2+8=14");
} TEST_METHOD(Length_2)
{
string ret = calc->Solve("90/3*22+8");
Assert::AreEqual(ret, (string)"90/3*22+8=668");
} TEST_METHOD(Length_3)
{
string ret = calc->Solve("90/30*2+89");
Assert::AreEqual(ret, (string)"90/30*2+89=95");
}
}; }

Bug修复

  经过调试,对源程序的以下三个部分进行修复。

string Calculator::Solve(string formula) {
vector<string>* tempStack = new vector<string>();
stack<char>* operatorStack = new stack<char>();
int len = formula.length();
int k = 0;
for (int j = -1; j < len - 1; j++) {
char formulaChar = formula[j + 1];
if (j == len - 2 || formulaChar == '+' || formulaChar == '-' ||
formulaChar == '*' || formulaChar == '/') {
if (j == len - 2) {
tempStack->push_back(formula.substr(k));
}
else {
if (k <= j) { // 判断条件错误:k < j ===> k <= j
/*
substr 使用错误:
tempStack->push_back(formula.substr(k, j + 1));
*/
/*----------修改后----------*/
tempStack->push_back(formula.substr(k, j - k + 1));
/*--------------------------*/
}
if (operatorStack->empty()) {
operatorStack->push(formulaChar);
}
else {
char stackChar = operatorStack->top();
if ((stackChar == '+' || stackChar == '-')
&& (formulaChar == '*' || formulaChar == '/')) {
operatorStack->push(formulaChar);
}
else {
/*
to_string 使用错误:
tempStack->push_back(to_string(operatorStack->top()));
*/
/*----------修改后----------*/
string tempOp(1, operatorStack->top());
tempStack->push_back(tempOp);
/*--------------------------*/
operatorStack->pop();
operatorStack->push(formulaChar);
}
}
}
k = j + 2;
}
}
// 以下略。
  • 错误一导致一位数计算时无法将字符串中的数字截取插入临时栈(tempStack)。
  • 错误二导致截取数字时截取到错误的长度的子串。
  • 错误三会将运算符转换为相应的ASCII码,导致插入临时栈的为数字字符串而非运算符字符串。

[2019BUAA软工]第0次代码作业的更多相关文章

  1. [BUAA软工]第0次个人作业

    [BUAA软工]第0次个人作业 本次作业所属课程 : 2019BUAA软件工程 本次作业要求: 第0次个人作业 我在本课程的目标: 熟悉软件工程流程,规范开发习惯 本次作业的帮助: 熟悉课程流程 Pa ...

  2. [2017BUAA软工]第0次个人作业

    第一部分:结缘计算机 1.你为什么选择计算机专业?你认为你的条件如何?和这些博主比呢? 我觉得我选择计算机系完全是误打误撞吧.当时我的分数上北航是没问题的,所以填专业时就是机械,电气,自动化,计算机等 ...

  3. 2017[BUAA软工]第0次个人作业

    第一部分:结缘计算机 1.你为什么选择计算机专业?你认为你的条件如何?和这些博主比呢? ●其实填写志愿之前并不知道要学什么专业,当初选择计算机是因为计算机就业前景好.方向多.计算机应用的领域无处不在, ...

  4. [2019BUAA软工助教]第0次代码作业

    [2019BUAA软工助教]第0次代码作业 前言 本博客为完成结对项目所需的先导知识,题目不难,请认真对待 :) 欢迎来到软件工程 :) 注:本次实验为附加作业,不做不扣分,做了有附加分 Part 0 ...

  5. [2019BUAA软工助教]第0次个人作业

    [2019BUAA软工助教]第0次个人作业 一.前言 我认为人生就是一次次地从<存在>到<光明>. 二.软件工程师的成长 博客索引 同学们在上这门课的时候基本都是大三,觉得在大 ...

  6. [2019BUAA软工助教]结对编程 - 小结

    [2019BUAA软工助教]结对编程 - 小结 一.评分规则 博客 博客共五十分 序号 要求 分值 1 在文章开头给出Github项目地址 1 2 在开始实现程序之前,在下述PSP表格记录下你估计将在 ...

  7. [2019BUAA软工助教]第一次阅读 - 小结

    [2019BUAA软工助教]第一次阅读 - 小结 一.评分规则 总分 16 分,附加 2 分,共 18 分 markdown格式统一且正确 - 2分 不统一:扣 1 分 不正确:扣 1 分(例如使用代 ...

  8. 《软工实践》第零次作业 - 一些QA

    <软工实践>第零次作业 - 一些QA Q&A (1)回想一下你初入大学时对计算机专业的畅想 当初你是如何做出选择计算机专业的决定的? 你认为过去两年中接触到的课程是否符合你对计算机 ...

  9. [2019BUAA软工助教]Alpha阶段无人转出申请审核结果

    [2019BUAA软工助教]Alpha阶段无人转出申请审核结果 一.队伍信息 队伍名 项目 人数 红太阳 社团 8(6+2) pureman 博客园 6 水哥牛逼 招募 6 葫芦娃 拖拽Pytorch ...

随机推荐

  1. 安装framework 4.6.2的时报错 “无法建立到信任根颁发机构的证书链”

    解决方案: 1.下载证书:MicrosoftRootCertificateAuthority2011.cer 2.开始→运行→MMC 3.文件→添加删除管理单元 (Ctrl+M) 4.证书→计算机账户 ...

  2. javascript 深入理解 继承(转)

    通过对继承的深入理解,更了解javascript.本人还不太写会博客,转自汤姆大叔,链接http://www.cnblogs.com/TomXu/archive/2012/01/05/2305453. ...

  3. 将SharePoint站点另存为模板并根据模板创建站点!

    1,将SharePoint站点模板另存为模板. 在网站设置—网站操作一栏下面可以将网站另存为模板. 这儿应该注意:有的时候“将网站另存为模板这个”链接看不到,这个时候打开管理网站功能链接,查看一下“S ...

  4. MySql修改WordPress密码

    首先,需要几样东西:Xshell,MySql的密码 具体过程:这里我的服务器用的是Vultr, 登上数据库: 使用的语句是:mysql -u root -p 出现的结果如下图: 接着输入语句:show ...

  5. rpm-yum_install_software

    rpm -ivh software_name安装软件 打印详情rpm -q software_name查询软件是否安装rpm -ql software_name查询安装目录rpm -e softwar ...

  6. 编写Dockerfiles

    指令 docker build通过Dockerfile制作镜像 docker build [PATH] [-f Dockerfile] 其中PATH不写,默认执行指令的当前目录,不要用 /,这样将导致 ...

  7. WPF之ListView使用WrapPanel

    原文:WPF之ListView使用WrapPanel 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/jiuzaizuotian2014/articl ...

  8. JavaScript总结(三)

    如何执行代码语句? 使用函数,函数是一组可以随时随地运行的语句,它们是JavaScript的核心.函数是由关键字function.函数名加一组参数以及置于括号中要执行的代码声明的.语法如下: Func ...

  9. [Oracle]如何查看一个数据文件是否是自动扩展

    开始 SQL> col file_id format 99SQL> col file_name format a50SQL> col tablespace_name format a ...

  10. Noip前的大抱佛脚----图论

    目录 图论 知识点 二分图相关 DFS找环 并查集维护二分图 二分图匹配的不可行边 最小生成树相关 最短路树 最短路相关 负环 多源最短路 差分约束系统 01最短路 k短路 网络流 zkw费用流 做题 ...