《持续交付》- 持续集成

一 持续集成是什么


持续集成是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

对于很多软件项目来说,开发人员虽然可以做到在提交代码后对代码进行自动化的单元测试, 但基本上没人会在试运行环境中去启动并使用它。这样便可能会发生一些潜在的问题。比如当开发结束后需要留出很长时间去集成,这个阶段往往会很费时间,最糟糕的是没人知道这将会花费多长时间才能完成集成。

所以我们应该尽早去做持续集成,而持续集成的目的就是让软件一直处于可工作的状态。

二 实现持续集成


1、准备工作

  • 版本控制:任何项目都应该使用版本控制
  • 自动化构建
  • 团队意识

2、一个基本的持续集成系统

  • 查看一下是否有构建正在运行,如果有的话,等它完事,如果它失败了,就和团队的其他人把他一起修复,然后再提交代码
  • 一旦构建完成且测试完全通过,就从版本控制库中将该版本的代码更新到自己的开发环境上
  • 在自己的开发机上执行构建脚本,运行测试,以确保在你机器上的所有代码都正常工作
  • 如果本地构建成功,提交代码
  • 然后等待你这次提交的构建结果
  • 如果失败了,停下手中的活,修复问题,转到步骤3
  • 如果成功,开始下个任务

三 持续集成的前提条件


1、频繁提交
2、创建全面的自动化测试套件

自动化测试的套件包括:

  • 单元测试:用来测试应用程序中某些小单元的行为(方法、函数...),通常不需要启动整个应用程序,也不需要连接数据库、文件系统或网络。
  • 组件测试:用于测试应用程序中几个组件的行为。它也不需要启动整个应用程序,但有可能需要连接数据库、访问文件系统或其它外部系统或接口。
  • 验收测试:用来验证应用程序是否满足厌恶需要所定应的验收条件,包括应用程序提供的功能,以及其它特定需求。一般会将整个应用程序运行于类生产环境的运作方式。

3、保持较短的构建和测试过程
4、管理开发工作区

当开发人员开始工作的时候,应该总是从一个已知正确的状态开始。

四 应该遵守的实践


  • 构建失败之后不要提交新代码
  • 提交前在本地运行所有的提交测试,或者让持续集成服务器完成此事
  • 等提交测试通过之后再继续工作
  • 回家之前,构建必须处于成功状态
  • 时刻准备着回滚到前一个版本
  • 按照持续集成的流程,前一个版本肯定是没有问题的
  • 在回滚之前规定一个修复时间
  • 不要将失败的测试注释掉
  • 为自己的导致的问题负责
  • 测试驱动开发
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,287评论 19 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 177,269评论 25 709
  • <<互联网敏捷DevOps和自动化之5.持续集成>>持续集成的价值是什么?对于开发和测试人员又意味着什么呢?1.1...
    燕京博士阅读 7,814评论 0 5
  • 迎着清晨的阳光,起床,出发,一个小时的车程,告诉自己不远,不累。连续三、四个星期往医院跑,身体终于有所好转。...
    卢佩文阅读 2,383评论 0 0
  • 你幸福吗?快乐吗? 不是你有家财万贯,妻妾成群。 幸福是比较出来的。
    杨增年中医经络调理阅读 2,187评论 0 0

友情链接更多精彩内容