4. Using Workflow to Enforce SCM Policy : Quick Start: Implementing a Simple Workflow

Quick Start: Implementing a Simple Workflow
This Quick Start tells you how to implement a simple workflow that enforces both issue management and SCM policies. The Quick Start describes the easiest way to implement a workflow in AccuRev; because of this it makes certain assumptions about the AccuWork schema and the need to customize workflow stages and transitions. Links to more detailed descriptions of each step in the process are provided throughout the Quick Start.
Before You Begin
Tools for creating and implementing a workflow are available only in the Web UI for AccuRev. Before you begin, verify that the Admin menu appears on the AccuRev Web UI toolbar:
The Admin menu is the starting place for all workflow activities.
Process Overview
The following table summarizes the process of implementing a workflow in AccuRev:
Step 1: Identify the Workflow Stage Field in Your AccuWork Schema
To create a workflow, first identify the field in your AccuWork schema that you want to use to represent the stages in your workflow—you might want your workflow to have New, Scheduled, WIP (work-in-progress), and Closed stages, for example.
Chances are good that your AccuWork schema already contains such a field—a field like Status or State, for example, that you can use for this purpose, but you will have to create one if it does not. You review—and optionally modify—your AccuWork schema using the AccuRev Java GUI, shown here:
For more information. See the Java GUI online help for more information on using the Schema Editor.
Step 2: Create and Activate the Workflow
Once you know which AccuWork schema field you will use to represent your workflow stages, you can create and activate the workflow.
1.
Start the AccuRev Web UI, and choose Admin > Create Workflow from the toolbar.
The Create Workflow dialog box appears:
2.
The Set Workflow Conditions dialog box appears.
3.
Workflow conditions can be as simple as the one shown here, but you can use any combination of AND and OR statements you need. Note that only those issues that satisfy the conditions you specify here are subject to the workflow. In this example, issues with a type of, say, Enhancement are not subject to this workflow. Finally, the conditions you specify for a workflow must be unique for all workflows within a depot.
When you are finished specifying workflow conditions, click Ok. The Workflow Editor—an empty canvas and a toolbar—appears.
Note: A workflow is not activated until you set conditions for it. That is, you can fully describe a workflow’s stages and transitions, but you cannot use that workflow to automate issue processing or to enforce SCM policies until you specify the types of issues to which it applies.
For more information. The Set Workflow Conditions dialog box has the same features and uses the same mechanics as the AccuRev Web UI Query Builder. See Working with the Query Builder on page 64 for more information on this topic.
For more detailed information on creating workflows, see Creating and Managing Workflows on page 134.
Step 3: Create Workflow Stages and Transitions
Now that you have created the workflow and specified conditions for it, you can create workflow stages and transitions. You can create stages and transitions manually, but we will use the Stage Generator to automatically generate these workflow objects for us.
1.
The Stage Generator dialog box appears. You use the Schema fields with type of Choose field to specify the field in the AccuWork schema whose values represent your workflow stages. You use the Value field to indicate the values for which you want to create workflow stages.
2.
AccuRev populates the workflow with one stage for every value selected in the Stage Generator (New, Scheduled, and so on), and one transition for each stage (to New, to Scheduled, and so on):
The next step is to use these transitions to link one stage to another to create the workflow.
3.
To link the New stage to the Scheduled stage, for example: right-click the Scheduled stage and choose Add Link > to Scheduled from the context menu, as shown here:
When finished, the workflow diagram for the New and Scheduled stages looks like this:
4.
5.
Delete the to New transition (new issues are created with a Status of New, and thus are placed in the New stage by default; that is, they do not come from another stage in the workflow).
Link the WIP and Review stages to reflect the process by which an issue is returned to the submitter for more information.
When finished, the resulting defects workflow should look something like this:
6.
Click the Save button () to save your work.
Workflow for Issue Management is Complete
At this step of the workflow implementation process, workflow for issue management is complete. Now that the workflow is activated (by specifying the workflow condition as Type = defect), and its stages and transitions have been defined, all issues whose Type field is set to defect are subject to the rules defined in this workflow.
For the AccuRev user, the Issue Edit form for defects will now display the issue’s current stage, and the transitions that can be executed from that stage, as shown here:
Note the ways in which workflow enforces issue processing compliance:
For more information. See Creating and Managing Workflow Stages on page 138, Linking Workflow Stages on page 150, and Creating and Managing Workflow Transitions on page 146 for more information on the topics described in this step.
Step 4: Use the Workflow to Enforce SCM Policies
Once you have created a workflow, you can use it to enforce compliance with your SCM development and release policies. You might want to ensure that only defects in the Done stage can be promoted to your QA stream, and that only defects in the Closed stage can be promoted to your Production stream, for example. You do this using workflow stages to create rules that restrict entry into and, optionally, exit from a stream.
1.
2.
The Workflow Rules for Stream dialog box appears.
3.
By default, AccuRev allows incomplete issues in a stream. Clear the Allow incomplete issues in this stream check box if you want to restrict entry to complete issues.
4.
In the Choose Workflow field, select the workflow whose stages you want to use to create stream entry and exit rules. In this example, we use the defects workflow created earlier and click the Add button.
A tab displaying options for stream entry and exit rules for the selected workflow appears.
5.
By default, all issue types are allowed in the stream; AccuRev uses the specified workflow to enforce rules only on those issues that are subject to that workflow. If you want to restrict entry to this stream to only those issues that are subject to this workflow, select the Allow issues from specified workflows only check box; stream entry and exit rules, if any, are enforced on those issues.
To further restrict entry into or exit from a stream to issues in a specific workflow stage:
1.
In the Stream Entry Rules section, select the Restrict entry to issues in specified workflow stages radio button.
2.
In the When Stage Is column, select the stage you want an issue to be in before it can be promoted to this stream. For example, you might want to restrict entry to the QA stream to issues whose status is Done—that is, development is finished and the issue is ready to be verified by QA.
3.
Optionally, in the Perform This Transition field select the transition you want AccuRev to execute when the issue is promoted to the stream for which you are setting workflow rules. For example, when an issue is promoted to the QA stream, you might want to execute the to Closed transition, which changes the issue’s Status field from Done to Closed.
4.
5.
If you want to set rules on this stream for a different workflow, return to Step 4; otherwise, click the Ok button on the Workflow Rules dialog box to save the workflow rules for this stream.
Note: Clicking the X icon on the workflow tab () deletes the workflow rules for that workflow. It does not simply close the tab.
When you are done, streams for which you have set up workflow rules display a workflow icon, like the one on the phoenix_Client stream shown here:
Tip: You can click this icon to display the Workflow Rules for Stream dialog box to review and modify the workflow rules specified for a stream at any time.
For more information. See Using Workflow to Enforce SCM Policies on page 161 for more information on the topics described in this step.
Summing Up: Results of Implementing a Workflow
Implementing a workflow for issues with the type of defect as described in this Quick Start has resulted in the following behavior:
Only issues with a Type field whose value is set to defect come under the control of this workflow.
Clicking the stage button (here, it is New) displays a read-only version of the workflow diagram, providing users with an understanding of where their issue is relative to other stages in the workflow.
Clicking a transition button (here it is to Scheduled, but there might be more than one) moves the issue through the workflow. The availability of a transition is based on the issue’s current stage and any conditions you have defined for the transitions—you might specify a condition that makes a particular transition available only to a specific user or group, for example.
Finally, notice that the Status field is read-only—it can be updated only by AccuRev based on actions defined for the appropriate workflow stage or transition.
Once the defects workflow is associated with a stream, only issues whose type is defect are allowed in that stream.
What to Do Next
The Quick Start showed you how to use the Stage Generator and tools in the Workflow Editor to quickly create a functional workflow that provides both issue process automation and compliance with development and release process policies. The remaining sections in this chapter revisit each of the steps in the QuickStart in greater detail. Refer to them to learn more about additional workflow features and functionality.

Borland