Skip to content

Small Python library for quick prototyping and code demonstrations

Notifications You must be signed in to change notification settings

slyphix/quickdemo

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

quickdemo

For when unit tests would be too much!

quickdemo is a tiny Python library for code demonstrations and small-scale testing. If your debugging tool of choice is printing to stdout, this might be the right library for you.

quickdemo allows you to decorate any module-level function with an invocation or testing directive:

import quickdemo as qd

@qd.expect([1, 2], [0, 1], 1)
@qd.run([1, 2, 3], 5)
def add_to_list(input_list, number):
    return [x + number for x in input_list]

The snippet above produces the following output:

add_to_list([1, 2, 3], 5) -> [6, 7, 8]
Passed: add_to_list([0, 1], 1)

Check out the showcase*.py files for more examples!

I developed quickdemo for two reasons:

Firstly, when presenting solutions to other people, I always wrote several print statements per function to demonstrate the correctness of the solution. The print statements always added up quickly, making it difficult to discern which output corresponded to which function. Also, changing any function name implied re-writing the invocation code. This was especially tedious when working with Jupyter Notebooks, where you have to take great care to re-run a cell each time something changes.

Secondly, there is an educational programming language called Pyret, which allows writing short unit tests as part of a function definition. I believe this to be a sensible choice when targeting beginners. Unfortunately, Pyret code is neither readable nor particularly fast, so I decided to introduce this feature to Python as a part of quickdemo.

About

Small Python library for quick prototyping and code demonstrations

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages