二维素组操作

project\main.c

 

/****************************************************************************** 

******************************************************************************
  File Name     :
  Version       :
  Author        :
  Created       : 2009/6/1
  Last Modified :
  Description   :
  Function List :
             
  History       :
  1.Date        : 2009/6/1
    Author      :
    Modification: Created file

******************************************************************************/
#include <cppunit/TextOutputter.h>
#include <cppunit/XmlOutputter.h>
#include <cppunit/BriefTestProgressListener.h>
#include <cppunit/extensions/TestFactoryRegistry.h>
#include <cppunit/TestResult.h>
#include <cppunit/TestResultCollector.h>
#include <cppunit/TestRunner.h>
#include "conio.h"

int main(int argc, char* argv[])
{
    // Create the event manager and test controller
    CPPUNIT_NS::TestResult controller;

    // Add a listener that colllects test result
    CPPUNIT_NS::TestResultCollector result;
    controller.addListener( &result );       

    // Add a listener that print dots as test run.
    CPPUNIT_NS::BriefTestProgressListener progress;
    controller.addListener( &progress );     

    // Add the top suite to the test runner
    CPPUNIT_NS::TestRunner runner;
    runner.addTest( CPPUNIT_NS::TestFactoryRegistry::getRegistry("All Tests").makeTest() );
    runner.run( controller );

    // Print test in a text format.
    CPPUNIT_NS::TextOutputter outputter( &result, CPPUNIT_NS::stdCOut() );
    outputter.write();

    // This for XML output
    std::ofstream file( "TestResult.xml" );
    CPPUNIT_NS::XmlOutputter xml( &result, file );
    xml.setStyleSheet( "report.xsl" );
    xml.write();
    file.close();
 getch();

    return result.wasSuccessful() ? 0 : 1;
}

 

testcase\CExampleTest

/******************************************************************************

  Copyright (C), 2001-2011, Huawei Tech. Co., Ltd.

 ******************************************************************************
  File Name     :
  Version       :
  Author        :
  Created       : 2009/6/1
  Last Modified :
  Description   :
  Function List :
             
  History       :
  1.Date        : 2009/6/1
    Author      :
    Modification: Created file

******************************************************************************/
#include <cppunit/config/SourcePrefix.h>
#include "CExampleTest.h"

// 注册测试套到CppUnit
CPPUNIT_TEST_SUITE_REGISTRATION( CExampleTest );

// 测试用例实现示例

// SetUp: 在每个用例前执行一次
void CExampleTest::setUp()
{
    m_strOrbit = "";
}

// tearDown: 在每个用例后执行一次
void CExampleTest::tearDown()
{
    DestroyTable(); // 销毁数据表  
}

// 用例1:
void CExampleTest::TestCase01()
{
    int iRowLenth    = 0;
    int iColumnLenth = 1;
   
    int iRet = InitTable(iRowLenth, iColumnLenth); // 初始化数据表, 行非法
    CPPUNIT_ASSERT_EQUAL(-1, iRet);

    DestroyTable();                                // 销毁数据表

    iRowLenth    = 10;
    iColumnLenth = 1;
    iRet = InitTable(iRowLenth, iColumnLenth);     // 初始化数据表, 行非法
    CPPUNIT_ASSERT_EQUAL(-1, iRet);
}

// 用例2:
void CExampleTest::TestCase02()
{
    int iRowLenth    = 1;
    int iColumnLenth = 0;
   
    int iRet = InitTable(iRowLenth, iColumnLenth); // 初始化数据表, 列非法
    CPPUNIT_ASSERT_EQUAL(-1, iRet);   

    DestroyTable();                                // 销毁数据表

    iRowLenth    = 1;
    iColumnLenth = 10;
    iRet = InitTable(iRowLenth, iColumnLenth);     // 初始化数据表, 列非法
    CPPUNIT_ASSERT_EQUAL(-1, iRet);
}

// 用例3:
void CExampleTest::TestCase03()
{
    int iRowLenth    = 1;
    int iColumnLenth = 1;
   
    int iRet = InitTable(iRowLenth, iColumnLenth); // 初始化数据表, 行列合法
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    iRet = InitTable(iRowLenth, iColumnLenth);     // 重复初始化数据表
    CPPUNIT_ASSERT_EQUAL(-1, iRet); 

   
    DestroyTable();                                // 销毁数据表

    iRowLenth    = 9;
    iColumnLenth = 9;
    iRet = InitTable(iRowLenth, iColumnLenth);     // 初始化数据表, 行列合法
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    iRet = InitTable(iRowLenth, iColumnLenth);     // 重复初始化数据表
    CPPUNIT_ASSERT_EQUAL(-1, iRet);
}

