设为首页 收藏本站
查看: 1462|回复: 0

[经验分享] Hadoop分布式文件系统模拟桩HDFS_MOCK

[复制链接]

尚未签到

发表于 2018-11-1 09:31:25 | 显示全部楼层 |阅读模式
  简介
  Hdfs_mock属于单测工具,如果c/c++模块以API方式访问hdfs(相对于脚本模块会使用客户端方式),那么有了hdfs_mock就可以在没有真实hdfs情况下,协助进行手工或自动化测试。
  背景
  在linkcache模块单元测试(持续集成)时,遇到了一个问题:该模块会以API方式进行hdfs上文件的增删改查等操作,先不说搭建hdfs是一件费时费力得不尝试的事情,即使在单测阶段能够采用搭建真实环境进行测试,仍然存在以下弊端:
  · 异常测试:hdfs异常情况难于模拟,导致测试覆盖不全面
  · 执行时间:访问真实hdfs,自动化测试执行时间难以保证,给快速持续集成带来挑战
  · 环境维护:为了支持持久、频繁的持续集成测试,hdfs环境需要始终维持不能变动
  · 环境独立:hdfs环境需要与其他测试模块隔离,才能避免相互影响
  思路
  分析模块执行过程后发现,c/c++模块在使用API访问hdfs时,采用共享对象so的方式实现。编译时包含标准hdfs.h头文件,运行时查找libhdfs.so中API的实现来完成hdfs访问过程。基于以上分析,设计开发了单测工具hdfs_mock用以替代libhdfs.so,其具有以下特点:
  · 异常测试:支持从外部设置hdfs内部状态,能够构造各种异常情况进行测试
  · 执行时间:内部以本地文件系统方式实现,无网络通信代价,执行速度快
  · 环境维护:因为mock so动态加载,所以使用方面直接拷贝本so即可,易于使用维护
  · 环境独立:本地按照hdfs主机名分子目录独立维护数据,彼此间不受影响
  · 其他:支持标准hdfs API(linkcache使用的10个API函数)
  设计
  在没有使用hdfs_mock时的测试过程如下图所示:
  apache提供的标准hdfs API包含hdfs.h和hdfs.c,编译后生成libhdfs.so。
  rd开发linkcache部分代码(HdfsFile.h/HdfsFile.cpp)依赖需要include hdfs.h,在libhdfs.so存在时编译生成libfile.so;运行时以动态方式加载并调用执行libhdfs.so中的代码,输出结果result
  qa开发测试代码test_HdfsFile.cpp依赖rd代码,在libfile.so存在时编译生成test_HdfsFile程序,执行该测试程序时,同样以动态方式加载并调用执行libfile.so中代码,根据测试结果输出测试报告Test result
  · hdfsmock_old.JPG:
DSC0000.jpg

  在使用hdfs_mock后的测试过程如下图所示:
  设计开发了hdfs_mock(hdfs_mock.h/hdfs_mock.cpp),include了apache标准hdfs.h以使得接口报纸一致,编译后生成libhdfs.so(图中黄色方框)。其余步骤不变,唯一区别在于,测试执行时,libfile.so所动态加载并调用执行的hdfs API改成了hdfs_mock中的实现了。在hdfs_mock中使用本地文件系统访问替代了hdfs访问以达到模拟API的效果;此外在运行时,也可根据需要在test_HdfsFile中直接调用mock的libhdfs.so中方法来达到设置测试环境(状态、数据)的目的。
  · hdfsmock.JPG:
DSC0001.jpg

  使用方式
  下面是一个简单使用的例子,配置hdfs为正常状态,然后调用被测函数HDFSSystem::Init链接hdfs成功
  QA_TEST_HDFS_MOCK::QA_TEST_HDFS_MOCK* mock = QA_TEST_HDFS_MOCK::getInstance();
  mock->resetStat();
  mock->_M_stat = QS_TEST_HDFS_STAT_OK;
  ASSERT_TRUE(HDFSSystem::Init("yx-namenode-v.yx01.baidu.com",64310,"anchorchecker","**"));
  下面的简单跟上例是一组,只是配置hdfs为异常状态,然后调用被测函数HDFSSystem::Init链接hdfs失败
  QA_TEST_HDFS_MOCK::QA_TEST_HDFS_MOCK* mock = QA_TEST_HDFS_MOCK::getInstance();
  mock->resetStat();
  mock->_M_stat = QS_TEST_HDFS_STAT_SHUTDOWN;
  ASSERT_FALSE(HDFSSystem::Init("yx-namenode-v.yx01.baidu.com",64310,"anchorchecker","**"));
  下面是稍微复杂一点的例子,首先调用hdfs_mock的createHdfsFile接口,在hdfs_mock上模拟建立testfile文件,内容为给定buf开始的NUM个字节,然后构造HdfsFile对象Open打开testfile文件,最后是调用被测函数hf->Read()读取文件内容与标准数据进行比较
  // 构造测试环境
  uint32_t NUM = 1024U;
  char* buf = createNumChar(NUM);
  QA_TEST_HDFS_MOCK::QA_TEST_HDFS_MOCK* mock = QA_TEST_HDFS_MOCK::getInstance();
  mock->createHdfsFile("db-testing-ps7002.db01", "./home/spider/testdir/testfile", buf, NUM); // hdfs_mock提供的辅助接口
  // 构造被测对象
  const string fp("hdfs@db-testing-ps7002.db01/home/spider/testdir/testfile");
  HdfsFile* hf = new HdfsFile(fp);
  hf->Open(O_RDONLY);
  // 调用被测函数
  char rcvBuf[4096];
  ASSERT_EQ((ssize_t)NUM, hf->Read(rcvBuf, 4096));
  // 测试结果检查
  ASSERT_STREQ(buf, rcvBuf);
  (作者:shaanlan)
【本文首发于:百度测试技术空间】http://hi.baidu.com/baiduqa/blog/item/5bfab4153a6aa7184b90a76f.html【关注百度技术沙龙】

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-629211-1-1.html 上篇帖子: 淘宝Fourinone和Hadoop的完整对比 下篇帖子: hadoop mapred-site.xml配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表