Fixing Circular Imports in Python with Protocol

The problem started when I had two classes that needed to talk to each other. Sometimes, classes need to talk to each other in both directions. The following example is made up, but mostly behaves like the original problem. Let’s say I have a Director and an Actor. The Director tells the Actor to do_action(). In order to do the action, the Actor needs to get_data() from the Director. Here’s our director.py: ...

January 23, 2023 · 4 min · Brian

Testing with Python 3.12

Python 3.12.0a2 is out. So now may be a great time to get your projects to start testing against 3.12. Note about alpha releases of Python This is from the same link as above: “During the alpha phase, features may be added up until the start of the beta phase (2023-05-08) and, if necessary, may be modified or deleted up until the release candidate phase (2023-07-31). Please keep in mind that this is a preview release and its use is not recommended for production environments.” ...

December 5, 2022 · 3 min · Brian

Installing Python 3.11 on Mac or Windows

Installing Python from python.org The easiest and most obvious (to me) way to install the latest version of Python on either Mac or Windows is: Go to python.org Hover over the “Downloads” link in the navigation. This will detect if you are on Mac or Windows and present you with a button called “Python 3.11.0” (or whatever the latest version is). Click that button. This downloads an installer. Run the installer. That’s it. Done. ...

October 26, 2022 · 4 min

Talk - Sharing is Caring - pytest fixture edition

Sharing is Caring, pytest fixture edition I gave a talk at PyBay 2022 with the above title. It’s about sharing fixtures. The source code, and the slides, are at github.com/okken/pytest_fixture_sharing.

September 10, 2022 · 1 min · Brian

Current Git CLI workflow

Workflow Most of my interactions with git CLI, especially for quick changes, is: $ git checkout main $ git pull $ git checkout -b okken_something < code changes > $ git commit -a -m 'quick message' $ git push Then the code review and merge happen on the server. Commands Let’s break that down. git checkout main Start at the main branch. git pull Grab any changes from remote repo. git checkout -b okken_something Create and switch to a new branch to start work. git commit -a -m 'quick message' Commit changes. The -a automatically “adds” changed and deleted files, but not untracked files. See commit -a docs. git push Push to the remote repo. Normally this would show an error that the branch name doesn’t exist on the remote. However, I have a config setting that automatically creates a branch on remote. config setting: git config --global push.default current See push.default docs. With Autocorrect Even if I mistype a command, it will work: ...

April 13, 2022 · 2 min · Brian

Lean TDD

Preface Lean TDD is an attempt to reconcile some conflicting aspects of Test Driven Development and Lean Software Development. I’ve mentioned Lean TDD on the podcast a few times and even tried to do a quick outline at the end of episode 162. This post is a more complete outline, or at least a first draft. In audio form The initial version of this post is also available in audio form as Test & Code, episode 180. ...

February 20, 2022 · 17 min · Brian

Beta 9.0 of Python Testing with pytest, 2nd ed, available.

The Beta 9.0 is available for Python Testing with pytest, 2nd edition, as of Feb 9, 2022. With this 9th beta release, copy edit and indexing are complete. Next it goes to layout, then to printing. Amazon has it for pre-order, listing March 22 as availability. I think we should be able to hit that. I’m excited.

February 11, 2022 · 1 min · Brian

Python Packaging Struggle for pytest Plugins

Recently, Pradyun posted a tweet commenting not on the state of Python packaging, but more on the state of the documentation and guidance. Now, at the time, I figured that was the case for people new to packaging, not myself. I’m not really an old timer with packaging, but: I have a few published packages. I’ve used both Flit and setuptools. I’ve interviewed Brett Cannon 3 times on the packaging in episodes of Test & Code. 52: pyproject.toml : the future of Python packaging 119: Editable Python Installs, Packaging Standardization, and pyproject.toml 152: Python Packaging There’s also a pip interview with Stéphane Bidoul: 163: pip install ./local_directory and a couple solo episodes talking about flit: 80: From Python script to Maintainable Package 81: TDD with flit Mostly trying to say that I’ve followed the story enough that I should be able to figure this out for a new package. At least, for a Python only package, which is really all I’ve done in the past. ...

September 22, 2021 · 2 min

Python Testing with pytest, 2nd Edition

2nd edition is now in print and shipping from various booksellers. eBook is available through Pragmatic includes pdf, epub, and mobi (for Kindle) paper editions bookshop.org Amazon Barnes & Noble Waterstones It might be at your local independent bookstore. If not, they could order it for you. Or request it from your library. Why a Second Edition? This section is an excerpt from the Preface, which is available to read as a larger excerpt on the books Pragmatic page. ...

June 14, 2021 · 4 min

Pinning Application Dependencies with pip-tools compile

pip-tools has more functionality than this, but compile alone is quite useful. Start with a loose list of dependencies in requirements.in: typer rich The requirements.in file can have things like >= and such if you have some restrictions on your dependencies. Now install pip-tools: pip install pip-tools Then, in create a requirements.txt file with compile: pip-compile requirements.in or: python -m piptools compile requirements.in The output will be shown on stdout, but also in requirements.txt: ...

June 9, 2021 · 1 min