Contribution Workflow

[ this workflow will be actively updated and enhanced as we receive feedback ]

Create and contribute your first model

  1. Understand the modeling structure

    • Data models iterate through different β€œlayers”. Generally speaking these are bronze, silver, and core. How these layers interact is defined in Model Standards.

  2. Create model file within the proper layer and naming convention

    • Naming convention for file is <layer name>__<table name>.sql

    • Example for silver layer: ./models/silver/silver__my_new_table.sql

  3. Create a corresponding .yml file

    • This should hold any model/column descriptions and tests for the model/columns

    • Example for silver layer: ./models/silver/silver__my_new_table.yml

  4. Start writing SQL code

  5. Turn SQL code into DBT SQL

  6. Run the dbt model to put it into the community dev database. You must run this command within the dbt-console. If you have exited the console run make dbt-console again

    • dbt run -s <path to model>

    • If this is your 1st time using dbt run in this docker container, you may need to run dbt deps command

    • Models will be deployed to <BLOCKCHAIN>_COMMUNITY_DEV database within Snowflake. This database refreshes daily at 04:00 AM UTC, any non-production resources will be erased.

  7. Run the test file

  8. Create GitHub Pull Request and write a summary on your updates/changes, as well as attaching passing test logs

  9. Request Reviewer from one of the GitHub handles below

    • austinFlipside

    • juls858

    • James-Mission

    • desmond-hui

  10. Fix Review Comments

  11. Re-Request Reviewer after fixing review comments

  12. If your PR has been approved, merge it to production

  13. Congratulations! You’ve successfully contributed a data model!

Last updated