Skip to main content

A watcher for running python code when after every modification

Project description

python-watcher

I've crated this project to watch over a repo dir and execute a file after modifying anything on that same dir. Its lightweight since it only has watchdog as a dependency.

Parameters for running

-d or --dir (str, required): 
    Folder you want the watcher to look for changes. Defaults to "."
-f or --file (str, required): 
    Script that you want to run after a file is changed (probably you main.py or something similar)
-t or --time (int, optional):
    Time delay to run again (good when saving constantly). Defaults to 1.
--test (bool, optional):
    If the watcher should run pytest command instead of python. Defaults to False.
--lint (bool, optional):
    If the watcher should run pylint command instead of python. Defaults to False.
--lint_src (str, optional):
    where the linter should be run (so it does not run into unwanted files).
--lint_threshold (float, optional):
    Threshold for Pylint to fail. Defaults to None (no threshold).

To run

Watching and executing a python script:

# watch changes in the directory "." and execute watcher.py
watcher -d . -f watcher.py

# watch changes only in the file watcher.py
watcher -f watcher.py

# watching and executing pytest
watcher --test

# watching and executing pylint only for "src" directory with a threshold with 90%
watcher --lint --lint_src src --lint_threshold 9

For dependencies all you need to do is run

Install from PyPi

pip install watcher-cli

Or from source:

git clone https://github.com/NathanGavenski/python-watcher
cd python-watcher
pip install -e .

Use cases

Although trivial, there are some uses cases that made me create this package:

  • Run pytest when saving a file.
  • Run pylint when making corrections.
  • Run smaller scripts after every modification.

Mostly I was tired off having to tab out from vim just to run pytest/pylint/python on the terminal.

Todo

  • create a proper setup
  • make it executable from command line
  • be able to pass parameters
  • read parameters from yaml file
  • only watch a single file changes
  • run pytest
  • run pylint
    • to run pylint there has to be a folder to run pylint over
    • fail with some threshold
  • Spawn a new process to close if needed (more control over running process)
  • Create documentation
  • Create tests
  • Publish
  • Fix pytest not working on GitHub actions

Project details


Download files

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

Source Distribution

watcher_cli-0.1.0.tar.gz (7.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

watcher_cli-0.1.0-py3-none-any.whl (6.9 kB view details)

Uploaded Python 3

File details

Details for the file watcher_cli-0.1.0.tar.gz.

File metadata

  • Download URL: watcher_cli-0.1.0.tar.gz
  • Upload date:
  • Size: 7.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for watcher_cli-0.1.0.tar.gz
Algorithm Hash digest
SHA256 8ce68e6c61b7853e038152f4bbc27aef2bf05ccf1987f9972fe2bfef2e91f07a
MD5 7dc01e9186281c9c4f40aaa7e8ea6ca5
BLAKE2b-256 9c03aafd1d61d68c1629ad790481a10d2b3f83a192015c55a627e613411e67a2

See more details on using hashes here.

File details

Details for the file watcher_cli-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: watcher_cli-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 6.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for watcher_cli-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5cc8f5598a7a3e57d07408079d3c97f8b0ec222fdb98a341f894c4edb9891677
MD5 2b4c0b2c4b5cd81381a4be58df00fdf4
BLAKE2b-256 4f48d9c11172d40ee218efdec08d49d8b267c735e09bae1bb8b99fb9439001c2

See more details on using hashes here.

Supported by

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