Skip to main content

Magically refactor Python

Project description

Sourcery Logo

Sourcery Command Line Interface

Installation and usage

Installation

Sourcery command line interface can be installed by running:

pip install sourcery

Login

Once installed you need to log in with:

sourcery login

which will open up a browser tab and ask for confirmation. This is only needed once per computer.

You can also log in via providing your token:

sourcery login --token YOUR_TOKEN

Usage

To review a file or a directory (recursively) with Sourcery, use the sourcery review command:

sourcery review example_file.py

To apply the changes suggested by Sourcery, use the --fix option:

sourcery review --fix {file_or_directory}

Command Line Options

Sourcery provides a few options for running. You can list them by running sourcery review --help

sourcery review --help


Usage: sourcery review [OPTIONS] [SRC]...

  Review SRC files/directories. Reads from stdin when SRC is -

Options:
  --diff TEXT               Run only on changed code with diff command (e.g.
                            "git diff")
  --enable TEXT             Only run the specified rule or tag. This option
                            can be used multiple times.
  --disable TEXT            Skip the specified rule or tag. This option can
                            be used multiple times.
  --check                   Return exit code 1 if unsolved issues found.
  --fix                     Automatically fix issues where possible.
  --config FILE             Location of the Sourcery YAML config file. Can be
                            a file or URL.
  --csv                     Output in CSV format
  --verbose                 Verbose output with explanation and code
                            snippets.
  --summary / --no-summary  Flag to determine whether to print a summary of
                            the review. Default: true.
  -h, --help                Show this message and exit.

Configuration

Sourcery reads configuration settings from .sourcery.yaml in the project directory. Full details are described here.

Pre-commit Hook

Sourcery works great with pre-commit. Once you have it installed, add this to the .pre-commit-config.yaml in your repository:

repos:
  - repo: https://github.com/sourcery-ai/sourcery
    rev: v1.25.1b4
    hooks:
      - id: sourcery
        # The best way to use Sourcery in a pre-commit hook:
        # * review only changed lines:
        # * omit the summary
        args: [--diff=git diff HEAD, --no-summary]

To review all changes compared to the main branch:

args: [--diff=git diff main]

If you want Sourcery to automatically apply the suggested changes,add the --fix option:

args: [--diff=git diff HEAD, --fix]

If Sourcery is the first pre-commit hook that you've added to your project, you'll also need to run pre-commit install.

Continuous Integration

For the majority of projects, the best usage of Sourcery in the CI is to review only the code of the current PR.

You can use the script below to detect Sourcery violations that are present in the current code but not in the main branch:

pip install sourcery
# Store your Sourcery token as a secret in your CI environment.
sourcery login --token $SOURCERY_TOKEN
sourcery review --diff "git diff main" .

Instead of main, you can pick another branch as well. For example, in GitHub Actions you can use --diff="git diff ${{ github.event.pull_request.base.sha }}"

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

sourcery_nightly-1.25.1b4-py2.py3-none-win_amd64.whl (107.4 MB view details)

Uploaded Python 2 Python 3 Windows x86-64

sourcery_nightly-1.25.1b4-py2.py3-none-manylinux1_x86_64.whl (140.3 MB view details)

Uploaded Python 2 Python 3

sourcery_nightly-1.25.1b4-py2.py3-none-macosx_10_9_universal2.whl (109.2 MB view details)

Uploaded Python 2 Python 3 macOS 10.9+ universal2 (ARM64, x86-64)

File details

Details for the file sourcery_nightly-1.25.1b4-py2.py3-none-win_amd64.whl.

File metadata

File hashes

Hashes for sourcery_nightly-1.25.1b4-py2.py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 fd6e8387a4e9b6d25d73c055a3c9ae4b15047e7fa7919f3de8af8080af1d8a2e
MD5 9ba4739dc7999aea231b75c4f89dc0f6
BLAKE2b-256 d76d42b4c5f685cabcc741be7ec205993abff411e0a7175f79048bbb22029ff9

See more details on using hashes here.

File details

Details for the file sourcery_nightly-1.25.1b4-py2.py3-none-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for sourcery_nightly-1.25.1b4-py2.py3-none-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 a7926821ad045d7a83c9e5814f3f7cb9047c79c938a53c256d550266dd794fe7
MD5 3d3f29e13b796eb4e6631bb0a7c75f06
BLAKE2b-256 46291d88d95ae8776a4a5103a44ed83f0bb688f195ec6f80fb1c18a82f8cf789

See more details on using hashes here.

File details

Details for the file sourcery_nightly-1.25.1b4-py2.py3-none-macosx_10_9_universal2.whl.

File metadata

File hashes

Hashes for sourcery_nightly-1.25.1b4-py2.py3-none-macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 bd4b7d9db01bebf56657878f6855f4e4e6797ff38b7e85f4b430bfc4a7a7d8e0
MD5 ed583113d97715c68812fd6baf8734ea
BLAKE2b-256 0eba7a95a4981db44c5fe4f88cbcf43e85874c4a0007b7e935d7d3c9a533e3ff

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page