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. 【题解】洛谷P4158 [SCOI2009] 粉刷匠(DP)

    次元传送门:洛谷P4158 思路 f[i][j][k][0/1]表示在坐标为(i,j)的格子 已经涂了k次 (0是此格子涂错 1是此格子涂对)涂对的格子数 显然的是 每次换行都要增加一次次数 那么当j ...

  2. GIt帮助文档之创建新的Git仓库——现有目录下,通过导入所有文件来创建

    1.新建仓库初始化操作 1.1打开Git Bash命令窗口,切换到项目文件夹目录: $ cd weixin 1.2执行命令: $ git init 初始化操作,把项目weixin纳入Git管理.初始化 ...

  3. linux 学习第十八天学习(DNS分离解析、DHCP配置、邮件服务配置)

    DNS分离解析技术 yum install bind-chroot systemctl restart named systemctl enable named vim /etc/named.conf ...

  4. Linux服务-NFS

    目录 1. nfs简介 1.1 nfs特点 1.2 使用nfs的好处 1.3 nfs的体系组成 1.4 nfs的应用场景 2. nfs工作机制 2.1 RPC 2.2 NIS 2.3 nfs工作机制 ...

  5. Android ViewPager设置监听注意事项

    首先 implements View.OnClickListener 因为Item比较多用这个方便 设置监听要注意地方,如果在 onCreate 直接 findViewById布局里的ID是会出错的 ...

  6. GoLand Dep Integration Project

    Dep integration 标签(空格分隔): Go 1. 通过 GoLand 使用 dep integration 创建项目 参见 Dep integration 使用 dep integrat ...

  7. 4013: [HNOI2015]实验比较

    4013: [HNOI2015]实验比较 链接 分析: 首先把等号用并查集合并起来. 由于只存在最多一个质量不比i差的数,发现这是森林.若x<y,连边x->y.于是建虚拟根节点0. 然后树 ...

  8. 使用jquery ajax代替iframe

    大家在实际编写网页时可能会遇到网页中需要嵌套网页的情况,这时候通常想法就是通过iframe标签. 但实际用过的人都知道其有种种的不方便,比较直观的问题就是iframe的自适应高度,这也是处理起来比较麻 ...

  9. DMS路由表

    DMS路由表: route add -p 53.90.146.0 mask 255.255.255.0 10.77.35.249   ================================= ...

  10. vue组件--通讯录

    简介 在移动端开发中,通讯录是个很常见的需求. 通讯录通常要实现以下功能 首字母导航 滚动到一定位置首字母固定 在线通讯录demo 布局 通讯录是典型的上下两栏布局,上面是header,下面是内容区, ...