Skip to main content

Install and Manage Packages

Coalesce Packages are custom Node Types that are accessed from the Coalesce Marketplace.

Coalesce Marketplace is a centralized library that provides data teams with templated collections of code, known as Packages. Every Package provides a curated selection of different Snowflake objects (known as node types in Coalesce), which are bundled together for a particular purpose, such as building out declarative data pipelines or implementing a Data Vault.

Packages Availability

Packages are currently only available in the US and EU regions for now. ANC and Canada will be available at a later date.

Install Packages

You can install packages from our Coalesce Marketplace. Packages are installed on the Workspace level only.

  1. Choose a package from the Coalesce Marketplace.

  2. Make note of the Package ID.

    The Dynamic Tables Package streamlines Snowflake data pipelines with tools for creating, deploying, and managing dynamic tables. It enhances efficiency by automating table updates and ensuring data consistency. This package is essential for maintaining robust and scalable data workflows.
  3. In the Coalesce App, go to Build Settings > Packages. Click Install.

    The installation screen for packages requires the user to enter the Package ID and Version, as well as a unique and descriptive Package Alias. For further details and guidelines, users are directed to the Coalesce Documentation. This ensures proper configuration and management of installed packages.
  4. Enter the Package ID you previously copied.

  5. Select the version you want to install.

  6. Enter a Package Alias. The alias is a unique and descriptive name for the package so you can easily identify it later.

    1. A package alias can only contain letters, numbers, and dashes. It can’t contain consecutive dashes.
    2. Package aliases can’t start or end with a dash.
  7. Install your package.

Use a Package

Once a package is installed, you can use them like any other Node. Create a new Node in the Mapping Grid or change the node type in the Node Editor.

Manage Your Packages

Packages can come installed with multiple Macros and Node Types.

Use Package Macros In Your Workspace

If your Package includes macros, you can use them in any Node. First, add them to your Workspace macros so they’re available throughout your Workspace.

  1. Go to Build Settings > Macros.
  2. Select the Workspace macros from the list.

Next, import the macros in your Workspace macros:

{% import "<package-alias>" as <friendly-name> with context %}

After importing, call the macro using its alias:

{{ <friendly-name>.<package-macro-name>(<parameter>, <parameter>) }}

Example Using Package Macros

If you installed the @coalesce/test-utility Package with the alias testUtils and want to use a macro called expect_table_row_count_to_be_between in a Node test:

  1. In your Workspace macros, add:

    {% import "testUtils" as testUtils with context %}
    The Workspace macros screen allows users to import macros from installed Packages.
  2. Call the macro:

    {{ testUtils.expect_table_row_count_to_be_between('{{this}}', 1, 5) }}
    Calling a imported macro for use in a Node test.

Workspace Macros

If you want to use Workspace macros in a package node, you can use them as normal. The import syntax isn’t needed.

Edit the Package Configuration

The package configuration is a set of variables you can set values for to customize the package for your use. The available configuration options depend on the package. Not all packages have a configuration. For example, timestamp_format would let you set the format to HH:MM:SS.

  1. Go to Build Settings > Packages.
  2. For the package you want to edit, click Edit Config.
The package configuration screen allows users to edit the configuration settings of an installed package. Users can define various parameters such as aliases, hash settings, timestamp formats, and default values to customize the package behavior. This feature ensures that the package operates according to specific project requirements and standards.

Enable or Disable Package Nodes

Packages will be listed by the package alias created during installation.

Go to Build Settings > Node Types, to toggle the node.

The Node Types screen allows users to manage various node types associated with installed packages, enabling or disabling them as needed. Each node type can be assigned a default storage location and linked to a specific package version.

Duplicate or Copy Packages

You can duplicate packages by going to Build Settings > Node Type and selecting Duplicate next to the package you want to copy. Duplicating a package allows you to customize the package Node Types.

Screen showing the results of copying a package in Coalesce.

Upgrading Packages

  1. Install the new package version. You'll follow the same steps as installing a package, just choose the version you want to install.
  2. Copy the package configuration from the old package to the new package.
  3. Bulk update the node types of any nodes you want to move.
  4. Uninstall the old package version.

Uninstall a Package

Packages can only be uninstalled if they aren’t in use. In use packages will return a list of locations the package is in use. You’ll need to remove those locations before you can delete them.

This screen informs users that the package support-demo-docs version 1.0.0 contains custom node types currently in use by the workspace. To remove the package, users must update or remove nodes using these custom types. It lists the node types and the number of nodes for easy management and action.

To delete a package:

  1. Go to Build Settings > Packages.
  2. Click Uninstall next to the package you want to delete.
  3. This will remove the package from the current workspace.

Your packages are committed using the package alias you created during installation. The file will contain the package ID.

Git and Packages

Your packages are committed using the package alias you created during installation. The file will contain the package ID.

To see an example of a Git Commit, review What Gets Committed.

Example of two packages being committed.