内容来源:2017年4月8日,京东到家资深测试开发工程师孙斌在“饿了么技术沙龙北京测试专场”进行《持续集成实践》演讲分享。IT大咖说做为独家视频合做方,经主办方和讲者审阅受权发布。css
阅读字数: 1716 用时: 11分钟html
持续集成概念android
持续集成是一种软件开发实践,即团队开发成员常常集成他们的工做,一般每一个成员天天至少集成一次,也就意味着天天可能会发生屡次集成。每次集成都经过自动化的构建(包括编辑、发布、自动化测试)来验证,从而尽快地发现集成错误。许多团队发现这个过程能够大大减小集成的问题,让团队可以更快的开发内聚的软件。ios
持续集成的价值css3
一、减小风险:越早发现的错误,修正的费用越低。及时检查软件测试的健康情况,减小发布时的风险。git
二、减小重复性的工做:经过自动化的持续集成能够将编译、部署、测试等动做都变成自动化的,无需太多人工干预。web
三、任什么时候间、任何地点均可以部署软件:利用持续集成,能够常常对源代码进行一些小改动,并将这些改动和其余的代码进行集成。若是出现问题,项目成员立刻就会被通知到。ajax
持续集成对到家的意义api
京东到家是基于地理位置的o2o生活平台。虽然业务和京东商城不太同样,可是系统的复杂度不低于商城,从成立到如今有200+个服务。系统之间依赖度高,可是因为业务的特殊性,迭代速度比较快。如何使各个服务可以快速部署快速测试上线,对测试和研发工程师造成了很大的挑战。咱们引入了持续集成的概念,并开始逐步实施。
持续集成帮京东到家解决了三个问题。
一、提测质量差。若是压缩了开发周期,质量必定是不行的。
二、测试周期长。一旦代码质量变差,测试投入成本就会很高。
三、重复性的工做多。
如何推动持续集成
持续集成须要整个team都达成共识,按统一好的规则去作同一件事。
咱们先找了易作的、影响力大的事情去作,而后用一个项目去作试点,会获得一些数据,就能够用这些数据去说服领导和同事。
京东到家持续集成的实现
提升代码到git,代码静态扫描,而后单元测试和代码覆盖job会运行,以后编译打包,部署到对应的服务器上。
UI、jsf和App会运行自动化测试,并修复和分析失败的case。若是有须要再作功能测试,收集功能测试代码覆盖率。
目前咱们对这套代码的要求就是要修复阻塞和重要级别的bug,新增代码必须达到必定的覆盖率。全部系统都作到自动编译、打包和部署。必须覆盖主流程,不断添加测试用例。及时查看覆盖率报告,对于新增代码业务逻辑必须全覆盖。
测试环境的演变
第一阶段:须要手动编译、打包、部署。解决方案就是引入jenkins自动化编译打包部署。
第二阶段:服务器硬盘打满了,一台机器上部署的服务太多,服务中止。咱们作的就是定时清理硬盘空间,监控服务状态,自动重启服务,保证整体服务可用。
第三阶段:主要问题是分布式服务之间调不通。是由于迭代速度快,开发在本地调试,随意修改本地配置文件。组名不对致使调用不到服务。
咱们部署了两套测试环境,一套对外提供服务,供他人测试调用,一套本身使用。保存本地配置,与线上配置比对,防止误改。使用自动化测试,检查整个系统的健康情况,及时修复。
代码静态扫描
Sonar代码质量管理系统
一、配置Sonar环境。
二、配置jenkins环境,下载sonarqube插件,并进行配置。
三、在jenkins代码静态扫描的job后,配置运行sonar。
代码覆盖率收集
单元测试代码覆盖率
Jenkins运行mvn clean install命令,生成代码覆盖率报告。
功能测试代码覆盖率环境搭建
一、启动脚本中插入监听参数。
二、Dump出监听文件。
三、使用Ant脚本生成最终的html。
功能测试代码覆盖率
配置到jenkins的持续集成环境。
自动化测试
UI自动化测试:Selenium+TestNG+Jenkins
一、配置maven pom.xml文件。
二、配置Jenkins job。
APP自动化测试
当时选择appium是由于它支持android和ios系统,支持现有框架和多种语言,并且能够跨应用。最重要的是appium不依赖于源代码。
APP自动化测试在持续集成中也遇到了一些问题。针对网络不稳定失败率高,咱们引入了重试监听,若是重试3次还不能经过,那就是有问题的。第二个问题是不容易定位case失败,咱们加入了截图和log日志功能,多打日志加截图,就能发现总体的问题所在。还有就是运行速度慢,android能够启动多个服务,分布运行。
以上是我今天分享的内容,感谢聆听!
相关推荐
推荐文章
近期活动
原文地址:t.cn/RoroPlK