工作空间指的是这样的“专用”区域:开发人员可以根据项目所采用的标准来实施和测试代码,与其他开发人员相对隔离。配置管理员需要为项目的每个开发人员创建一个工作空间环境。
工作空间为每个开发人员提供一个一致、灵活、经济且可重现的环境,该环境选择和展示每个文件的适当版本。工作空间需要能够同时对共享和隔离进行细粒度控制。这是必需的,因为在大多数项目中,开发人员需要与其他人所作的变更保持隔离;但与此同时,他们又必须能够将自己的变更与其他某些开发人员所作的变更共同进行单元测试.
在对较旧发行版执行维护时,开发人员需要能够查看较旧的版本、二进制文件、文档、测试、工具和其他对象。在此情况下,工作空间充当着“时间机器”,使环境中的所有事物(不仅是源代码)都能以其原来的样子出现。
每个开发人员的工作空间需要进行隔离,以便编辑、编译、测试和调试。 然而,工作空间的隔离应该是相对的,而非绝对的:
-
其他人应能够跟踪开发人员的工作,并选择性地将之集成到他们自己的工作中。
-
在下一个集成周期到来之前,其他人员应该能够排除那些可能使自己的工作不稳定的变更。
工作空间可以是个别开发人员完全私有的,也可以是通过网络在开发人员团队之间共享的。
除了提供对源版本的访问之外,工作空间需要为软件开发期间生成的文件提供专有(隔离)的存储区域:
-
源文件的工作(已检出)版本
-
可执行文件
-
其他工作空间私有对象 - 源代码、测试子目录和测试数据文件。
工作空间的专有存储区域通常位于开发人员在工作站上的主目录中。由一组开发人员共享的工作空间可能在中央文件服务器上有其自己专有的存储区域。不过,专有存储区域的实际位置基本上是无关的。从开发人员的角度来看,工作空间的专用存储区域看上去应当是完全集成的。
上图说明了在 CM 模块的整体环境中的专有和集成工作空间的概念。
工作配置(工作空间概要文件)指的是构成项目的工作集的特定子系统。工作集是为实施一件工作所必须引用或修改的子系统的特定版本的列表。该列表可以代表整个系统或某个子集。
视图提供对项目存储库中某个文件集的访问。视图还提供对这些文件的相应版本集合的访问:
-
新开发视图可以提供对文件的最新版本的访问。
-
另一种新开发视图可以提供对正由某个团队(该团队正在处理产品的新用户界面)使用的版本的访问。
-
维护视图可以提供对曾用于构建产品给定发行版的文件版本的访问。
工作空间(有时也称为视图)允许开发人员先独自作出并测试变更,然后再与团队其他人员共享这些修改。共有两种视图:
快照视图为开发人员提供了稳定不变的工作环境。它与计算机目录树相似。用一个或多个项目存储库中的文件的相应版本的副本来填充快照视图。有些人对此类目录树使用术语“沙箱”。当某个开发人员希望看到其他团队成员所作的变更时,她可更新她的视图。
此工作风格具有拉伸模型的特征,原因是它需要主动拉入相关信息,而不是通过自动刷新机制即时获得信息。
动态视图是一种虚拟数据结构,因为它看上去包含了所有开发数据。 动态视图不制作文件的本地副本,而是依赖于网络即时更新。动态视图可能是以下情况的最佳选择:
-
客户端的磁盘空间有限
-
您希望利用所提供的对象共享
-
开发团队必须处理代码的最新版本。对于需要任何给定软件的最新版本的集成而言,此功能尤为有用。
|