Clearcase UCM为共享开发创建功能流

问题描述 投票:1回答:1

背景:首先,我已经过头了,至少7年前我和基础Clearcase合作过,但我是UCM的新手。在我的新职位上似乎没有太多/任何SCM支持(他们丢失了一些资源)IT维护Clearcase但是无法在开发过程中提供太多支持。

问题:我正在尝试创建一个环境,其中2或3个人可以处理具有单独流的功能,我们可以在准备好时将其合并到集成流中。 (我们希望每个人都拥有自己的开发流,因此我们可以随意结账/进入,也不会影响进入集成流的其他开发工作)

我试图“创建项目...”,我能够用它自己的集成流创建项目(当我加入项目时,我能够创建我的dev和int视图)。让我们调用基础项目A和我创建的项目A'。我可以从A'结账并交付给A'_int流/视图。但是当我尝试从A'_int传递(希望转到A_int)时,我收到一条消息“无法传递”(尽管它确实正确地识别了我对A的集成视图)。

版本树如下所示:

main
 |
 0 -- A_int
       |
       0
       |
       ...
       |
       x -- sceaj_A'-- A'_int
              |           |
              0           0
              |           |
              1 --------> 1

在基本clearcase中,版本树看起来像:

main
 |
 0 -- A_int
       |
       0
       |
       ...
       |
       x -- A'_int
              |
              0 -- sceaj_A'
              |      |
              |      0
              |      |
              1 <--- 1

然后我可以合并回A_int。

那么,我该怎么做才能让它在UCM中发挥作用?问题是我作为普通用户在UCM中根本无法做到这一点吗?这甚至是正确的方法还是有不同的“UCM方式”?

更新:这是实际的分支结构。 branch structure。版本282在A_Int上,iip_core_1.0.0_tr_Integeration是A'_Int(特征分支),jr ... _ip_core_1.0.0_tr是我的dev分支。这个结构是由“创建项目......”创建的,但我怀疑这不是我想要的。

clearcase clearcase-ucm
1个回答
0
投票

实际上,第一次交付已经交付给A_Int。

ClearCase UCM view(作为seen here)是根据I always found an anti-pattern的子流创建的每个开发人员(A_Int在处理一个共同特征时,因为每个开发人员必须做的所有交付/ rebase常量工作流以便从同事的工作中受益) 。 一旦交付(默认情况下从子流合并到其直接父流),您将合并到A_Int

注意:我更喜欢在同一个流上只创建一个Dev流和多个UCM视图(每个开发人员一个):不需要传递/ rebase循环:每个开发人员可以检查合并时如果他们正在进行合并文件。 一旦完成检查,有人可以在该Dev(子) - 流上创建基线并将其传递给A_Int。

在您的情况下,看起来dev分支是从与功能分支相同的基础基线完成的。 最好在基础分支上创建基线,然后使用它创建开发分支,然后从dev交付到feature,从feature转到Int。

在任何情况下,尝试在您的情况下制作功能的基线,并尝试提供它以查看是否更好。

另见“Difference between branches and streams in ClearCase?”。

© www.soinside.com 2019 - 2024. All rights reserved.