This topic explains the general procedure you might use to define and configure the building blocks for your release process, including the environments that support your release life cycle, applications supporting the release deployment, and finally, the routes and policies that enable you to coordinate the release workflow.
This topic includes the following sections and use cases:
Before you begin 
- Plan your release life cycle. Consider the following stages:
 - Development
- Quality assurance (QA)
- User acceptance testing
- Deployment to production
 
- Plan the environment needed for successful release deployment, including hardware, software, and network components.
- Ensure the integration of all external systems that you are planning to use such as a build server, bug tracking system, test management system, and so on.
- Based on your release life cycle model, create plan templates for your continuous integration, deployment, and release plan.
- Plan roles for your project team members. For example:- Release manager—Schedules, coordinates, and manages releases, including application updates, patches, and security improvements.
- Environment manager—Manages processes for an application within a specific environment, including strategies for moving the application to another environment.
- Test engineer—Uses requests to test whether the product meets applicable specifications.
 
- Plan your product support and updating, including the continuous building, deploying, and updating of software and environments.
High-level steps for managing configuration of applications, topology, and infrastructure 
- Develop the release plan template with the necessary stages that match your release life cycle. For example, you might have the following stages: development > performance testing > regression testing > pre-release testing > user acceptance > deployment to production.
- Create the infrastructure for every release stage. You might have several servers for front end, back end, database, and others. Add every server that you plan to use with your application to BMC Release Process Management, using the procedure described in Use case 1: Add a hardware or virtual server involved in the release process.
- Create software components that are necessary for release delivery and for application operation in the target environment, using the procedure described in Use case 3: Create components of the release.
- Create the environments to support your release life cycle. You might need a separate environment for development, quality assurance, user acceptance testing, and production. 
 
 In BMC Release Process Management, an environment contains all the infrastructure elements required to deploy an application on a particular stage of the release life cycle.
 
 Your typical environment might contain several physical or virtual servers, hosted applications that are necessary for the successful deployment and operation of the released software (for example, web servers, application servers, database servers, and legacy applications), specific configuration settings for these servers and hosted applications, and finally, the network infrastructure that enables connectivity between the servers and hosted applications (for example, firewalls, SAN Storage, or network switches).
 
 You can assign an opened or closed deployment policy to your environments. With an opened deployment policy, you can access the environment at any time, except during the time frame of the associated prevent deployment windows. With a closed deployment policy, you can access the environment only during the time frame of the associated allow deployment window. For more information about managing the access to your environments with deployment windows, see Managing-deployment-windows.
- Create the application and select the servers on which you want to deploy the application.
- Create deployment windows for the application environments.
 
 A deployment window is a calendar event that allows or prevents the deployment of an application to a particular environment based on the environment deployment policy. You can create single deployment window events or a series of deployment windows.
- Create packages to manage binary files for applications, using the procedure described in Use case 7: Create packages, properties and references, and map packages to an application.
Use case 1: Add hardware servers or virtual servers for the release process 
Create all the servers necessary for your release process on all phases.
Click here to expand.
- Click Environment > Servers.
- On the Active Servers page, click Create Server on the right.
- Enter the following information for the server: |  |  | 
|---|
 |  | A unique name for the server |  |  | The Domain Name System (DNS) or Uniform Resource Locator (URL) for accessing the server |  |  | The Internet Protocol (IP) address of the server |  |  | The operating system on which the server runs |  
 
- In the Server Groups field, select the server groups that you want to associate with the server. 
- In the Environments field, select the environments that you want to associate with the server.
- Click Create.
 For more information, see Managing-servers.
Use case 2: Create environments for release deployment 
Create environments that you are planning to use during your product release life cycle.
Click here to expand.
- Go to Environment > Environments, and click Add a new environment on the right.
- Enter a name for the new environment.
- From the Environment type, select the environment type.
- From the Deployment policy list, select the deployment policy for the environment:
 - Select Opened to create an environment with opened deployment policy.
- Select Closed to create an environment with closed deployment policy.
 
- Add servers and server groups that you want to associate with your environment.
- Click Create.
WarningNote
Alternatively, you can add environments under Dashboard > My Applications, by clicking the application name to which you want to add a new environment. Click the add/remove environments link, and then click the create new environment link. However, in this case you cannot assign the environment to the desired environment type.
  For more information, see Managing-environments.
