/coalesce-22-inherited-project-refactoring-workshop

This repository contains the project for the Coalesce 2022 Inherited Project Refactoring workshop.

👑 Inherited Project Refactoring Workshop 👑

Welcome to the Inherited Project Refactoring workshop of Coalesce 2022!

🧙 About this Project 🐱

You've just started working at a new job and they've been using dbt to transform their data (YES!). However, once you've made it into their project, you realize that you can't make heads or tails of their data flows. Let's be honest - it's a messy project and you desperately want to form a plan for cleaning it up.

dbt's already got some great material out there regarding refactoring (if you want to start with hands-on-code refactoring, you can start with the refactoring course), but the road to get from where you are to where you need to be can be hard navigate unless you've traveled it numerous times. This refactoring workshop focuses on the roadmap for refactoring, and is the perfect start to getting that extra practice in!

Part of Christine and Lauren's day-to-day is taming those crazy projects - they've created this workshop to teach you the art of planning, show you some tips and tricks, and give you some leveling-up advice for wrangling those DAGs!

✅ Prerequisites:

Skillset
This workshop assumes that you're familiar with dbt. At a minimum you should know how to:

  • Generate documentation
  • Run commands and compile code
  • Create branches

Resources

  1. A Repository
    Ideally, with the files and folders contained in this workshop. To make a copy, fork this repository.

  2. dbt
    Using dbt Cloud vs. dbt Core doesn't matter. You'll specifically want to know how to:

    To setup dbt:

  3. Some Data
    This project is written on top of BigQuery and uses the publicly available TPC-H data set. A truncated version of the data set has been included in this project as CSV files, located in the _resources folder.

    If you don't have some data or a warehouse yet, don't worry - the setup will guide you through setting up a free BigQuery account and loading the data for this project. Here are some resources to reference, just in case:

    Note:
    We don't suggest seeding the CSV files. Though they are truncated, they still contain a significant amount of rows.

🧰 Setup

  1. Fork this repository.

  2. Set up your dbt Project

    Important
    If you don't set up the BigQuery account and want to use another warehouse:

    • You'll need a warehouse - the warehouse is an essential connection in dbt.
    • You'll need to load the data to your selected warehouse using another method.
    • You'll need to make changes to the repository code you forked so the syntax works with your warehouse.
  3. Load the data

    Download the files from the _resources/tpch_dataset. If you are working locally, the files will be within the repository location on your computer.

    • If you set up a BigQuery account during setup, load the data:

      1. In the BigQuery UI's Explorer pane, click the three dots next to your project name
      2. Click Create dataset.
      3. For Dataset ID, type raw_tpch.
      4. Click Create dataset
      5. You should now see your dataset listed under your project name. Click the three dots next to the dataset.
      6. Click Create table
      7. Choose Upload as the Create table from option.
      8. Click Browse under Select file
      9. Upload each file you downloaded from the _resources/tpch_dataset folder:
        • For the table name, use the file name without the extension. Some file names have _100mb appended. Omit this.
        • Make sure to check Auto detect under Schema
    • If you didn't setup BigQuery, load the data from the _resources/tpch_dataset into your warehouse.
      You will need to update the _sources.yml file with the location of your data.

  4. Run dbt deps to install dependencies.

  5. Confirm your setup:
    Try running the following commands:

    $ dbt run
    $ dbt test

    or alternatively:

    $ dbt build

 

🎉 You're ready to move on to the next stage! 🎉

Whoa... whoa there! You can't just go slinging at the DAG like that. Here's a walkthrough to get you trained up!

Additional Helpful Links:

  • Learn more about dbt in the docs
  • Check out Discourse for commonly asked questions and answers
  • Join the dbt community to learn from other analytics engineers
  • Find dbt events near you
  • Check out the blog for the latest news on dbt's development and best practices