Skip to main content
All CollectionsTx
Tx Deployments
Tx Deployments

Deploying a Tx project to an Environment

I
Written by Ivan Lopez
Updated over a year ago

A deployment is the act of copying a project codebase from a git branch to a Tx Environment, thereby fixing a static version of the project for testing or productive runs. During a deployment, the CREATE script of all project objects is compiled and compared against the related Snowflake environment, and corresponding CREATE/ALTER scripts are run.

Once a deployment is complete, the Tx Environment is aligned with the Snowflake environment and subsequent transformational runs can be performed.

Performing a deployment requires a Tx Environment. Please review the related documentation at the end of this article to ensure that a Tx Environment exists before proceeding.

Initiating the deployment

To initiate a deployment, the user can access the "Deploy" button on the toolbar. Upon clicking, a deploy popup is displayed, guiding the user through the environment selection and deployment process.

Selecting the environment

  • Environment list: A list of all available environments (excluding the current environment that represents the development environment) is presented in the popup. Each environment entry includes its name, type, and the last commit details.

  • Environment selection: Users can select an environment by clicking on its name. Once selected, the environment becomes highlighted, indicating it's ready for deployment. It is important to note that a selected environment cannot be deselected unless another environment is chosen.

Selecting a commit

Once the environment is selected, the next step is to choose a branch and a corresponding commit:

  • Branch selection: Users can view a list of all available Git branches, sorted in ascending order. Selecting a branch displays all commits associated with it. Users can search for a specific branch using the search field.

  • Commit selection: Each commit is represented by its ID (first 8 characters), author, comment, and timestamp. The user selects the desired commit for deployment from this list.

Previewing deployment

After selecting the commit, a preview of the deployment will be shown, which includes the following:

  • Tx Objects: The system compares the DDL script from the selected commit with the current environment. Based on this comparison, the system generates CREATE or ALTER scripts for new and updated objects, respectively. The proposed ALTER scripts shall be reviewed and modified manually if needed to avoid data loss.

  • Mapping Section: Displays the mappings of Tx objects to locations, such as databases and schemas.

  • Tx Templates: Displays the Properties, Create script, and Run script for all Tx templates.

Understanding the ALTER process

Tx employs a method that uses clone (copy) tables to ensure that any changes are first applied to a copy, safeguarding the original table from potential errors. This is the complete process:

  • Creation of a clone table. When Tx generates an ALTER statement, it first creates a clone (copy) of the original table.

  • Applying the ALTER operation. The system performs the ALTER operation on the clone table. This step isolates any issues that might occur during the modification process.

  • Swapping tables on success. If the ALTER operation is successful on the clone table:

    • The system swaps the original table with the altered clone table.

    • After the swap, the cloned table is dropped to free up resources.

  • Failed ALTER operation: If any ALTER operation fails on the clone table:

    • The clone table is dropped automatically.

    • The original table remains intact and unaffected. No Data Loss: This process ensures that your data remains safe even if modifications do not go as planned.

Identifying ALTER scripts for Tx Objects

An icon will differentiate ALTER scripts for the different Tx Objects. This visual aid helps quickly identify and manage scripts associated with specific objects in your database.

Important Warning Before Deployment

Before deploying any ALTER scripts, a warning will showcase:

Please verify the proposed ALTER script and edit if necessary to avoid data loss.

  • Action Required:

    • Review the script: Carefully check the proposed ALTER script.

    • Edit if necessary: Modify the script to fit your specific requirements and to prevent any unintended consequences.

Deploying the objects and viewing results

Once the preview is reviewed, the user can proceed with the deployment. The system will execute the CREATE and ALTER scripts. Once the deployment is complete, the results can be viewed in the "View Results" tab. This tab contains the following details:

  • Deployment Summary: A summary of the deployment status, including the number of objects deployed successfully or skipped, is provided at the top of the results tab. Includes start and end times, execution duration, and the number of objects inserted, updated, or deleted.

  • For each deployed object:

    • Execution Details: Includes start and end times, execution duration, and the number of objects inserted, updated, or deleted.

    • Deployment Status: A status icon (green, red, or grey) is displayed based on whether the objects deployed successfully, encountered errors, or have been skipped for each item object. Users can open the deploy object and view the executed statement.

This deployment process ensures that all changes are applied accurately while providing users with real-time feedback on deployment progress and results​​​.


See also:

Did this answer your question?