p1-insta485-static
Python Debugging Tutorial
This tutorial will explain how to use an enhanced Python debugger called PDB+.
Install
Install pdbp
(AKA PDB+). If you set up a virtual environment, you’ll have to install it again in your virtual environment.
$ pip3 install pdbp
Pitfall: Avoid using pdbpp
(AKA PDB++) as it is no longer maintained.
Run
Create a sample file called pdbtest.py
to debug. This short program will create a directory.
import os
dirname = "tmp/pdbtest/"
os.mkdir(dirname)
print("Created {}".format(dirname))
Run it. You’ll get an error.
$ python3 pdbtest.py
Traceback (most recent call last):
File "pdbtest.py", line 3, in <module>
os.mkdir(dirname)
FileNotFoundError: [Errno 2] No such file or directory: 'tmp/pdbtest/'
Import pdbp
and add the line breakpoint()
to your file.
import os
import pdbp
dirname = "tmp/pdbtest/"
breakpoint()
os.mkdir(dirname)
print("Created {}".format(dirname))
Pitfall: If you forget import pdbp
, you’ll get the boring default PDB.
> /Users/awdeorio/pdbptest.py(3)<module>()
-> breakpoint()
(Pdb)
Run again. The program stops on line with the breakpoint.
$ python3 pdbtest.py
[0] > /Users/awdeorio/pdbtest.py(4)
1 import os
2 import pdbp
3 dirname = "tmp/pdbtest/"
4 -> breakpoint()
5 os.mkdir(dirname)
6 print("Created {}".format(dirname))
(Pdb+) q
Traceback (most recent call last):
... (ignore the error here)
Tab completion
Try tab completion. Type os.m
, followed by the TAB key. You may need to press TAB twice.
$ python3 pdbtest.py
[0] > /Users/awdeorio/pdbtest.py(4)
1 import os
2 import pdbp
3 dirname = "tmp/pdbtest/"
4 breakpoint()
5 -> os.mkdir(dirname)
6 print("Created {}".format(dirname))
(Pdb+) os.m
major makedev makedirs minor mkdir mkfifo mknod
We see that there are two very similar ways to create a directory. That’s our bug! We should have used makedirs()
instead of mkdir()
.
PDB commands
We’ll show you a couple of PDB commands. You might also like this pdb
cheat sheet.
Print a variable name.
$ python3 pdbtest.py
[0] > /Users/awdeorio/pdbtest.py(4)
1 import os
2 import pdbp
3 dirname = "tmp/pdbtest/"
4 breakpoint()
5 -> os.mkdir(dirname)
6 print("Created {}".format(dirname))
(Pdb+) p dirname
'tmp/pdbtest/'
Change a value while the program is running.
(Pdb+) dirname = "hello"
(Pdb+) p dirname
'hello'
Execute the next line of code.
(Pdb+) n
[0] > /Users/awdeorio/pdbtest.py(5)
1 import os
2 import pdbp
3 dirname = "tmp/pdbtest/"
4 breakpoint()
5 os.mkdir(dirname)
6 -> print("Created {}".format(dirname))
Quit.
(Pdb+) q
Traceback (most recent call last):
... (ignore the error here)
Pitfall: If you’re running pdbp
with pytest
, you’ll need to use -s
. Review the pytest
tutorial for more details.
Acknowledgments
Original document written by Andrew DeOrio awdeorio@umich.edu.
This document is licensed under a Creative Commons Attribution-NonCommercial 4.0 License. You’re free to copy and share this document, but not to sell it. You may not share source code provided with this document.