// 用例4:
void CExampleTest::TestCase04()
{
    int iRowLenth    = 2;
    int iColumnLenth = 2;
    int iRet = 0;
    TABLE_NODE stNode00 = {0, 0};
    TABLE_NODE stNode01 = {0, 1};
    TABLE_NODE stNode02 = {0, 2};
    TABLE_NODE stNode09 = {0, 9};
 
    iRet = InitTable(iRowLenth, iColumnLenth); // 初始化数据表, 行列合法
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    iRet = SwapUnit(stNode00, stNode01);       // 交换数据表单元, Node00与Node01
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    iRet = SwapUnit(stNode01, stNode00);       // 交换数据表单元, Node01与Node00
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    iRet = SwapUnit(stNode00, stNode00);       // 交换数据表单元, Node00与Node00自身交换
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    iRet = SwapUnit(stNode00, stNode02);       // 交换数据表单元, Node02非法
    CPPUNIT_ASSERT_EQUAL(-1, iRet);

    iRet = SwapUnit(stNode00, stNode09);       // 交换数据表单元, Node09非法
    CPPUNIT_ASSERT_EQUAL(-1, iRet);
}

// 用例5:
void CExampleTest::TestCase05()
{
    int iRowLenth    = 7;
    int iColumnLenth = 7;
    int iRet = 0;
 
    iRet = InitTable(iRowLenth, iColumnLenth); // 初始化数据表, 行列合法
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    iRet = InsertColumnToTable(8);             // 插入列, 列非法
    CPPUNIT_ASSERT_EQUAL(-1, iRet);

    iRet = InsertColumnToTable(7);             // 插入列, 列合法
    CPPUNIT_ASSERT_EQUAL(0, iRet);
 
    iRet = InsertColumnToTable(8);             // 插入列, 数据表已变化, 列合法
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    iRet = InsertColumnToTable(0);             // 插入列, 数据表已达到最大规格, 非法
    CPPUNIT_ASSERT_EQUAL(-1, iRet);
}

// 用例6:
void CExampleTest::TestCase06()
{
    int iRowLenth    = 3;
    int iColumnLenth = 3;
    int iRet = 0;
    std::string expected;
 std::string actual;
 ORBIT_LIST *pOrbit;
    TABLE_NODE stNode00 = {0, 0};
    TABLE_NODE stNode22 = {2, 2};
    TABLE_NODE stNode33 = {3, 3};

    iRet = InitTable(iRowLenth, iColumnLenth);     // 初始化数据表, 行列合法   
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    expected = "[0,0]";
    iRet = QueryOrbitOfUnitData(stNode00, &pOrbit); // 查询数据表单元Node00变化轨迹
 actual = GetOrbitStr(pOrbit);
    CPPUNIT_ASSERT_EQUAL(0, iRet);
    CPPUNIT_ASSERT_EQUAL(expected, actual);

    expected = "[2,2]";
    iRet = QueryOrbitOfUnitData(stNode22, &pOrbit); // 查询数据表单元Node22变化轨迹
 actual = GetOrbitStr(pOrbit);
    CPPUNIT_ASSERT_EQUAL(0, iRet);
    CPPUNIT_ASSERT_EQUAL(expected, actual);

    iRet = QueryOrbitOfUnitData(stNode33, &pOrbit); // 查询数据表单元Node33变化轨迹, 非法
    CPPUNIT_ASSERT_EQUAL(-1, iRet);

    iRet = InsertRowToTable(0);                    // 插入行, 行合法
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    iRet = InsertColumnToTable(0);                 // 插入列, 列合法
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    iRet = QueryOrbitOfUnitData(stNode33, &pOrbit); // 查询数据表单元Node33变化轨迹, 非法
    CPPUNIT_ASSERT_EQUAL(-1, iRet);
}