Use case 3: Create components of the release 
- Create all the components necessary for your release process on all phases. - 
- 
Click here to expand.
- In BMC Release Process Management, click the Applications tab and click the appropriate application name.
- Click add/remove components.
 The Add/Remove Components dialog box appears.
- Click create new component one time for each component that you want to add.
- Enter a name for each component in the displayed fields.
- Click Save.
 The new components are added to the list of components.
 
 - For more information, see  Managing-components. 
- Map components to external objects. - 
- 
Click here to expand.
- On the Applications tab, click an application in the list.
- In the list of components, click Map next to the component that you want to map with an external object. 
- On the Map Component to an External Object dialog box, provide the following details:- Select an integration server from the Select Target Server list.
 This list displays integration servers that you created previously to integrate between various external systems. You must select the integration server that you created to integrate with the external system to which you want to connect when performing this mapping.
- Select a resource automation script from the list of available scripts.
 This list is available only after you select an integration server. You must select the resource automation script that you created previously for the purpose of mapping. For more information on creating a resource automation script, see Creating-resource-automation-scripts.
 - Warning- Notes - The resource automation script that you select must have its Maps to option set to Component.
- You can use one integration server at a time to create a single mapping with an external object.
 
 - While selecting the integration server and the resource automation script, you might see multiple objects that are generated automatically. The objects that you see and the output in which you see them (whether a tree or list of objects) depends on the resource automation script that you selected. The resource automation script retrieves data about the external objects and provides it to you so that you can select one of them for mapping with a component. 
 
- Click Save Mapping to save your changes.
- To modify or delete the mapping that you already created, perform the following steps:- Click Edit Map next to the component under the Actions column.
- On the Map Component to an External Object dialog box in the Select Target Server list, select the integration server for which you want to make changes or delete the mapping, and select the same resource automation script that you used to create the mapping. 
 The current mapping is displayed.
- Modify your mapping and click Save Mapping.
- To delete the mapping, click Delete Mapping and then click OK.
 
 - For more information about mapping components with component templates of BMC Application Automation, see Mapping-components-with-component-templates. 
 - For more information, see Managing-components. 
WarningNote
If an application depends on components in a separate application, the components in the other application are referred to as remote components. For example, the database component for an application named TravelTime might be supplied by a separate application named Oracle. In this case, the TravelTime application refers to the remote component in the Oracle application.
 Use case 4: Create properties configuration 
- Create a property and assign components or servers to the property. - 
- 
Click here to expand.
- From the Environments tab, click Properties, and then click Create Property.
- In Name, enter the name for the property.
- In Default Value, enter a list of the property values separated by comma.- You can enter numbers as the property values.
- If you want to leave the field blank, enter a comma.
 
- For a property that follows a component, click show at the left of Components Assignment and select the components to which to assign the property.
- For a property that follows a package, click show at the left of Package Assignment and select the packages to which to assign the property.
- For a property that follows a server and not the component installed on the server, click show at the left of Server Assignment and select the servers to which to assign the property.
- For a release that uses server levels, select the required server levels.
- Allow modification of property values during work task creation and execution, if desired.
- Click Create.
 
 - For more information, see Managing-properties. 
- Allow modification of property value during the work task creation or request execution. - 
- 
Click here to expand.
- Warning- Perform the following steps if a property does not change with an environment or component, but you want to allow modification of the property value during work task creation and execution. 
 - Click show at the left of the Property Entry Assignment pane.
- In the Work Tasks for Creation list, select the tasks where this property value can be modified during request creation.
- In the Work Tasks for Execution list, select the tasks where this property value can be modified during request execution.
 
 
Use case 5: Create an application for the release 
- Create an application for the release. - 
- 
Click here to expand.
- Start the BMC Release Process Management application and select the Applications tab.
- Click Create Application.
- In the Name field, enter the name for your application.
- (Optional) In the App version field, enter the version number of your application.
- (Optional) Ensure that Strict plan control is selected if you want to use your application only in requests that are part of a release plan.
- Select a team from the drop-down list to associate the application to a team. By default, an application is associated with the Default team.
- Click Create.
 
 - For more information about applications, see Managing-applications. 
- Add the environments that the application will go through during the release process. - 
- 
Click here to expand.
- Go to Environment > Environments, and click Add a new environment on the right.
- Enter a name for the new environment.
- From the Environment type, select the environment type.
- From the Deployment policy list, select the deployment policy for the environment:
 - Select Opened to create an environment with opened deployment policy.
- Select Closed to create an environment with closed deployment policy.
 
