Skip to content

prsutherland/pytest-sqlfluff

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pytest-sqlfluff

PyPI version Python versions See Build Status on Github Workflows Code Style: Black

A pytest plugin to use sqlfluff to enable format checking of sql files.


Features

  • Tests any sql files found in project.
  • Leverages existing sqlfluff configurations.
  • Skips unchanged sql files.

Requirements

Installation

You can install pytest-sqlfluff via pip from PyPI:

$ pip install pytest-sqlfluff

Usage

Out of the box, you can run pytest-sqlfluff as argument to pytest:

$ pytest --sqlfluff
====================================== test session starts ======================================
platform darwin -- Python 3.9.6, pytest-7.2.0, pluggy-1.0.0
rootdir: /code/github.com/prsutherland/pytest-sqlfluff
plugins: sqlfluff-0.1.0
collected 1 item

tests/file.sql .                                                                          [100%]

======================================= 1 passed in 0.45s =======================================

To configure your sqlfluff linting, use the standard sqlfluff configuration mechanisms. At the very least, you'll likely need to set the dialect.:

[sqlfluff]
dialect = postgres
...

Contributing

Contributions are very welcome. Tests can be run with pytest, please ensure the coverage at least stays the same before you submit a pull request.

To get started:

$ git clone https://github.com/prsutherland/pytest-sqlfluff.git
$ cd pytest-sqlfluff
$ poetry install

Run tests:

$ poetry run pytest

License

Distributed under the terms of the MIT license, "pytest-sqlfluff" is free and open source software

Issues

If you encounter any problems, please file an issue along with a detailed description.

About

A pytest plugin to use sqlfluff to enable format checking of sql files

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages