Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/edoburu/django-debugtools
A toolbox of small utilities to assist Django development
https://github.com/edoburu/django-debugtools
django
Last synced: 2 days ago
JSON representation
A toolbox of small utilities to assist Django development
- Host: GitHub
- URL: https://github.com/edoburu/django-debugtools
- Owner: edoburu
- License: apache-2.0
- Created: 2012-03-27T12:52:13.000Z (almost 13 years ago)
- Default Branch: master
- Last Pushed: 2021-11-16T21:47:40.000Z (about 3 years ago)
- Last Synced: 2024-12-25T15:08:12.602Z (9 days ago)
- Topics: django
- Language: Python
- Homepage:
- Size: 464 KB
- Stars: 98
- Watchers: 9
- Forks: 12
- Open Issues: 1
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGES.rst
- License: LICENSE
Awesome Lists containing this project
README
Introduction
============The ``debugtools`` module offers some easy to use debugging utilities to assist Django development.
It features:* A template tag to print context.
* A ``XViewMiddleware`` variation to see which *view* and *template* was used to render a page.
* A panel for django-debug-toolbar_ to show which *view* and *template* was used to render a page.
* A jQuery ``debug()`` function.Installation
============First install the module, preferably in a virtual environment. It can be installed from PyPI::
pip install django-debugtools
Or the current folder can be installed::
pip install .
Configuration
-------------Add the module to the installed apps::
INSTALLED_APPS += (
'debugtools',
)As of Django 1.9, either use ``{% load debugtools_tags %}`` or add the following to the settings:
.. code-block:: python
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
# ...
],
'builtins': [ # Add this section
"debugtools.templatetags.debugtools_tags", # Add this line
],
},
},
]Or, when you use a ``local.py`` settings file:
.. code-block:: python
TEMPLATES[0]['OPTIONS']['builtins'] += [
"debugtools.templatetags.debugtools_tags", # enables {% print %}
]Features
--------Print Template Tag
~~~~~~~~~~~~~~~~~~In Django templates, the following code can be used::
{% print variable1 variable2 %}
This will print out the specific variables, in case of ``{% print original %}``:
.. image:: https://github.com/edoburu/django-debugtools/raw/master/docs/images/print-original.png
:width: 959px
:height: 166pxWhen no variables are given (e.g. ``{% print %}``), all context variables are displayed:
.. image:: https://github.com/edoburu/django-debugtools/raw/master/docs/images/template-context.png
:width: 744px
:height: 569pxThe template context variables are printed in a customized ``pprint.pformat`` format, for easy reading.
Note no ``{% load %}`` tag is needed; the ``{% print %}`` function is added to the template builtins for debugging convenience.Print Queries template tag
~~~~~~~~~~~~~~~~~~~~~~~~~~For convenience, there is also a ``{% print_queries %}`` tag,
based on http://djangosnippets.org/snippets/93/For more sophisticated debugging, you may want to use the *django-debug-toolbar* for this job.
Debug Toolbar Panel
~~~~~~~~~~~~~~~~~~~Add the following settings to your django-debug-toolbar_ configuration::
DEBUG_TOOLBAR_PANELS = (
'debug_toolbar.panels.versions.VersionsPanel',
'debug_toolbar.panels.timer.TimerPanel',
'debug_toolbar.panels.settings.SettingsPanel',
'debug_toolbar.panels.headers.HeadersPanel',
'debug_toolbar.panels.request.RequestPanel',
'debug_toolbar.panels.sql.SQLPanel',
'debug_toolbar.panels.staticfiles.StaticFilesPanel',
'debugtools.panels.ViewPanel', # Add this one
'debug_toolbar.panels.templates.TemplatesPanel',
'debug_toolbar.panels.cache.CachePanel',
'debug_toolbar.panels.signals.SignalsPanel',
'debug_toolbar.panels.logging.LoggingPanel',
'debug_toolbar.panels.redirects.RedirectsPanel',
).. image:: https://github.com/edoburu/django-debugtools/raw/master/docs/images/debug-toolbar.png
:width: 887px
:height: 504px|
jQuery debug print
~~~~~~~~~~~~~~~~~~Add the following to the page::
Now you can print the jQuery selector context to the console::
$("#foo").children('li').debug().addClass('bar');
This will print the matched ``
Optionally, a prefix can be included in the ``debug()`` call::
$("#foo").debug("at baz: ").addClass('bar');
X-View Middleware
~~~~~~~~~~~~~~~~~
As alternative to the django-debug-toolbar_ panel, you can also add the ``XViewMiddleware``.
Add the following setting::
INTERNAL_IPS = (
'127.0.0.1',
)
MIDDLEWARE_CLASSES += (
'debugtools.middleware.XViewMiddleware',
)
All requests from the internal IP, or made by the admin user will have a ``X-View`` header and ``X-View-Template`` header.
In the Firebug console, or Chrome web inspector, you can see which view and template handled the current request:
.. image:: https://github.com/edoburu/django-debugtools/raw/master/docs/images/firebug-xview.png
:width: 811px
:height: 41px
The alternative templates are also displayed, in case the view allows the template to be overwritten with a different name.
Print tag examples
------------------
For example, when using the following code::
{% print original %}
{% print inline_admin_formset %}
{% for inline_admin_form in inline_admin_formset %}
{% print inline_admin_form %}
{% print inline_admin_form.form.name %}
{% endfor %}
It prints the context values, which helps to learn a lot about the template context:
.. image:: https://github.com/edoburu/django-debugtools/raw/master/docs/images/print-original.png
:width: 959px
:height: 166px
|
.. image:: https://github.com/edoburu/django-debugtools/raw/master/docs/images/inline_admin_formset.png
:width: 959px
:height: 208px
|
.. image:: https://github.com/edoburu/django-debugtools/raw/master/docs/images/inline_admin_form.png
:width: 959px
:height: 355px
|
.. image:: https://github.com/edoburu/django-debugtools/raw/master/docs/images/adminform.form.name.png
:width: 959px
:height: 352px
This makes it much easier to understand what the code provides to templates.
.. _django-debug-toolbar: https://github.com/django-debug-toolbar/django-debug-toolbar