- Add servers and server groups that you want to associate with your environment.
- Click Create.
 - Warning- Note - Alternatively, you can add environments under Dashboard > My Applications, by clicking the application name to which you want to add a new environment. Click the add/remove environments link, and then click the create new environment link. However, in this case you cannot assign the environment to the desired environment type. 
 
 - For more information about environments, see Managing-environments. 
- Add components. - 
- 
Click here to expand.
- In BMC Release Process Management, click the Applications tab and click the appropriate application name.
- Click add/remove components.
 The Add/Remove Components dialog box appears.
- Click create new component one time for each component that you want to add.
- Enter a name for each component in the displayed fields.
- Click Save.
 The new components are added to the list of components.
 
 - For more information about components, see Managing-components. 
- Associate components with the environments. - 
- 
Click here to expand.
- From Dashboard > My Applications or from the Applications tab, click the relevant application name.
- To copy all component associations from one environment to any number of target environments, perform the following steps:- Click the source environment to expand it and display its list of associated components.
- Click Clone Environment Components under the list of components.
- Select the target environments (to which to copy component associations), and then click Save.
 
- To associate individual components with a single environment, perform the following steps:- Click the target environment to expand it and display its list of associated components.
- Drag each component that you want to associate from the components list on the right, and drop it on the list of environment components on the left.
 
