Skip to content

symon-ai/pipelinewise-tap-snowflake

 
 

Repository files navigation

pipelinewise-tap-snowflake

PyPI version PyPI - Python Version License: Apache2

Singer tap that extracts data from a Snowflake database and produces JSON-formatted data following the Singer spec.

This is a PipelineWise compatible tap connector.

How to use it

The recommended method of running this tap is to use it from PipelineWise. When running it from PipelineWise you don't need to configure this tap with JSON files and most of things are automated. Please check the related documentation at Tap Snowflake

If you want to run this Singer Tap independently please read further.

Install and Run

Ensure poetry is installed on your machine.

  • This command will return the installed version of poetry if it is installed.
poetry --version
curl -sSL https://install.python-poetry.org | python3 -
PATH=~/.local/bin:$PATH

Within the pipelinewise-tap-snowflake directory, install dependencies:

poetry install

Then run the tap:

poetry run tap-snowflake <options>

Configuration

  1. Create a config.json file with connection details to snowflake.

    {
      "account": "rtxxxxx.eu-central-1",
      "dbname": "database_name",
      "user": "my_user",
      "password": "password",
      "warehouse": "my_virtual_warehouse",
      "tables": "db.schema.table1,db.schema.table2"
    }

Note: tables is a mandatory parameter as well to avoid long running catalog discovery process. Please specify fully qualified table and view names and only that ones that you need to extract otherwise you can end up with very long running discovery mode of this tap. Discovery mode is analysing table structures but Snowflake doesn't like selecting lot of rows from INFORMATION_SCHEMA or running SHOW commands that returns lot of rows. Please be as specific as possible.

  1. Run it in discovery mode to generate a properties.json

  2. Edit the properties.json and select the streams to replicate

  3. Run the tap like any other singer compatible tap:

  tap-snowflake --config config.json --properties properties.json --state state.json

Discovery mode

The tap can be invoked in discovery mode to find the available tables and columns in the database:

$ tap-snowflake --config config.json --discover

A discovered catalog is output, with a JSON-schema description of each table. A source table directly corresponds to a Singer stream.

Replication methods

The two ways to replicate a given table are FULL_TABLE and INCREMENTAL.

Full Table

Full-table replication extracts all data from the source table each time the tap is invoked.

Incremental

Incremental replication works in conjunction with a state file to only extract new records each time the tap is invoked. This requires a replication key to be specified in the table's metadata as well.

To run tests:

  1. Define environment variables that requires running the tests
  export TAP_SNOWFLAKE_ACCOUNT=<snowflake-account-name>
  export TAP_SNOWFLAKE_DBNAME=<snowflake-database-name>
  export TAP_SNOWFLAKE_USER=<snowflake-user>
  export TAP_SNOWFLAKE_PASSWORD=<snowfale-password>
  export TAP_SNOWFLAKE_WAREHOUSE=<snowflake-warehouse>
  1. Install python dependencies
make venv
  1. To run unit tests:

PS: There are no unit tests at the time of writing this document

make unit_test
  1. To run Integration tests
make integration_test

To run formatting and linting:

make venv format pylint

License

Apache License Version 2.0

See LICENSE to see the full text.

About

Singer.io Tap for Snowflake - PipelineWise compatible

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 99.3%
  • Makefile 0.7%