Skip to main content

Constructor injection for Python

Project description

diapyr

Constructor injection for Python

Overview

  • Automatic wiring between application objects
  • Declare what collaborator types you want in your constructor using an @types decorator, they correspond with params
    • You can decorate a (factory) function in the same way, in which case the return type must also be declared using 'this' kwarg
    • Surround a type in square brackets if you want a list of all matching objects, normally diapyr provides a unique match
  • Add such classes/factories to a DI instance
    • You can also add objects, for example an application config object
  • Request a type from the DI instance and diapyr will attempt to make it for you, along with the rest of the object graph
  • Instances are cached in the DI object
    • On exit from 'with' clause, dispose is called on any created instances that have it

Motivation

  • Manual wiring is messy and tedious especially when an app gets big
  • Constructor injection avoids spaghetti code
  • It's trivial to depend on an object anywhere in the graph as long as you don't create a reference cycle e.g. most objects will depend on the same config instance
    • No need to resort to globals, which come with a big risk of leaking state between unit tests
  • Unit testing is easy when an object only interacts with what was passed into its constructor

Convention

  • When depending on a config object the constructor should first extract what it needs and assign those values to fields
  • Collaborators should also be assigned to fields, and ideally the constructor won't do anything else

Advanced

  • Parameter defaults are honoured, this can be used to depend on module log object in real life and pass in a mock in unit tests
  • Decorating an instance method (without 'this' kwarg) will make it behave as an additional constructor
    • Take advantage of name mangling (start with double underscore e.g. __init) to avoid having to call super
  • Decorating an instance method with 'this' kwarg will make it behave as a factory function
    • Adding a class to DI will implicity add all such methods it has as factories
  • You can play fast and loose with types, diapyr doesn't care whether a factoried object satisfies the declared type

Install

These are generic installation instructions.

To use, permanently

The quickest way to get started is to install the current release from PyPI:

pip3 install --user diapyr

To use, temporarily

If you prefer to keep .local clean, install to a virtualenv:

python3 -m venv venvname
venvname/bin/pip install diapyr
. venvname/bin/activate

To develop

First clone the repo using HTTP or SSH:

git clone https://github.com/combatopera/diapyr.git
git clone git@github.com:combatopera/diapyr.git

Now use pyven's pipify to create a setup.py, which pip can then use to install the project editably:

python3 -m venv pyvenvenv
pyvenvenv/bin/pip install pyven
pyvenvenv/bin/pipify diapyr

python3 -m venv venvname
venvname/bin/pip install -e diapyr
. venvname/bin/activate

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

diapyr-26.tar.gz (20.3 kB view details)

Uploaded Source

Built Distribution

diapyr-26-py2.py3-none-any.whl (23.8 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file diapyr-26.tar.gz.

File metadata

  • Download URL: diapyr-26.tar.gz
  • Upload date:
  • Size: 20.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.9.6 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.10.1 urllib3/1.26.15 tqdm/4.64.1 importlib-metadata/4.8.3 keyring/23.4.1 rfc3986/1.5.0 colorama/0.4.4 CPython/3.6.9

File hashes

Hashes for diapyr-26.tar.gz
Algorithm Hash digest
SHA256 e12b04cc4f363ef70d36e0d2e00e75a170606cf7a975cac6dc4b4fdeb1be591b
MD5 6e5bc3087d7aca8d04394bcfe825bd5c
BLAKE2b-256 3eb8acb4a48ab520633e05bf8bf647ffd51bfe6b14d3b2446a3bb40b3f5ac5e9

See more details on using hashes here.

File details

Details for the file diapyr-26-py2.py3-none-any.whl.

File metadata

  • Download URL: diapyr-26-py2.py3-none-any.whl
  • Upload date:
  • Size: 23.8 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.9.6 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.10.1 urllib3/1.26.15 tqdm/4.64.1 importlib-metadata/4.8.3 keyring/23.4.1 rfc3986/1.5.0 colorama/0.4.4 CPython/3.6.9

File hashes

Hashes for diapyr-26-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 094d584813786342fcd099b59cf6f9c0e677a1d1322dc7f64aec0bc35b466255
MD5 c4447e433b4836ba5879b9d80c9512c1
BLAKE2b-256 5e7bd10536b52edf4d5318d26cdf26ce27750ffcf3ed2bb1d85ddcfcf9d9e8cb

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