- To remove a component from the list of components associated with an environment (in the environment's expanded display), click the Remove installed component icon in the right-most column, and then click OK.
 
 - For more information, see Associating-components-with-environments. 
WarningNote
An application might have a three-tier architecture, in which case a component could be an application server, a database, and a load balancer.
 - Create routes to determine the order in which environments are accessed by the application. - 
- 
Click here to expand.
- Open the Applications tab.
- Click Create Application to create a new application, or click the name of the existing application for which you want to create a route.
- Open the Routes tab. - Warning- Note - The default route is created automatically. It contains environments that are associated with the application. You can view the default route by clicking either Edit or the default route name. 
 
- To create a new route, click Create Route. 
- Enter the route name and description, and then click Create.
- From the Available Environments table, select the environments for which you want to assign to the route, and then click Add Selected. - Warning- Notes - Based on the environment type, environments are automatically assigned to the appropriate route via the route gates. For more information, see Managing-environment-types. You can rearrange the route gates by dragging the environmnents and dropping them in the desired order.
- If in the Available Environments table there are no environments to select, return to the application details page under Applications > Apps, and click the add/remove environments link to add the environments to your application.
 
 
 
 - For more information, see Managing-routes. 
- Create a plan template to structure the release plan of your software. - 
- 
Click here to expand.
- Click Environment > Metadata > Manage Plan Templates.
- Click Create Plan Template.
- In the Name field, enter the name of your template.
- From the Template type field, select the template type.
- Click Create.
- To complete the plan template, click Add stage below the plan and add as many stages as required.
- (Optional) If you want to make the plan template available for other users, go to Environment > Metadata > Manage Plan Templates and change the status for the plan template to a state other than Draft.
 For more information about the states available for plan templates, see Using status of objects.
 
 - For more information, see Managing-plans. 
- Add stages (Development, QA, Staging, Production and so on) to the plan template. - 
- 
Click here to expand.
- After creating a plan template, you must add stages. - From Environment > Metadata > Manage Plan Templates.
 The list of existing plan templates is displayed under Plan Templates.
- Click the template to which you want to add stages.
 The selected template opens.
- In the Stages section, click Add stage.
 You can add as many stages as needed.
- In the Creating Plan Stage dialog box, enter a name for the stage in the Name field.
- From the Environment type list, select the environment type that you want to be mapped with the plan stage.  
- To make this stage required, select the check box.
- From Default Request Template, add as many request templates as you require. Use the Ctrl key to add multiple templates.
- Click Create.
 
 - For more information, see Managing plans. 
- Create a plan to organize the software release process. - 
- 
Click here to expand.
- From the Plans tab, click Create Plan.
- From the Plan Template list, select a template.
- In the Plan Name field, type a plan name.
- From the Release Manager list, select the release manager name.
- From the Teams field, select the required check boxes.
- From the Release tag list, select a release tag.
- From the Release Date field, select a release date. - Warning- Note - If you click Edit Plan Details after you have created the plan, the release tag and the release date that you select appear as defaults. They also appear as defaults when you want to add a request to the plan. 
 
- Enter a release description in the Release Description field.
 
 - For more information, see Managing plans. 
- Add routes to a plan. - 
- 
Click here to expand.
- Click Create Plan to create a new plan, or click the name of the existing plan to which you want to add a route.
- Click Assign App Route.
- Select the desired application from the App list.
- Select the desired route from the Route list.
- Click Add.
 The Routes tab opens with the plan stages mapped to the application route environments.
 
 
 - Warning- Note - Route gate constraints validate the compliance of the request environments to the plan stage route gates. Route gates are mapped to the plan stages according to the environment types of the route gate environments. You can change the default (automatic) route gate assignment to plan stages. For more information about route gates, see Managing-routes. 
 
 - Error- Warning - After adding a route to a plan, you cannot reopen the completed request if the environment of the request does not match the environment specified in a route. 
 
 - For more information, see Managing plans. 
- Create a plan run to assemble requests from different applications and different environments in an executable flow. - 
- 
Click here to expand.
- Click the Plans tab.
- From the list of plans, click a plan to open it.
- Select the stage containing the requests for which you need to create the run.
- Click Create Run.
- Enter the appropriate information in the fields. - Warning- Note - Only the Name and Owner fields are required. The rest of the fields are optional.  
 
- (Optional) Select the Auto promote check box to enable the run to promote automatically to the next plan stage after successful completion of all the requests in the run. Otherwise, you can promote the run manually.
- Click Create.
- After you create the run, you can perform the following tasks (the buttons are associated with each stage):- Reorder run (Click the Reorder run tab and then drag and drop the requests.)
- Plan run
- Cancel run
- Hold a run
- Delete a run
- Add and remove a request from a run
- System can automatically put run in problem or complete status based on child request status - Warning- Note - When all the requests go into the Complete state, the run is finished. 
 
 
 
 - For more information, see Managing-plan-runs. 
- Create deployment windows or deployment windows series to manage access to the environments.
Use case 7: Create packages, properties and references, and map packages to an application
- Create a package to manage binary files for applications. - 
- 
Click here to expand.
-   - Go to Environments > Packages.
- Click Add a new package.
- In Name, enter a name for the package.
- Click Create to create the package.
 The Edit Package page opens.
- In Instance name format, enter the mask for names of instances related to this package (for example, 0.0..0[#]).
- In Next instance number, enter the value to be used in a mask for the next package instance name (for example, 1).
- In the Properties section, add properties to the package.
- In the References section, add references to the package.
- Click Update to save your settings.
 
 - For more information, see Managing-packages. 
- Add existing properties to the package or create new properties for the package. - 
- 
Click here to expand.
-   - Go to Environments > Packages.
- From the list of packages, click the appropriate package.
 The Edit Package page opens.
- To add existing properties to the package, perform the following actions:- In the Properties section, click Map/Unmap Properties
 The Select properties dialog box opens
- From the left property list, move properties that you want to add to the package to the right property list.
- Click Select Properties to save your changes.
 
- To add a new property to the package, perform the following actions:-  In the Properties section, click Add Property.
 The Create New Property dialog box opens.
- Enter the necessary property data as described in Managing-properties.
- Click Create to save your changes.
 
- Click Update to save changes to the package.
 
 - For more information, see Managing-packages. 
- Add references to the package. - 
- 
Click here to expand.
- Go to Environments > Packages.
- From the list of packages, click the appropriate package.
- In the References section, click Add Reference.
- Specify the following details for the reference:- In the Name field, enter the name for the reference.
- In the Method field, ensure that the File access method to a package is selected.
- From the Server list, select the appropriate server for a reference.
- In the Uri field, enter the server URL address for the reference. - 
- 
Click here to expand.
 - Warning- Note - The Uniform resource identifier (Uri) is a string of characters used to identify a name of a resource. The Uri is metadata and can be in any format, but the most common format is a URL. Depending on the packaging tool that you are using, you can add whatever you need. Properties should be in the format of the packaging tool. For example, for BladeLogic Server Automation, you can use ??PROP??. For BMC Release Package and Deployment, you can use ${prop}. 
 
 
- Click Create Reference to save your changes.
 
 - For more information, see Managing-packages. 
- Assign packages to an application. - 
- 
Click here to expand.
- Click the Applications tab.
- From the list of applications, click edit for the required application.
- Click the Packages tab on the right.
- Click Add/Remove Packages.
 The Select Packages dialog box opens.
- For each package that you want to assign to the application, move the package from the list on the left to the list on the right.
- Click Select Packages to save your package selection.
 
 - For more information, see Managing-packages.