Skip to main content

Try to import all modules below a given root

Project description

A three-line unit test in your project automatically imports every Python file and module in it, optionally testing for warnings.

Why?

Not every file is covered by unit tests; and unit tests won’t report any new warnings that occur.

import_all is a single-file library with a unit test that automatically imports every Python file and module in your project.

I drop include_all into each new project. It takes seconds, it inevitably catches lots of dumb problems early, and it requires no maintenance.

How to use import_all

Install it with pip install import_all, and use it by adding this tiny file (raw) anywhere in a project - it looks like this:

import import_all


class ImportAllTest(import_all.ImportAllTest):
    pass

and most of the time that’s all you need.

Overriding properties

ImportAllTest has eight properties that can be overridden.

  • ALL_SUBDIRECTORIES: Whether to search all subdirectories

  • CATCH_EXCEPTIONS: Catch all exceptions and report at the end

  • EXCLUDE: Which modules to exclude

  • EXPECTED_TO_FAIL: Which modules are expected to fail

  • INCLUDE: Which modules to exclude

  • PROJECT_PATHS: Roots for searching subdirectories

  • SKIP_PREFIXES: Skip subdirectories that start with these prefixes

  • WARNINGS_ACTION: What to do on warnings

Full documentation for each property is here.

To permanently override a test property, set it in the derived class, like this:

import import_all


class ImportAllTest(import_all.ImportAllTest):
    WARNINGS_ACTION = 'error'

To temporarily override a test property, set an environment variable before runnning the test, like this:

$ _IMPORT_ALL_WARNINGS_ACTION=error pytest

Using import_all.py as a standalone program

The file import_all.py is executable and is installed in the path by pip. You can use it on projects that you are evaluating or debugging like this:

$ import_all.py [directory ..directory]

where if no directory is specified it uses the current directory.

You can use environment variables to set properties as above and for convenience there are also command line flags for each property, so you can write:

$ import_all.py --catch_exceptions --all_directories --exclude=foo/bar

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

import_all-0.9.5.tar.gz (6.6 kB view details)

Uploaded Source

File details

Details for the file import_all-0.9.5.tar.gz.

File metadata

  • Download URL: import_all-0.9.5.tar.gz
  • Upload date:
  • Size: 6.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Python-urllib/3.5

File hashes

Hashes for import_all-0.9.5.tar.gz
Algorithm Hash digest
SHA256 77ed30b6537ebf59fb3ae3dd4706c9a257670ef3fb05042b482ec5058bd3b868
MD5 24c8dc36f643e25a11ec630c71924e30
BLAKE2b-256 1d4feed24061302cd7671d37a8ad7501389b26646a65d69002dc0f2e080d6c7e

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