Collection of useful checks for Django Checks Framework
Project description
Django Extra Checks
Useful checks for Django Checks Frameworks
Settings
To enable some check define EXTRA_CHECKS
setting with a dict of checks and its settings:
EXTRA_CHECKS = {
"checks": [
# require non empty `upload_to` argument.
"field-file-upload-to",
# use dict form if check need configuration
# eg. all models must have fk to Site model
{"id": "model-attribute", "attrs": ["site"]},
# require `db_table` for all models, increase level to CRITICAL
{"id": "model-meta-attribute", "attrs": ["db_table"], "level": "CRITICAL"},
]
}
By default only your project apps are checked but you can use
include_apps
option to specify apps to check (including third party apps):
EXTRA_CHECKS = {
# use same names as in INSTALLED_APPS
"include_apps": ["django.contrib.sites", "my_app"],
...
}
Ignoring check problems
To ignore all warnings on some object you can use ignore_checks
decorator:
from extra_checks import ignore_checks, CheckID
@ignore_checks("model-attribute", "X011", CheckID.X050)
class MyModel(models.Model):
image = models.ImageField()
Another way is to specify type of the object that need to be ignored in ignore_types
option:
EXTRA_CHECKS = {
"check": [
{
"id": "field-verbose-name-gettext",
# make this check skip wagtail's StreamField
"ignore_types": ["wagtail.core.fields.StreamField"],
}
]
}
Checks
Models
- extra-checks-config - settings.EXTRA_CHECKS is valid config for django-extra-checks (always enabled).
- model-attribute - Each Model in the project must have all attributes from
attrs
setting specified. - model-meta-attribute - Each Model.Meta in the project must have all attributes from
attrs
setting specified. - no-unique-together - Use UniqueConstraint with the constraints option instead.
- no-index-together - Use the indexes option instead.
- model-admin - Each model must be registered in admin.
- field-file-upload-to - FileField/ImageField must have non empty
upload_to
argument. - field-verbose-name - All model's fields must have verbose name.
- field-verbose-name-gettext - verbose_name must use gettext.
- field-verbose-name-gettext-case - Words in text wrapped with gettext must be in one case.
- field-help-text-gettext - help_text must use gettext.
- field-text-null - text fields shoudn't use
null=True
. - field-boolean-null - prefer using
BooleanField(null=True)
instead ofNullBooleanField
. - field-null - don't pass
null=False
to model fields (this is django default). - field-foreign-key-index - ForeignKey fields must specify
db_index
explicitly (to apply only to fields in indexes:when: indexes
). - field-default-null - If field nullable (
null=True
), thendefault=None
argument is redundant and should be removed. WARNING Be aware that setting is database dependent, eg. Oracle interprets empty strings as nulls as a result django uses empty string instead of null as default.
DRF Serializers
- drf-model-serializer-extra-kwargs - ModelSerializer's extra_kwargs must not include fields that specified on serializer.
- drf-model-serializer-meta-attribute - Each ModelSerializer.Meta must have all attributes specified in
attrs
, use case.
Development
Install dev deps in virtualenv pip install -e .[dev]
.
Credits
The project was built using ideas and code snippets from:
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
django-extra-checks-0.7.1.tar.gz
(21.9 kB
view hashes)
Built Distribution
Close
Hashes for django-extra-checks-0.7.1.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 357bd39511c3df1ea86cbc9347bffcf0e23e6cd61f73f8c0ec9b2c191e4a1f91 |
|
MD5 | 617b6a50429bd1b102b61f3a80770dc4 |
|
BLAKE2b-256 | 7783b380a9107086d8b31a31c4d774bea420493079cfc36ffa1d9795852524e4 |
Close
Hashes for django_extra_checks-0.7.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 760c7953fe4e6d27992eeeed570b6a1c2a2aaa0c4f5a5366566b95ad72ecbdf5 |
|
MD5 | 2ba6ab5289c1b35e16699bdebb28e841 |
|
BLAKE2b-256 | 3ebfd3332cedf3ace35ba80c7539e909df5306eedf6012112bb70e6e639ba58f |