Skip to content
/ python-template Public template

Template for Python-based projects within PrivateAIM

License

Notifications You must be signed in to change notification settings

PrivateAIM/python-template

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

PrivateAIM Python Template

This repository serves as a template for Python-based repositories within the PrivateAIM project. It comes preconfigured with tools for testing, building, linting and formatting your Python code.

Prerequisites

Poetry is the Python package manager of choice. Follow the installation instructions and make sure that Poetry is working on your machine.

Using PyCharm as the primary IDE is not required, but heavily encouraged. The instructions in this document are mostly tailored towards PyCharm.

Project setup

In GitHub, click on "Use this template", then "Create in a new repository". Enter the name of your repository and click on "Create repository".

With PyCharm

Go to Git > Clone…. Enter the URL to the repository you just created and the directory you'd like to clone it to. Click on Clone. Confirm that you trust the project. PyCharm will then automatically set up a new Poetry environment with all configured dependencies for your repository. Open a terminal within PyCharm, then run pre-commit install --install-hooks -t pre-commit -t commit-msg to install the pre-commit hooks.

Manually

Clone the repository. Open a terminal and navigate to the repository. Run poetry install. This will create a new Poetry environment and install all dependencies. Run poetry shell to drop into the Poetry environment. Finally, run pre-commit install --install-hooks -t pre-commit -t commit-msg to install the pre-commit hooks.

Project structure

The project directory is the location to put all your Python code. Rename it to the actual name of your code project and modify the packages property in pyproject.toml accordingly.

The tests directory is where all your tests go. Running pytest on the command line will automatically pick up any tests inside that directory and execute them. Refer to the pytest documentation for more information on how to write your tests and get the most out of pytest.

The Poetry environment comes with these pre-installed dependencies:

Furthermore, thanks to pre-commit, the following hooks are installed by default:

  • out-of-the-box pre-commit hooks
    • check-added-large-files: prevents large files from being committed
    • check-toml: checks TOML files for syntax errors
    • check-yaml: checks YAML files for syntax errors
    • end-of-file-fixer: checks for single newlines at the end of a file
    • trailing-whitespace: removes trailing whitespaces from files
  • ruff hook: lints and auto-formats files using ruff
  • conventional commits hook: checks commit messages against the conventional commits spec

If any of the pre-commit hooks fail, you will have to resolve all conflicts that have been pointed out, re-add all your previously staged files and commit again.

Linting and auto-formatting

Ruff is the Python linter and formatter of choice. It is highly recommended to install the Ruff plugin from the JetBrains Marketplace. Once installed, go to File > Settings…, then navigate to Tools > Ruff. Make sure that "Run ruff when Reformat Code" is checked and that Project Specific > ruff executable points to the Ruff executable within your virtual environment. Next, go to Tools > Actions on Save and check "Reformat code". This will automatically run Ruff on a file every time it is saved.

About

Template for Python-based projects within PrivateAIM

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Languages