Book Image

Modern Python Cookbook

Book Image

Modern Python Cookbook

Overview of this book

Python is the preferred choice of developers, engineers, data scientists, and hobbyists everywhere. It is a great scripting language that can power your applications and provide great speed, safety, and scalability. By exposing Python as a series of simple recipes, you can gain insight into specific language features in a particular context. Having a tangible context helps make the language or standard library feature easier to understand. This book comes with over 100 recipes on the latest version of Python. The recipes will benefit everyone ranging from beginner to an expert. The book is broken down into 13 chapters that build from simple language concepts to more complex applications of the language. The recipes will touch upon all the necessary Python concepts related to data structures, OOP, functional programming, as well as statistical programming. You will get acquainted with the nuances of Python syntax and how to effectively use the advantages that it offers. You will end the book equipped with the knowledge of testing, web services, and configuration and application integration tips and tricks. The recipes take a problem-solution approach to resolve issues commonly faced by Python programmers across the globe. You will be armed with the knowledge of creating applications with flexible logging, powerful configuration, and command-line options, automated unit tests, and good documentation.
Table of Contents (18 chapters)
Title Page
Credits
About the Author
About the Reviewers
www.PacktPub.com
Preface
Index

Handling dictionaries and sets in doctest examples


We will look at one small aspect of writing a proper test in this recipe. We'll look at testing overall in Chapter 9, Testing. The data structures in this chapter—dict and set—both include some complexity when it comes to writing proper tests.

Since dict keys (and set members) have no order, our test results will have a problem. We need to have a repeatable result, but there's no way to guarantee the order of the collection. This can lead to test results which don't properly match our expectations.

Assume that our test expects the set {"Poe", "E", "Near", "A", "Raven"}. Since there's no defined order to a set, Python can display this set in any order:

>>> {"Poe", "E", "Near", "A", "Raven"}  
{'E', 'Poe', 'Raven', 'Near', 'A'} 

The elements are the same, but the overall line of output from Python isn't the same. The doctest package relies on the literal output from the example being identical to the output produced by Python's REPL...