Willem's Fizzy Logic

Running Django Tests in VSCode

Running Django Tests in VSCode

Because I’ve been using Copilot Workspace a lot lately, I’m also using Visual Studio Code a lot more. I like the test explorer, which allows me to run my unit tests in the context of Visual Studio Code.

Most of the test frameworks are supported, but Django seemed to be challenging for Visual Studio Code. Lucky for me, they fixed the issues in 1.93! Or say they mention in the release notes because it still wouldn’t work for me.

The documentation for this new feature is pretty short, and it took me some time to figure out exactly why it didn’t work. After some trial and error, I finally figured out a smooth workflow for running Django tests in VSCode. I’m sharing this guide to help other developers facing similar challenges.

In this post, we’ll walk through the process of configuring VSCode for Django testing and explore how to run tests from your test source files and the test explorer. Let’s start by setting up the necessary configuration.

Configuring VSCode

To set up testing for Django, you’ll need to enable the unittest framework in the Python extension in VSCode.

First, add a settings.json file to your project’s .vscode folder to enable the correct settings for running unit-tests in vscode. Add the following content to the file:

{
    "python.testing.unittestEnabled": true,
    "python.testing.pytestEnabled": false,
    "python.testing.unittestArgs": [
        "-p",
        "*test*.py"
    ]
}

I’ve configured the following settings:

It’s necessary to set the command line arguments for unittest in the settings file because the default settings include a verbosity setting that doesn’t work for Django. The default arguments also specify a source folder we don’t use for Django.

Next, you’ll need a .env file in the root of the project:

MANAGE_PY_PATH=manage.py

The MANAGE_PY_PATH environment variable resolves the manage.py file. The test explorer runs this file to discover the test cases.

Once you’ve configured VSCode correctly, you can start running tests.

Running tests

There are two methods to run tests. First, you can use the test explorer to run all tests or select tests for the project. Second, you can run tests from a test source file.

If you’re unfamiliar with the test explorer, you can find it under the erlenmeyer flask icon. When you select it, VSCode shows a panel like this:

Test explorer window showing the django tests

You’ll need to open a test file to run tests from source files. You’ll see a code lens above test cases to run or debug a test.

Test case with the test run button in the left margin

Running tests in VSCode for Django is now a lot easier. Thanks to the bug fixes done by the community, you can now use the test explorer or run tests directly from the test source file you’re working on.

These features significantly streamline the testing process, making it easier to maintain high code quality, and catch issues early in the development cycle.

Summary

This guide covers the essential steps to set up and run Django tests in Visual Studio Code. We configured the settings.json file to enable unittest support and properly discover Django tests. Then, we explored two convenient ways to run tests: using the Test Explorer and running them directly from the source files.

Having everything in a single window makes my life as a developer a lot easier, and I hope this helps people out there get more out of their VSCode experience for Django.

About

Willem Meints is a Chief AI Architect at Aigency/Info Support, bringing a wealth of experience in artificial intelligence and software development. As a Microsoft AI Most Valuable Professional (MVP), he has been recognized for his significant contributions to the AI community.

In addition to his professional work, Willem is an author dedicated to advancing the field of AI. His latest work focuses on effective applications of large language models, providing valuable guidance for professionals and enthusiasts alike.

Willem is a fan of good BBQ, reflecting his appreciation for craftsmanship both in and out of the digital realm.

Contact