pytest plugin for testing Revit API code via RevitDevTool Named Pipe bridge
Project description
RevitDevTool.PyTest
pytest plugin for testing Revit API code via RevitDevTool Named Pipe bridge. Tests run inside a live Revit process — write standard pytest, execute remotely.
Installation
pip install revitdevtool_pytest
Dependencies
| Package | Version |
|---|---|
| Python | >= 3.10 |
| pytest | >= 9.0 |
| pywin32 | >= 311 |
Requirements
- Windows (Named Pipes)
- Revit with RevitDevTool add-in installed and loaded
Project Setup
Recommended: scaffold your project with uv or pixi:
# uv
uv init my-revit-tests
cd my-revit-tests
uv add revitdevtool_pytest
# pixi (uses pyproject.toml as manifest)
pixi init --format pyproject my-revit-tests
cd my-revit-tests
pixi add --pypi revitdevtool_pytest
Configuration
Add plugin settings to [tool.pytest.ini_options] in your pyproject.toml:
[tool.pytest.ini_options]
revit_version = "2025"
revit_launch = false
revit_launch_timeout = "180"
| Option | Type | Default | Description |
|---|---|---|---|
revit_version |
string | — | Revit version year (e.g. "2025"). Required when revit_launch = true. |
revit_launch |
bool | false |
Force-launch a new Revit instance (skip reusing existing free instances). |
revit_timeout |
string | "60" |
Per-test execution timeout in seconds. |
revit_launch_timeout |
string | "120" |
Seconds to wait for Revit to start. |
revit_pipe |
string | — | Explicit pipe name (bypasses auto-discovery). |
CLI flags override INI settings:
pytest --revit-launch --revit-version=2025 -v
Connection Behavior
- Default (
revit_launch = false): plugin auto-discovers a running Revit instance matchingrevit_versionvia Named Pipe scan. If none found, exits with error. - Force launch (
revit_launch = true): always spawns a new Revit process, waits for its pipe to appear, then connects. Existing instances are ignored.
Print Output
Captured print() output from tests running inside Revit is automatically shown in the terminal for passing tests (equivalent to -rP). No extra flags needed.
Usage
Fixtures
Define fixtures in conftest.py that provide Revit API objects:
import pytest
@pytest.fixture(scope="session")
def revit_uiapp():
return __revit__ # UIApplication injected by RevitDevTool
@pytest.fixture(scope="session")
def revit_app(revit_uiapp):
return revit_uiapp.Application
@pytest.fixture(scope="session")
def revit_doc(revit_uiapp):
return revit_uiapp.ActiveUIDocument.Document
Writing Tests
def test_active_view(revit_doc):
view = revit_doc.ActiveView
print(f"Active View: {view.Name}")
assert view.Name is not None
def test_revit_version(revit_app):
assert "2025" in revit_app.VersionName
PEP 723 Dependencies
Declare test-suite dependencies in conftest.py using PEP 723 metadata. RevitDevTool auto-installs them before test execution:
# /// script
# dependencies = [
# "numpy>=2.0",
# "polars>=1.0",
# ]
# ///
Running Tests
# With pyproject.toml configured:
pytest
# Override version for a single run:
pytest --revit-version=2026 -v
# Using uv or pixi:
uv run pytest
pixi run pytest
How It Works
- pytest discovers and collects tests locally
- Plugin intercepts
pytest_runtestloop, connects to Revit via Named Pipe - Test nodeids are sent to Revit's
PytestRunner.py(embedded in RevitDevTool) - Tests execute inside Revit's Python.NET environment with full API access
- Results (pass/fail/skip, stdout, stderr, tracebacks) are returned via pipe
- Plugin maps results back to standard pytest reports
IDE Integration
VS Code / Cursor
{
"python.testing.pytestEnabled": true,
"python.testing.pytestArgs": ["tests"]
}
PyCharm
Enable pytest as the test runner. Plugin auto-detects IDE adapters and disables streaming to avoid duplicate results in the test tree.
License
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file revitdevtool_pytest-0.2.0.tar.gz.
File metadata
- Download URL: revitdevtool_pytest-0.2.0.tar.gz
- Upload date:
- Size: 56.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9e2751455775b135fb724bdb7dda8dfd4726a71bf248715fe254a0d80aedaa51
|
|
| MD5 |
4365e19ac9168b81e1449037851c7892
|
|
| BLAKE2b-256 |
748e79b890b18432d3430e4e8c966ad27e27aab0a1a575ccd3b016acf6a74d9b
|
Provenance
The following attestation bundles were made for revitdevtool_pytest-0.2.0.tar.gz:
Publisher:
publish.yml on trgiangv/RevitDevTool.PyTest
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
revitdevtool_pytest-0.2.0.tar.gz -
Subject digest:
9e2751455775b135fb724bdb7dda8dfd4726a71bf248715fe254a0d80aedaa51 - Sigstore transparency entry: 1676195338
- Sigstore integration time:
-
Permalink:
trgiangv/RevitDevTool.PyTest@b9f2daa0a48cd18933aca0ac376fd6c8e1d07ce7 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/trgiangv
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@b9f2daa0a48cd18933aca0ac376fd6c8e1d07ce7 -
Trigger Event:
release
-
Statement type:
File details
Details for the file revitdevtool_pytest-0.2.0-py3-none-any.whl.
File metadata
- Download URL: revitdevtool_pytest-0.2.0-py3-none-any.whl
- Upload date:
- Size: 24.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
36bbd5b8fdecdf4238471d51f4a6aa288a65ad13516ab7e3db8f5a3ec892a740
|
|
| MD5 |
f521340c04945c80338fdb7e3a406d03
|
|
| BLAKE2b-256 |
d22019dce0bac235068902485a880fdb17a519f0ba41f1eff98a1d92bd8534ad
|
Provenance
The following attestation bundles were made for revitdevtool_pytest-0.2.0-py3-none-any.whl:
Publisher:
publish.yml on trgiangv/RevitDevTool.PyTest
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
revitdevtool_pytest-0.2.0-py3-none-any.whl -
Subject digest:
36bbd5b8fdecdf4238471d51f4a6aa288a65ad13516ab7e3db8f5a3ec892a740 - Sigstore transparency entry: 1676195411
- Sigstore integration time:
-
Permalink:
trgiangv/RevitDevTool.PyTest@b9f2daa0a48cd18933aca0ac376fd6c8e1d07ce7 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/trgiangv
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@b9f2daa0a48cd18933aca0ac376fd6c8e1d07ce7 -
Trigger Event:
release
-
Statement type: