Skip to main content

Package configuration example using bleeding edge toolset.

Project description

modernapp

This package allows to quickly initialise new Python package using bleeding edge tools like linters, just run:

  • pip install modernapp
  • modernapp <your-package-name> # or $ mp <your-package-name>

Now you are able to:

  • cd <your-package-name>
  • make check # To run tests and linters
  • make publish # To publish your new package to PyPi.org to make it accessable to everyone

Add Git remote repository (first create this project on Gitlab) to be able to push changes:

  • git remote add origin git@gitlab.com:<your-username>/<your-package-name>.git
  • git push

Development

Commonly used commands for package development:

  • make check - run unit tests and linters.
  • make fix - format code and fix detected fixable issues.
  • make publish - publishes current package version to pypi.org.
  • make compile - bump and freeze dependency versions in requirements*.txt files
  • make sync - upgrade installed dependencies in Virtual Environment (executed after make compile)

Toolset

This package uses these cutting edge tools:

  • ruff - for linting and code formatting
  • mypy - for type checking
  • pip-audit - for known vulnerability detection in dependencies
  • deadcode - for unused code detection
  • pytest - for collecting and running unit tests
  • coverage - for code coverage by unit tests
  • hatch - for publishing package to pypi.org
  • uv - for Python virtual environment and dependency management
  • pyproject.toml - configuration file for all tools
  • Makefile - aliases for commonly used command line commands

Feature requests:

  • Newly installed package could have virtualenv initialised.

  • Check if git is available before trying to initialise the repository.

  • remove init Makefile alias and cli.py command python files.

  • make a cli command: this package should be installable. Ideally this flow should work:

    • pip install modernapp
    • modernapp mynewpackage
    • cd mynewpackage && make check && make publish
  • Add pre-commit hooks with all the tools enabled.

  • codspeed.io could be considered for Continuous integration pipeline

  • Provide Python version for modernapp CLI command.

  • Add modernapp abreviation CLI alias not to type so much

  • make compile and make sync does not work when virtual environment is activated

  • enable async test execution by default:

    • "pytest-asyncio", [tool.pytest.ini_options] addopts = "--cov=. --no-cov-on-fail --cov-fail-under=90.0" +asyncio_mode = "auto"
  • Clean up the /main.py file after initialization: that logic is overwhelming.

  • Clean up README and descriptions in pyproject.toml and /init.py.

  • Package should display proper messages when internet connection or git is not available. Now it crashes without internet connection with this Traceback:

Cloning modernapp files to /home/niekas/tools/gitruff
Cloning into '/home/niekas/tools/gitruff'...
fatal: unable to access 'https://github.com/albertas/modernapp/': Could not resolve host: github.com
Traceback (most recent call last):
  File "/home/niekas/venv/bin/modernapp", line 8, in <module>
    sys.exit(main())
             ^^^^^^
  File "/home/niekas/venv/lib/python3.12/site-packages/modernapp/main.py", line 40, in main
    init_new_package(package_name=parsed_args.package_name)
  File "/home/niekas/venv/lib/python3.12/site-packages/modernapp/main.py", line 26, in init_new_package
    pipe = Popen(["make", "init", package_name], stdin=PIPE, stdout=PIPE, cwd=new_package_path)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/lib/python3.12/subprocess.py", line 1026, in __init__
    self._execute_child(args, executable, preexec_fn, close_fds,
  File "/usr/lib/python3.12/subprocess.py", line 1955, in _execute_child
    raise child_exception_type(errno_num, err_msg, err_filename)
FileNotFoundError: [Errno 2] No such file or directory: '/home/niekas/tools/gitruff'
  • --django --fastapi or other options to add some kind of dependencies and initial project stub to get started with those projects easily.
  • Should create package tags during publishing. Each version should a commit tagged in main branch.

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

modernapp-0.0.1.tar.gz (5.2 kB view details)

Uploaded Source

Built Distribution

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

modernapp-0.0.1-py3-none-any.whl (4.3 kB view details)

Uploaded Python 3

File details

Details for the file modernapp-0.0.1.tar.gz.

File metadata

  • Download URL: modernapp-0.0.1.tar.gz
  • Upload date:
  • Size: 5.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.27.2

File hashes

Hashes for modernapp-0.0.1.tar.gz
Algorithm Hash digest
SHA256 55b8cbc3606027a43d992ce7aedd44ab4de6c33ec05e61348acff843d4f9b190
MD5 555ac12d3b39e7b48e8fa1d1471e6536
BLAKE2b-256 7704344545a47dec9cef2d6cf5b714f9b7bb26042d652cd759ae5422d74dba39

See more details on using hashes here.

File details

Details for the file modernapp-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: modernapp-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 4.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.27.2

File hashes

Hashes for modernapp-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e07694546cc0cd335a913e2dddba737e5b37f75d817a7c97179a688e7906498f
MD5 69f4fa2dd06d2b78bacfc274120641b2
BLAKE2b-256 54e4c6430e52693f2256574e39a513e8489c97c21d68f4596cf34d0420525b14

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