// 用例7:
void CExampleTest::TestCase07()
{
    int iRowLenth    = 3;
    int iColumnLenth = 3;
    int iRet = 0;
    std::string expected;
 std::string actual;
 ORBIT_LIST *pOrbit;
    TABLE_NODE stNode02 = {0, 2};
    TABLE_NODE stNode11 = {1, 1};
 
    iRet = InitTable(iRowLenth, iColumnLenth);     // 初始化数据表, 行列合法
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    iRet = SwapUnit(stNode11, stNode11);           // 交换数据表单元, Node11与Node11自身交换
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    expected = "[1,1]";
    iRet = QueryOrbitOfUnitData(stNode11, &pOrbit); // 查询数据表单元Node11变化轨迹, 无变化
    CPPUNIT_ASSERT_EQUAL(0, iRet);
    actual = GetOrbitStr(pOrbit);
    CPPUNIT_ASSERT_EQUAL(expected, actual);

    iRet = SwapUnit(stNode02, stNode11);           // 交换数据表单元, Node02与Node11
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    expected = "[0,2]->[1,1]";
    iRet = QueryOrbitOfUnitData(stNode02, &pOrbit); // 查询数据表单元Node02变化轨迹
    CPPUNIT_ASSERT_EQUAL(0, iRet);
 actual = GetOrbitStr(pOrbit);
 CPPUNIT_ASSERT_EQUAL(expected, actual); 
}

// 用例8:
void CExampleTest::TestCase08()
{
    int iRowLenth    = 3;
    int iColumnLenth = 3;
    int iRet = 0;
    std::string expected;
 std::string actual;
 ORBIT_LIST *pOrbit;
    TABLE_NODE stNode11 = {1, 1};
    TABLE_NODE stNode12 = {1, 2};
    TABLE_NODE stNode23 = {2, 3};

    iRet = InitTable(iRowLenth, iColumnLenth);     // 初始化数据表, 行列合法
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    iRet = InsertColumnToTable(1);                 // 插入列, 列合法
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    iRet = SwapUnit(stNode12, stNode23);           // 交换数据表单元, Node12与Node23
    CPPUNIT_ASSERT_EQUAL(0, iRet);

    expected = "[1,1]->[1,2]->[2,3]";
    iRet = QueryOrbitOfUnitData(stNode11, &pOrbit); // 查询数据表单元Node11变化轨迹
    CPPUNIT_ASSERT_EQUAL(0, iRet);
 actual = GetOrbitStr(pOrbit);
 CPPUNIT_ASSERT_EQUAL(expected, actual);

 if(NULL != pOrbit)
 {
  FreeOrbitOfUnitData(pOrbit);
 }

}

// 在这里添加测试用例实现
// void CExampleTest::TestCasexx()
// {
//
// }


// 工具方法,请勿修改
void CExampleTest::AppendToOrbitStr(ORBIT_LIST *pOrbit)
{
 ORBIT_LIST *pTemp = pOrbit;

 while (NULL != pTemp)
 {
  std::stringstream os;
  os << "[" << pTemp->node.iRowNo << "," << pTemp->node.iColumnNo << "]";

  if (m_strOrbit != "")
  {
   m_strOrbit = m_strOrbit + "->" + os.str();
  }
  else
  {
   m_strOrbit = os.str();
  }

  pTemp = pTemp->pNext;
 }

 return; 
}

std::string CExampleTest::GetOrbitStr(ORBIT_LIST *pOrbit)
{
 AppendToOrbitStr(pOrbit);

 std::string ouput = m_strOrbit;
 m_strOrbit = "";
 return ouput;
}

 

testcase\CExampleTest.h

/******************************************************************************

  Copyright (C), 2001-2011, Huawei Tech. Co., Ltd.

 ******************************************************************************
  File Name     :
  Version       :
  Author        :
  Created       : 2009/6/1
  Last Modified :
  Description   :
  Function List :
             
  History       :
  1.Date        : 2009/6/1
    Author      :
    Modification: Created file

******************************************************************************/
#ifndef _CEXAMPLE_TEST_H
#define _CEXAMPLE_TEST_H
#include <cppunit/extensions/HelperMacros.h>

// 数据表节点位置信息定义
typedef struct Table_Node
{
 int  iRowNo;    // 行号, 从0开始编号
 int  iColumnNo; // 列号, 从0开始编号
}TABLE_NODE;

// 节点轨迹变化链表信息
typedef struct Orbit_List
{
 TABLE_NODE   node;           //节点位置信息
 struct Orbit_List *pNext;
}ORBIT_LIST;

