External Approval Gate
The External Approval Gate halts stage execution until the associated change ticket(s) are either approved or rejected. If the "Create Ticket" option is selected, change tickets can be automatically created by the gate. Change tickets can be defined either per Project/Package combination or as a single change ticket for all Project/Packages in the Snapshot. If no specific change ticket is provided for a Project/Package, the common change ticket listed in the stage execution details will be used. Users must manually enter the change ticket, if necessary, in the Stage Execution Information when the "Create Ticket" option is not checked. Additionally, the Change Ticket can be configured through a Custom Gate if required, as described later on this page.
The gate will complete successfully if all listed change tickets are approved. In this case, the approved change ticket(s) will be linked to the corresponding deployment executions. For example, CHG30301 will be associated with the deployment of the ALLIED-2 and ALLIED-3 packages, while CHG30350 will be associated with the deployment of the ALLIED-1 package. If there is no External Approval Gate in a stage, the Change Tickets entered will not be linked to deployments.
Additionally, this gate also creates a task for the group members of the associated override role, which allows for an override of the gate if necessary. Gate override is allowed by override role only if release setting does not prohibit override of external gate.
Administrators can always approve or reject this gate.
Change ticket can be entered (or created automatically) on stage execution information page.
When all entered change tickets are approved in external change management system, gate will be approved.
When any change ticket is rejected then gate will be rejected.
Even when change tickets are only entered on few of the project(s) / package(s) and not on main change ticket, gate will be approved.
Field | Description |
---|---|
Name | The name of the gate. |
Description | An optional description for the gate. |
Override Role | The pipeline role which is allowed to approve or reject the gate in FlexDeploy outside of the Change Management System. Provides mitigation in event that CMS is unavailable for any reason. Approval tasks are created for the group members of this role, and will be automatically approved or rejected based on the status of the associated change ticket. If no group member is assigned to the role, the task is assigned to a group designated as a FlexDeploy Administrator. Optionally, use a Groovy expression to make this field dynamic based on some contextual value (e.g. a property defined on the pipeline, and specified on the release). When using a role script you can dynamically return a key/value pair. For example If not specified, only a FlexDeploy Administrator can approve or reject the gate. |
CMS Instance | The Change Management System instance to use for this external gate. See Integrations page to configure change management system integration. |
Create Ticket | Determines whether to automatically create a CMS ticket when this gate is executed. If unchecked, it is expected that the related ticket fields for either the stage or the individual projects/packages is populated (either manually by the user or through a Custom Gate). |
Precondition | An optional Groovy script that determines whether the gate or step is applicable during execution. The script has access to variables and methods listed in Pipeline Groovy Variables and Methods. You can find these variables and methods while using the Groovy Editor. The script must return true if the gate is applicable, or false otherwise. If no script is provided, the default is to return true (applicable). |
Scope | Only applies when Create Ticket is checked. Determines the scope for setting the created change ticket.
|
<Ticket Fields> | Only applies when Create Ticket is checked. Used to set the values of individual ticket fields when creating a ticket. By default, the ticket field mapping comes from the global configuration. Use a Groovy expression to the values for the individual ticket fields and make them dynamic based on some contextual value (e.g. a property defined on the pipeline, and specified on the release). |
One common use case is to propagate the ticket number entered or created in one stage across into future stage(s) to avoid duplicate effort. This can be implemented by having a snapshot variable (e.g. CMS_TICKET) on the pipeline to hold the ticket, and a custom gate after the external approval gate to store the ticket number into the variable. The future stage can use another Custom Gate to set the related ticket from the value of the snapshot variable.
// Initial Stage in a Custom Gate
CMS_TICKET = stgexecinfo.getRelatedTicket()
// Subsequent Stage in a Custom Gate
stgexecinfo.setRelatedTicket(CMS_TICKET)
- style