Composite baselines - multiple versions of a library
Here is a CM scenario that I have been struggling with for many years. In words:
Does RTC support baselining a component tree containing different versions of the same component?
Explanation:
Suppose we have a system composed of components that use external components as follows:
Framework XYZ123 is a component from an external supplier.
Now Component A needs new functionality of Framework XYZ123 version 2.0, but Component B cannot be upgraded because it interfaces with other external systems that do not support Framework XYZ123 version 2.0. However, Component B needs to upgrade to version 1.3 for bugfixes.
So how can we baseline this in RTC:
In UCM it is impossible to make a composite baseline hierarchy that contains different versions of the same component. In Synergy (formerly Telelogic Synergy CM) it is possible, and we make use of this capability in our organization.
How does RTC support this?
Explanation:
Suppose we have a system composed of components that use external components as follows:
System X
|-- Component A
| |-- using Framework XYZ123 version 1.2
|-- Component B
| |-- using Framework XYZ123 version 1.2
|-- ... and much more ...
Framework XYZ123 is a component from an external supplier.
Now Component A needs new functionality of Framework XYZ123 version 2.0, but Component B cannot be upgraded because it interfaces with other external systems that do not support Framework XYZ123 version 2.0. However, Component B needs to upgrade to version 1.3 for bugfixes.
So how can we baseline this in RTC:
System X
|-- Component A
| |-- using Framework XYZ123 version 2.0
|-- Component B
| |-- using Framework XYZ123 version 1.3
|-- ... and much more ...
In UCM it is impossible to make a composite baseline hierarchy that contains different versions of the same component. In Synergy (formerly Telelogic Synergy CM) it is possible, and we make use of this capability in our organization.
How does RTC support this?
Accepted answer
Note that RTC lets you load multiple repository workspaces into the same
Eclipse workspace. So you can have one repository workspace with the
XYZ123 2.0 baseline, and another repository workspace with the XYZ123
1.3 baseline, and load them both into the same Eclipse workspace.
So depending on your use cases, this might be sufficient.
And one more question:
5: when you deliver a change-set that modifies some files in that
component, does that change-set get applied to both baselines, or just
one? And if just one, which one?
Cheers,
Geoff
Geoffrey Clemm wrote:
Eclipse workspace. So you can have one repository workspace with the
XYZ123 2.0 baseline, and another repository workspace with the XYZ123
1.3 baseline, and load them both into the same Eclipse workspace.
So depending on your use cases, this might be sufficient.
And one more question:
5: when you deliver a change-set that modifies some files in that
component, does that change-set get applied to both baselines, or just
one? And if just one, which one?
Cheers,
Geoff
Geoffrey Clemm wrote:
Hi Frank,
The short answer is no.
We can submit an RFE, but would need to know what semantics you
require/expect. In particular:
1: when you ask for that component to be loaded into the file system,
which baseline do you expect to be loaded?
2: if you want both baselines to be loaded into the file system, where
do you want them to be loaded?
3: when you accept a component into a workspace, which baseline do you
expect to be accepted?
4: when you deliver a new baseline of that component to a stream, does
it get added as a "third" baseline, or does it replace one of the
existing baselines (and if so, which one)?
Cheers,
Geoff
fschop wrote:
Here is a CM scenario that I have been struggling with for many years.
In words:
Does RTC support baselining a component tree containing
different versions of the same component?
Explanation:
Suppose we have a system composed of components that use external
components as follows:
System X
|-- Component A
| |-- using Framework XYZ123 version 1.2
|-- Component B
| |-- using Framework XYZ123 version 1.2
|-- ... and much more ...
Framework XYZ123 is a component from an external supplier.
Now Component A needs new functionality of Framework XYZ123 version
2.0, but Component B cannot be upgraded because it interfaces with
other external systems that do not support Framework XYZ123 version
2.0. However, Component B needs to upgrade to version 1.3 for
bugfixes.
So how can we baseline this in RTC:
System X
|-- Component A
| |-- using Framework XYZ123 version 2.0
|-- Component B
| |-- using Framework XYZ123 version 1.3
|-- ... and much more ...
In UCM it is impossible to make a composite baseline hierarchy that
contains different versions of the same component. In Synergy
(formerly Telelogic Synergy CM) it is possible, and we make use of
this capability in our organization.
How does RTC support this?
One other answer
Hi Frank,
The short answer is no.
We can submit an RFE, but would need to know what semantics you
require/expect. In particular:
1: when you ask for that component to be loaded into the file system,
which baseline do you expect to be loaded?
2: if you want both baselines to be loaded into the file system, where
do you want them to be loaded?
3: when you accept a component into a workspace, which baseline do you
expect to be accepted?
4: when you deliver a new baseline of that component to a stream, does
it get added as a "third" baseline, or does it replace one of the
existing baselines (and if so, which one)?
Cheers,
Geoff
fschop wrote:
The short answer is no.
We can submit an RFE, but would need to know what semantics you
require/expect. In particular:
1: when you ask for that component to be loaded into the file system,
which baseline do you expect to be loaded?
2: if you want both baselines to be loaded into the file system, where
do you want them to be loaded?
3: when you accept a component into a workspace, which baseline do you
expect to be accepted?
4: when you deliver a new baseline of that component to a stream, does
it get added as a "third" baseline, or does it replace one of the
existing baselines (and if so, which one)?
Cheers,
Geoff
fschop wrote:
Here is a CM scenario that I have been struggling with for many years.
In words:
Does RTC support baselining a component tree containing
different versions of the same component?
Explanation:
Suppose we have a system composed of components that use external
components as follows:
System X
|-- Component A
| |-- using Framework XYZ123 version 1.2
|-- Component B
| |-- using Framework XYZ123 version 1.2
|-- ... and much more ...
Framework XYZ123 is a component from an external supplier.
Now Component A needs new functionality of Framework XYZ123 version
2.0, but Component B cannot be upgraded because it interfaces with
other external systems that do not support Framework XYZ123 version
2.0. However, Component B needs to upgrade to version 1.3 for
bugfixes.
So how can we baseline this in RTC:
System X
|-- Component A
| |-- using Framework XYZ123 version 2.0
|-- Component B
| |-- using Framework XYZ123 version 1.3
|-- ... and much more ...
In UCM it is impossible to make a composite baseline hierarchy that
contains different versions of the same component. In Synergy
(formerly Telelogic Synergy CM) it is possible, and we make use of
this capability in our organization.
How does RTC support this?