Skip to content

Latest commit

 

History

History
49 lines (37 loc) · 3.74 KB

README.md

File metadata and controls

49 lines (37 loc) · 3.74 KB

sqlfluff-github-actions

The official resource for SQLFluff related GitHub Actions and Workflows.

Menu of GitHub Workflows

Workflows are listed below by contributing team with a brief description. To learn more and how to implement each, click the links below.

  • Sunrise Movement

    • Simple, clean.
    • Start here if you are new to workflows!
  • Surfline

    • Lints any added or modified models in /models
    • Uses conda to setup a virtual environment and manage python, dbt, and sqlfluff dependencies.
    • Uses templater = dbt - this requires a dummy profiles.yml and the ability to connect to your data warehouse from inside the workflow.
      • If your data warehouse only allows connections via VPN, the workflow includes steps to configure a VPN connection. This can be easily disabled if not needed.
    • Annotates failures on the PR, on the line where they occur.
  • Drizly

    • Lints modified and changed SQL files in PRs (in your dbt/models directory)
    • Annotates failures on the PR, on the line where they occur
  • Jetblue

    • Uses a combination of SQLFluff and Diff Quality to lint only new/modified .sql files
    • Only runs on a github pull request when a comment has /lint (can be adjusted) in it
    • Returns output of lint as a tidy comment on same github pull request
  • tails.com

    • Heavily inspired by the Surfline worflow, with the following additions:
    • Custom root directory.
    • requirements.txt based dependency managment rather than conda.
    • Robust to logging bugs in dbt logging, but using the sqlfluff --write-output option.

A note on nomenclature

GitHub Actions is a feature within GitHub. It allows you to...

Automate, customize, and execute your software development workflows right in your repository with GitHub Actions. You can discover, create, and share actions to perform any job you'd like, including CI/CD, and combine actions in a completely customized workflow.

These workflows, defined by YAML files placed in the .github/workflows/ directory of your repo, are event-driven, meaning that you can run a workflow after a specified event has occurred (e.g., opening a Pull request to the main branch).

To add a layer of confusion, the GitHub Marketplace has individual "Actions" (e.g., the checkout action) that you can use as steps inside your workflow(s). Using Actions can reduce the code you need to write to define your worflow and accomplish your goal.

Conceptually, you can connect these poorly named pieces like so:

  • GitHub Actions (a feature within GitHub allowing you to automate workflows).
    • Workflows (define a list of steps to be executed. Triggered by an event like opening a Pull request).
      • Actions (help you perform individual tasks within workflow, like checking out the pull request branch, without you having to write a bunch of code).

Often you will hear us (and others, including GitHub) use the term "GitHub Action" and "Workflow" interchangeably. If you simply remember that the YAML files are defining a list of steps to be executed when a certain event happens in your repo, you are well on your way to understanding and using the power of workflows in GitHub Actions.

Resources

See the Github docs to learn more about GitHub Actions and developing your own worflows.