Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/santiagobasulto/debug-inspector-panel

A django-debug-toolbar panel to get information about certain variables.
https://github.com/santiagobasulto/debug-inspector-panel

Last synced: 3 months ago
JSON representation

A django-debug-toolbar panel to get information about certain variables.

Awesome Lists containing this project

README

        

# This project has been abandoned. There's an updated version by @hgezim here: https://github.com/hgezim/debug-inspector-panel

Inspector Panel
===============

> So long as I can put `print` statements in the code, and can read it thoroughly, I can usually find the bugs.

*Joshua Bloch*, about his techniques for debugging programs (extracted from [Coders at work](http://goo.gl/WI0RU))

Inspector panel is intended to retrieve information about variables when developing Django applications.

The panel must be used with [django-debug-toolbar](https://github.com/django-debug-toolbar/django-debug-toolbar).

### Motivation

Have you found yourself doing this all the time?:

def my_view(request):
my_var = some_third_party_function()
print my_var
print type(my_var)
#...

Well, I used to do that a lot. So, I decided to write this simple panel.

The idea is to use just one function `debug` and get lots of information. Here's an example of a [real Django App](https://github.com/santiagobasulto/guide-to-testing-in-django):

from inspector_panel.panels.inspector import debug

def index(request):
latest_poll_list = Poll.published.all().order_by('-pub_date')[:5]
debug(latest_poll_list) # Just add this line
return render_to_response('polls/index.html', {'latest_poll_list': latest_poll_list})

You get first some information in the Debug Toolbar:

![Debug Toolbar panel](http://i.imgur.com/Wv9rV.png)

And you can optionally get the same info in the console:

![Console debug](http://i.imgur.com/z4Ybe.png)

### Installation

$ pip install git+git://github.com/santiagobasulto/debug-inspector-panel

Add the panel to the `DEBUG_TOOLBAR_PANELS` settings variable:

DEBUG_TOOLBAR_PANELS = (
...
'inspector_panel.panels.inspector.InspectorPanel',
...
)

Add `inspector_panel` to your `INSTALLED_APPS`

INSTALLED_APPS = (
# ... More Apps ... #
'debug_toolbar',
'inspector_panel'
)

### Use

Just import the debug function:

from inspector_panel import debug

and use it to debug whatever you want:

debug([1, 2, 3])
debug(Poll)
debug(Poll.objects.all())

def my_function():
print "Hello World"

debug(my_function)

Optionally you can disable console logging:

debug([1, 2, 3], console=False)

### Important!

This panel is NOT a replacement for other more complete tools as [python logging](http://docs.python.org/library/logging.html) and [pdb](http://docs.python.org/library/pdb).

### License

See LICENSE on project root.