• [2019BUAA软工]第0次代码作业


    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码,导致插入临时栈的为数字字符串而非运算符字符串。
  • 相关阅读:
    大数据是否有可能有效配置资源?
    在大数据时代,我们需要数据售货员
    在大数据时代,我们需要数据售货员
    粗糙的贝叶斯转化概率预测模型
    粗糙的贝叶斯转化概率预测模型
    MVC中的ViewData、ViewBag和TempData
    58被微信玩弄,你知道吗?
    你的以太网速度足够快吗?四种更快的速度正在路上&#183;&#183;&#183;&#183;&#183;&#183;
    hibernate预编译SQL语句中的setParameter和setParameterList
    创建单线性链表的不同表示方法和操作
  • 原文地址:https://www.cnblogs.com/Cookize/p/10440029.html
Copyright © 2020-2023  润新知