求知 文章 文库 Lib 视频 iPerson 课程 认证 咨询 工具 讲座 Modeler   Code  
会员   
 
  
 
 
 
集成与构建指南
 

2011-2-12 来源:网络

 
1.概述
     软件开发的目标是得到满足需求的可运行的交付工件,即通常是得到由源码等中间工件编译、链接并集成而生成的一个建造(build)。然而集成却是一项看似简单实际上充满了陷阱的工作,特别是在团队开发的场景下,将牵涉到将不同成员开发的源码等集成一体,解决各类冲突与依赖等复杂情况,这个过程还直接依赖于软件配置管理流程的支持。一个合格的集成员需要掌握多项知识和技能,本文档将帮助集成员等相关角色理解一个完整的构建集成过程,引导他们迅速地掌握本项目的构建工作。

本文档主要内容包括:
     1 描述如何创建满足项目集成与构建活动的工作环境
     2 简要介绍构建工具的相关知识
     3 描述实施—〉单元测试—〉提交—〉集成—〉冒烟测试的基本流程
     4 深入说明自动化持续集成的流程
     5 提供对第三方开发包、项目构件等的源码结构组织和集成的指南

2.术语说明?
     冒烟测试
     用于快速验证一个系统集成的工作版本被成功地构建的一组测试。它们必须是低成本的测试(比如自动化的测试),目标是保证一个相对稳定的、值得展开后续重量级测试的工作版本被发布给测试员使用。

     持续集成
     是对日构建的进一步扩展。在专门工具的支持下,通过实施自动化的构建、测试,使得项目的源码可以在专用构建机上持续地进行集成构建与测试,即在既定周期(可以短到30秒)中,新提交的源码将被自动地集成,相关人员随即获得编译和测试结果。

3.角色与职责参与构建集成过程的角色如下:

角色

相关职责描述

备注

集成员
  • 制定集成与构建计划
  • 编制集成的自动化构建脚本
  • 指导或帮助实施员编制私有构件的自动化构建脚本
  • 执行集成,解决编译与链接冲突,调试构建脚本?/li>
  • 建立工作基线

 

实施员
  • 编制私有构件面向集成的自动化构建脚本
  • 提交构件源码等中间工件(delivery)
  • 重设开发基线(rebase)

 

配置管理员
  • 配置集成用工作视图(view)
  • 分配存取权限

 

环境工程师
  • 制定项目组的开发环境配置方案
  • 建立项目的开发、集成与测试软件环境
  • 解决软件开发环境和工具使用中出现的问题
 
4.集成环境
     为了将源码等中间工件编译、链接生成的一个建造(build),必须使用相应的编译工具;而实现构建的自动化,则需要类似make等构建工具的支持;实施持续集成还依赖CruiseControl这类专门工具;另外由于集成通常在团队协同的环境下开展,软件配置管理工具将在此间充当重要角色。
推荐的安装顺序是:克隆主机—〉安装配置管理工具客户端—〉建立用户视图—〉准备用户私有构建场所—〉配置编译环境—〉配置构建环境—〉执行初次构建
    4.1集成网络部署
    4.2编译环境
    4.2.1msvc6本项目的首要IDE用的是MS Visual Studio 98,编译器相应的用msvc6。
项目中使用了msvc6的基础库和mfc库的全集(包括unicode部件,在安装时注意要使用定制方式来选择)。
为了正常使用msvc6,注意正确设置相应的Path等环境变量,虽然安装程序能自动设置它们,但通过克隆的机器可能丢失。
环境变量示例:
Path=C:\WINNT\system32;C:\WINNT;C:\Development_Tools\Building-Utils\apache-ant-1.6.0\bin;C:\Development_Tools\Microsoft Visual Studio\Common\Tools\WinNT;C:\Development_Tools\MicrosoftVisual Studio\Common\MSDev98\Bin;C:\Development_Tools\Microsoft Visual Studio\Common\Tools;C:\Development_Tools\MicrosoftVisual Studio\VC98\bin; C:\Development_Tools\Microsoft Visual Studio\Common\MSDev98\bin
另外可以直接运行下列批命令来自动设置(仅对克隆的机器有效):
D:\Development_Home\Tools.Configs\path.bat
     4.2.2bcc55为了支持第三方使用Borland IDE,需要配置Bcc55编译器。

     4.3构建工具
     常见的构建工具,C/C++有Make,Bjam,cpptasksfor Ant;Java有Ant,C#有NAnt。考虑到Ant具备使用方便、功能全面、XML格式可读性强、容易掌握等优点,本项目选用Ant作为首要的构建工具。
