Skip to main content

Community object-oriented Python 3 bindings for the National Instruments TestStand™ COM API

Project description

py-teststand

Community object-oriented Python 3 bindings for the National Instruments TestStand™ COM API.

⚠️ Early Implementation Stage — Consider as experimental. Interfaces may change between releases without prior notice.

Overview

py-teststand exposes the TestStand™ COM API as an object-oriented Python interface via pywin32.

Name

The package is named py-teststand (with a dash) to avoid naming collision with the pytest testing framework and for easier relation to TestStand™ test executive.

PyPI version Python versions License: MIT Build Status


Project Status

py-teststand is a hobby project maintained on a best-effort basis and is not under active full-time development (for first release). There are no guaranteed scheduled release cadences or support (but feel free to contact).

That said:

  • Bug reports and feature requests are welcome via GitHub Issues.
  • Pull requests are welcomed and reviewed. If you are working with the TestStand™ COM API and have improvements, fixes, or additional bindings, contributions are encouraged.

If you encounter a missing TestStand™ binding, an incorrect type annotation, or unexpected TestStand™ COM dispatch behavior, opening an issue with a reproducible case is the most effective way to get it addressed, I will try to investigate and find solution as fast as possible.


Implementation Notes

Type Library Generation

Python class stubs and interface definitions are generated from the TestStand™ COM Type Library (.tlb) using pywin32's makepy utility. The generated output is cached as a pywin32 dispatch cache module and checked into the repository, meaning a live TestStand™ installation is not required at import time — only at runtime when TestStand™ COM objects are actually instantiated.

The generation process follows this pipeline:

  1. TLB introspectionmakepy reads the registered TestStand™ COM type library via the Windows registry and reflects all exposed interfaces, CoClass definitions, enumerations, and dispatch IDs.
  2. Cache dump — The reflected TestStand™ metadata is serialized into a Python module stored under win32com/gen_py/, keyed by the TestStand™ type library GUID and version. This cache is committed to the repository so users do not need to run makepy themselves.
  3. Wrapper generationpy-teststand classes are authored on top of the cached TestStand™ dispatch definitions, adding Python type annotations and translating raw COM VARIANT and IDispatch returns into typed Python objects where applicable.

This approach means the bindings target a specific version of the TestStand™ type library. Compatibility across TestStand™ engine versions is maintained by keeping the wrapper surface aligned with stable, long-lived TestStand™ COM interfaces present across the supported version range.


Design Goals

  • Python 3.8 minimum — Python 3.8 (uv supports / distributes even 3.8.20) is the last CPython release with official Windows 7 support. Many manufacturing and test environments run long-lifecycle OS images on air-gapped station hardware where upgrading the OS is not feasible on short timescales. Maintaining a 3.8-compatible codebase allows incremental adoption of Python-based automation on existing TestStand™ station hardware without requiring a platform migration first.
  • TestStand™ station options as code — The TestStand™ Station Options object model is fully exposed, allowing TestStand™ search directories, model paths, station globals, and result processing configuration to be read and written programmatically. This makes TestStand™ station configuration reproducible and suitable for provisioners such as Ansible, Chef, or custom deployment scripts — replacing manual point-and-click TestStand™ setup with version-controlled configuration.
  • No TestStand™ documentation mirroring — The library does not duplicate or paraphrase the official TestStand™ API reference in its docstrings, as eproducing NI's documentation would introduce a secondary source that diverges from the official TestStand™ spec as new versions evolve, creating a risk of misinformation, therefore for authoritative descriptions of TestStand™ COM objects, properties, method parameters, and return value semantics etc. refer directly to the TestStand™ API Reference.

Technical Stack

Tool Purpose
uv Python package and project manager
ty Static type checker for interface validation
ruff Linter and code formatter
pytest Unit and integration test runner
pywin32 Windows COM dispatch layer and TestStand™ TLB introspection

Compatibility

Component Versions
Windows 7 — 11
Python 3.8 — 3.14
TestStand™ 2016 — 2026+

Older TestStand™ engine versions may also work if the underlying TestStand™ COM interfaces have not changed, but they were not explicitly tested.


Features

  • Pythonic attribute access — TestStand™ COM properties are accessible via standard Python attribute notation instead of raw Dispatch calls.
  • Type annotations — All public members carry type hints compatible with ty.
  • TestStand™ station options provisioning — Read and write TestStand™ station-level configuration suitable for use in automated deployment pipelines (like test stations install scripts).
  • Minimal binding surface — No behavior is added beyond what the TestStand™ COM layer provides. Edge cases and error conditions follow the TestStand™ COM API contract documented in the official TestStand™ reference. The binding layer is intentionally lightweight and not overcommented, signatures and object hierarchy map directly to the TestStand™ COM API without adding abstraction or reinterpreting behavior (but modules themselves are sorted under domains for easier management).
  • No live TestStand™ installation required at import time — The committed pywin32 dispatch cache allows the library to be imported and partially used (type checking, configuration building) without a TestStand™ installation present.

Installation

pip

pip install py-teststand

uv

uv pip install py-teststand

Popularity Over Time

Star History Chart


Legal

TestStand™ is a registered trademark of National Instruments Corporation. Refer to NI's TestStand™ licensing options for information on required licenses to operate the TestStand™ engine.

py-teststand is an independent community project and is not affiliated with, endorsed by, or maintained by National Instruments or its parent company Emerson. References to the TestStand™ API are made solely for interoperability purposes.

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

py_teststand-0.1.0.tar.gz (152.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

py_teststand-0.1.0-py3-none-any.whl (184.0 kB view details)

Uploaded Python 3

File details

Details for the file py_teststand-0.1.0.tar.gz.

File metadata

  • Download URL: py_teststand-0.1.0.tar.gz
  • Upload date:
  • Size: 152.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.12 {"installer":{"name":"uv","version":"0.11.12","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Arch Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for py_teststand-0.1.0.tar.gz
Algorithm Hash digest
SHA256 e37fba7aa986706a47b2c210b6e74f3466d3aa2013cf05997b4967df629839a1
MD5 458be1b1c707e7f777cd8056cd7c5526
BLAKE2b-256 520f8458d56d92767d9ad4a26744584d9f52c0dbb32fa19c4b06df8d0b2409d9

See more details on using hashes here.

File details

Details for the file py_teststand-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: py_teststand-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 184.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.12 {"installer":{"name":"uv","version":"0.11.12","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Arch Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for py_teststand-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 762ebc3b3ec897e0739af21572a7cf112ca457d149b6f054c045c22cf912653f
MD5 2bcdad4b3ae7480c04a08d3f08b6ddc1
BLAKE2b-256 fd0f6074871d00150a8b511282b86f7de97ffe028836322ccef9a9a59570e2be

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page