// 被测函数声明
extern int InitTable(int iRowLenth, int iColumnLenth);
extern void DestroyTable (void);
extern int SwapUnit (TABLE_NODE stNode1, TABLE_NODE stNode2);
extern int InsertColumnToTable(int iColumnNo);
extern int InsertRowToTable(int iRowNo);
extern int QueryOrbitOfUnitData(TABLE_NODE stNode, ORBIT_LIST** ppOrbit);
void FreeOrbitOfUnitData(void* pOrbit);

class CExampleTest : public CPPUNIT_NS::TestFixture
{
    CPPUNIT_TEST_SUITE( CExampleTest );
    CPPUNIT_TEST( TestCase01 );
    CPPUNIT_TEST( TestCase02 );
    CPPUNIT_TEST( TestCase03 );
    CPPUNIT_TEST( TestCase04 );
    CPPUNIT_TEST( TestCase05 );
    CPPUNIT_TEST( TestCase06 );
    CPPUNIT_TEST( TestCase07 );
    CPPUNIT_TEST( TestCase08 );
    // 在这里添加测试用例声明, 将测试用例加入测试套
    // CPPUNIT_TEST( TestCasexx );

    CPPUNIT_TEST_SUITE_END();

public:
    void setUp();
    void tearDown();
    void TestCase01();
    void TestCase02();
    void TestCase03();
    void TestCase04();
    void TestCase05();
    void TestCase06();
    void TestCase07();
    void TestCase08();
    // 在这里添加测试用例声明, 声明测试类的成员函数
    // void TestCasexx();

private:
 void AppendToOrbitStr(ORBIT_LIST *pOrbit);
 std::string GetOrbitStr(ORBIT_LIST *pOrbit);
 std::string m_strOrbit;
 
};

#endif /*_CEXAMPLE_TEST_H*/

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
东南亚位于我国倡导推进的“一带一路”海陆交汇地带,作为当今全球发展最为迅速的地区之一,近年来区域内生产总值实现了显著且稳定的增长。根据东盟主要经济体公布的最新数据,印度尼西亚2023年国内生产总值(GDP)增长5.05%;越南2023年经济增长5.05%;马来西亚2023年经济增速为3.7%;泰国2023年经济增长1.9%;新加坡2023年经济增长1.1%;柬埔寨2023年经济增速预计为5.6%。 东盟国家在“一带一路”沿线国家中的总体GDP经济规模、贸易总额与国外直接投资均为最大,因此有着举足轻重的地位和作用。当前,东盟与中国已互相成为双方最大的交易伙伴。中国-东盟贸易总额已从2013年的443亿元增长至 2023年合计超逾6.4万亿元,占中国外贸总值的15.4%。在过去20余年中,东盟国家不断在全球多变的格局里面临挑战并寻求机遇。2023东盟国家主要经济体受到国内消费、国外投资、货币政策、旅游业复苏、和大宗商品出口价企稳等方面的提振,经济显现出稳步增长态势和强韧性的潜能。 本调研报告旨在深度挖掘东南亚市场的增长潜力与发展机会,分析东南亚市场竞争态势、销售模式、客户偏好、整体市场营商环境,为国内企业出海开展业务提供客观参考意见。 本文核心内容: 市场空间:全球行业市场空间、东南亚市场发展空间。 竞争态势:全球份额,东南亚市场企业份额。 销售模式:东南亚市场销售模式、本地代理商 客户情况:东南亚本地客户及偏好分析 营商环境:东南亚营商环境分析 本文纳入的企业包括国外及印尼本土企业,以及相关上下游企业等,部分名单 QYResearch是全球知名的大型咨询公司,行业涵盖各高科技行业产业链细分市场,横跨如半导体产业链(半导体设备及零部件、半导体材料、集成电路、制造、封测、分立器件、传感器、光电器件)、光伏产业链(设备、硅料/硅片、电池片、组件、辅料支架、逆变器、电站终端)、新能源汽车产业链(动力电池及材料、电驱电控、汽车半导体/电子、整车、充电桩)、通信产业链(通信系统设备、终端设备、电子元器件、射频前端、光模块、4G/5G/6G、宽带、IoT、数字经济、AI)、先进材料产业链(金属材料、高分子材料、陶瓷材料、纳米材料等)、机械制造产业链(数控机床、工程机械、电气机械、3C自动化、工业机器人、激光、工控、无人机)、食品药品、医疗器械、农业等。邮箱:market@qyresearch.com

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值