典型构建工具环境的配置为:
jsdk1.4.x——Java运行环境
apache-ant-1.6.0——Ant工具
安装路径示例:
C:\Development_Tools\Building-Utils\apache-ant-1.6.0
cpptasks1.0beta——支持Ant进行C/C++构建的扩展
安装路径示例:
C:\Development_Tools\Building-Utils\apache-ant-1.6.0\lib\cpptasks.jar
ant-contrib-0.6——支持Ant使用控制逻辑的扩展
安装路径示例:
C:\Development_Tools\Building-Utils\apache-ant-1.6.0\lib\ ant-contrib-0.6.jar
envset——项目组自行开发的一个WinNT环境变量设置小程序
安装路径示例:
C:\Development_Tools\Building-Utils\apache-ant-1.6.0\bin\ envset.exe
注意:
为了支持cpptasks,ant-contrib的使用,必须在Ant构建脚本中加入以下声明:
<!--task and type extension -->
<taskdefresource="cpptasks.tasks"/>
<typedefresource="cpptasks.types"/>
<taskdefresource="net/sf/antcontrib/antcontrib.properties"/>

     4.4持续集成工具
     主流的持续集成工具有CruiseControl,提供了Java与dot.net两个版本。我们通过对Java版本进行相应配置,实现了C/C++项目的持续集成。
在集成服务器上的安装路径示例:
C:\Development_Tools\Building-Utils\cruisecontrol-2.1.5
为了支持C/C++项目,需要加入cpptasks、ant-contrib,可以通过修改CruiseControl.bat文件来实现,示例如下:
setEXTLIBDIR=%ANT_HOME%\lib
%EXTLIBDIR%\ant-contrib-0.6.jar;%EXTLIBDIR%\cpptasks.jar;

     4.5软件配置管理客户端
     本项目选用ClearCase作为软件配置管理的工具。开发工作站、测试工作站和集成服务器都将安装ClearCase客户端,其安装配置参见其它ClearCase相关文档。
视图路径示例:
D:\Shared_Views\PCHL_V1_Dev

     4.6用户私有构建场所
     各构建主机上需要创建类似D:\Development_Home\的目录,作为工作用户私有的开发场所,开发人员可以将\PCHL_Supports\Environments\Development\Development_Home.zip(可以从ClearCase的PCHL_Working流下找到)解压直接生成此目录集,其中D:\Development_Home\Building.Workspace子目录将用于自动构建。Development_Home.zip包内还包含CruiseControl持续集成的相关配置文件。

     4.7主机克隆
     为了提高工作效率,项目组的开发工作站可以通过克隆的方式进行快速安装。环境工程师针对项目组日常开发、管理、协同等工作需要,制作了完整的系统盘(C主分区)映像,包括开发工具、CASE工具、其它常用工具等,上述构建用工具软件均包含在内。
映像有Windows2000Professional与Windows2000Server两个版本,源路径示例:
\\back1-svr\ghost_imgs\w2ksrv_x\w2ksrv.GHO
使用者可以用支持网络连接的引导CD启动系统,执行ghost,然后进行克隆。


集成与构建指南
项目管理:Maven让事情变得简单
持续集成工具hudson
持续集成
Maven权威指南
程序集(UML中的包)之间循环
更多...   


产品发布管理
配置管理方法、实践、工具
多层次集成配置管理
使用CC与CQ进行项目实践
CVS与配置管理
Subversion管理员


海航股份 重构及持续集成
电研华源 设计原理、建模与重构
软件配置管理日构建及持续集成
单元测试、重构及持续集成
中国软件研发中心 单元测试与重构
单元测试、重构和持续集成实践
罗克韦尔 C++单元测试+重构+Gtest
更多...