ToB业务的交付环境中的自动化测试方案

不同于ToC业务的部署环境,当我们交付ToB业务时,经常会面临需要到客户指定环境部署的任务。主要分成两个类别,一种是必须部署在客户私有的网络环境,与外部物理隔离。另一种通过远程桌面可以访问,但是服务器本身也是与外部物理隔离,不能够直接访问到。

在这种“封闭”的环境之中,执行交付测试,由于网络不通,不能直接使用现成的测试环境,给测试人员带来了很大的困扰。

本文针对以上情况,总结了以Java语言为例的测试方案,包括测试环境搭建,测试代码的注意事项

BadNews First

曾经蹚过一条泥坑,是以后坚决不用的方式:利用java -cp的方式后台执行测试代码的main函数。

最开始选择这种方案是考虑到,交付环境中网络不通畅,如果尽量减少不需要的软件下载和安装,基于最简单的JDK环境就能够执行回归测试,想来会很美~ 哪知道,现实太tm骨感

实际实施方式

  1. 改造测试代码结构,将所有的测试代码从test scope移动到src/main/java中。
  2. 编写一个新的主类RunCaseTest,通过动态加载配置文件和testng.xml方式获取配置信息,然后加载要执行的测试用例。
  3. 实际执行时从cmd进入,利用java -cp的方式后台执行main函数。
  4. 先在自己的本子上利用maven-assembly-plugin插件把所有的依赖都打包进一个jar保重,将这个jar包通过U盘或者(邮箱)发送到交付环境中,执行代码

不好使的原因:在真实环境中,测试用例99.9%不能一把跑过。 Anyway,这也是交付测试的意义所在啊~
当测试用例失败的时候,需要要从cmd那一堆黑坨坨的日志里,找到对应测试源代码哪一行验证代码的失败。很难。同时在debug的时候,要人工的不断修改testng.xml里进行修改来执行特定的case,远程桌面上操作起来也很麻烦。

自动化测试方案

测试环境的搭建

通过U盘或者公网在交付环境中下载好三剑客,jdk/maven/idea, 在将测试源码拷贝进去,搭建和公司里一样的测试环境执行测试。 听起来有点蠢吧,哈哈,是的,就是用了最原始的方式。

测试代码注意事项

  1. 远程桌面的属于较好的情况,矮子里面拔将军。这时修改maven里的镜像地址为阿里云,可以很快下完

  2. 让你的pom.xml里依赖的包尽量都是公网可下载,可以直接用。如果测试代码依赖了公司内部的包,就麻烦了。只能通过U盘或者邮箱,一个一个的给拷贝进去机器上

  3. 如果是最差情况即所有机器物理隔绝,没有远程桌面。那就需要从自己的本子上,将repository整个目录拷贝到机器里面去

这种方式和基于idea自动下载依赖包的方式不太一样,所以有概率会遇到即使本地仓库有这个包,当时idea里仍然飘红的找不到包的情况。
解决方案是刷新idea的仓库索引,具体操作步骤是:打开settings,搜索repositories,在搜索出来的页面中,选择Type是local的仓库,然后点击右边的Update按钮

总结

  1. 在泥坑里的方式,确实可以将实际拷贝进去的数据变小(最终jar包是100M),如果拷贝仓库repo的话,大概时150M,测试代码本身的大小可以忽略不记
  2. 简单而直观,就是美
  3. 泥坑方式何时有用?对待你的敌人的时候。比如有个悬赏,如果你能够发现环境中存在的问题,就给你奖赏。那泥坑模式完全够用了。但是我们交付测试的目的却是对自己的检验,发现问题是表象,解决问题才是真正的目的。所以只能用更加多的步骤来发现问题,快速解决问题了
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容