Skip to main content

Python API library for WATS - manufacturing test data management

Project description

PyWATS

PyPI version Python 3.10+ License: MIT

A Python library for interacting with the WATS test data management platform API.

⚠️ Beta Release: This is a beta version. The API is stabilizing but may have changes before 1.0.

Requirements

  • Python 3.10 or later
  • WATS Server 2025.3.9.824 or later

Features

  • PyWATS Library - Core API library for WATS integration

    • Async-First Architecture - Built on httpx with native async support
    • Sync Compatibility - Full sync API via thin wrappers (no code changes needed)
    • 9 Domain Services: Product, Asset, Report, Production, Analytics, Software, RootCause, Process, SCIM
    • 170+ API Endpoints - Centralized route management
    • Report creation and submission with comprehensive step types
    • OData filtering and pagination support
    • Structured logging with configurable verbosity
    • Performance Optimizations
      • Enhanced TTL Caching - Automatic expiration with background cleanup (100x faster cache hits)
      • Connection Pooling - HTTP/2 multiplexing with 100 max connections (3-5x faster bulk operations)
      • Request Batching - Time-window and size-based batching utilities (95% reduction in server calls)
      • MessagePack Serialization - 50% smaller payloads, 3x faster serialization (optional)
    • Offline Queue - File-based queue for reliable report submission when offline
      • WSJF format as standard
      • Format conversion from WSXF, WSTF, ATML
      • Automatic retry with configurable max attempts
      • Metadata tracking and statistics
  • PyWATS Client - Desktop and headless client application

    • Connection management with multi-instance support
    • Converter configuration and management
    • Report queue management
    • GUI Mode: Qt-based desktop application (Windows, macOS, Linux)
    • Service Mode: Background Windows service or Unix daemon
    • Headless Mode: CLI and HTTP API for servers, Raspberry Pi, embedded systems

Installation

From PyPI (Recommended)

# Install core API library only
pip install pywats-api

# Install with GUI client (requires Qt)
pip install pywats-api[client]

# Install headless client (no Qt - for Raspberry Pi, servers)
pip install pywats-api[client-headless]

From Source (Development)

# Clone the repository
git clone https://github.com/olreppe/pyWATS.git
cd pyWATS

# Create virtual environment
python -m venv .venv
.venv\Scripts\activate  # Windows
source .venv/bin/activate  # Linux/Mac

# Install in development mode
pip install -e ".[dev]"

Configuration

Create a configuration with your WATS credentials:

from pywats import pyWATS

api = pyWATS(
    base_url="https://your-server.wats.com",
    token="your_base64_encoded_token"
)

Or use environment variables:

WATS_BASE_URL=https://your-server.wats.com
WATS_AUTH_TOKEN=your_base64_encoded_token

Quick Start

from pywats import pyWATS, WATSFilter

# Initialize API
api = pyWATS(
    base_url="https://your-server.wats.com",
    token="your_token"
)

# Test connection
if api.test_connection():
    print(f"Connected! Server version: {api.get_version()}")

# Get products (sync)
products = api.product.get_products()
for p in products:
    print(f"{p.part_number}: {p.name}")

Async Quick Start

For high-performance applications with concurrent requests:

import asyncio
from pywats import AsyncWATS

async def main():
    async with AsyncWATS(
        base_url="https://your-server.wats.com",
        token="your_token"
    ) as api:
        # Concurrent requests - much faster!
        products, assets, version = await asyncio.gather(
            api.product.get_products(),
            api.asset.get_assets(top=10),
            api.analytics.get_version()
        )
        print(f"Fetched {len(products)} products, {len(assets)} assets")

asyncio.run(main())

Performance Optimization Example

Use caching, batching, and connection pooling for high-performance applications:

import asyncio
from pywats import AsyncWATS
from pywats.core.batching import batch_map

async def main():
    async with AsyncWATS(
        base_url="https://your-server.wats.com",
        token="your_token"
    ) as api:
        # Built-in caching for static data (95% reduction in server calls)
        processes = await api.process.get_processes()  # First call - from server
        processes = await api.process.get_processes()  # Second call - from cache (100x faster!)
        
        # Check cache statistics
        stats = api.process.cache_stats
        print(f"Cache hit rate: {stats['hit_rate']:.1%}")
        
        # Batch processing with automatic concurrency control
        serial_numbers = [f"SN-{i:05d}" for i in range(1000)]
        
        async def fetch_unit(sn: str):
            return await api.production.get_unit(sn, "WIDGET-001")
        
        # Process 1000 units in batches (5-10x faster than sequential)
        units = await batch_map(
            items=serial_numbers,
            func=fetch_unit,
            batch_size=50,
            max_concurrent=10
        )
        print(f"Processed {len(units)} units")

asyncio.run(main())

See PERFORMANCE_OPTIMIZATIONS.md for complete guide.

Query Reports

# Query recent reports (OData filter)
headers = api.report.query_uut_headers(
    odata_filter="partNumber eq 'WIDGET-001'",
    top=10
)

# Or use helper methods
headers = api.report.get_headers_by_serial("SN-12345")
headers = api.report.get_todays_headers()

Enable Debug Logging

from pywats import pyWATS, enable_debug_logging

# Quick debug mode - shows all library operations
enable_debug_logging()

# Or configure logging your way
import logging
logging.basicConfig(level=logging.INFO)
logging.getLogger('pywats').setLevel(logging.DEBUG)

# Now use the API with detailed logging
api = pyWATS(base_url="...", token="...")

See LOGGING_STRATEGY.md for comprehensive logging documentation.

Running the GUI Client

Important: The GUI is for configuration only. You must run the service first:

# Start the background service (runs 24/7)
python -m pywats_client service --instance-id default

# Then launch GUI for configuration (in a separate terminal)
python -m pywats_client gui --instance-id default

Or simply run:

# Default behavior: starts service
python -m pywats_client

# Then launch GUI when needed
python -m pywats_client gui

Service Installation (Production)

For production deployments, install pyWATS as a system service that auto-starts on boot:

Windows:

# Install as Windows Service (requires admin)
python -m pywats_client install-service
net start pyWATS_Service

Linux (systemd):

# Install as systemd service (requires sudo)
sudo python3 -m pywats_client install-service
sudo systemctl start pywats-service

macOS:

# Install as Launch Daemon (requires sudo)
sudo python3 -m pywats_client install-service

# Or as user-level Launch Agent (no sudo)
python3 -m pywats_client install-service --user-agent

See platform-specific guides:

GUI Configuration

The GUI supports modular tab configuration and logging control:

  • Tab Visibility: Show/hide tabs (Software, SN Handler, etc.) based on your needs
  • Logging Integration: Automatic PyWATS library logging when debug mode is enabled
  • Multiple Instances: Run multiple client instances with separate configurations
  • Service Discovery: Automatically discovers and connects to running service instances

See GUI Configuration Guide for detailed setup instructions.

Running Headless (Raspberry Pi, Servers)

For systems without display or Qt support:

# Initialize configuration
pywats-client config init

# Test connection
pywats-client test-connection

# Run service in foreground
python -m pywats_client service

# Run with HTTP control API
python -m pywats_client service --api --api-port 8765

# Install as system service (auto-start on boot)
sudo python3 -m pywats_client install-service

CLI Commands

pywats-client config show          # Show configuration
pywats-client config set key value # Set config value
pywats-client status               # Show service status
pywats-client converters list      # List converters

HTTP Control API

When running with --api, manage the service remotely:

curl http://localhost:8765/status    # Get status
curl http://localhost:8765/config    # Get configuration
curl -X POST http://localhost:8765/restart  # Restart services

See Headless Operation Guide for complete documentation.

Project Structure

pyWATS/
├── src/
│   ├── pywats/              # Core library
│   │   ├── domains/         # Domain services (async + sync wrappers)
│   │   │   ├── analytics/   # Statistics, yield, Unit Flow
│   │   │   ├── asset/       # Equipment tracking, calibration
│   │   │   ├── process/     # Operation types, caching
│   │   │   ├── product/     # Products, revisions, BOMs
│   │   │   ├── production/  # Serial numbers, unit lifecycle
│   │   │   ├── report/      # Test reports, measurements
│   │   │   ├── rootcause/   # Issue tracking, defects
│   │   │   ├── scim/        # User provisioning
│   │   │   └── software/    # Package distribution
│   │   ├── core/            # HTTP client, routes, sync_runner
│   │   ├── models/          # Report models (UUT/UUR)
│   │   ├── async_wats.py    # AsyncWATS main class
│   │   └── sync_wats.py     # SyncWATS wrapper (pyWATS alias)
│   └── pywats_client/       # Client application
│       ├── core/            # Core client functionality
│       ├── gui/             # Qt GUI components (optional)
│       ├── control/         # Headless control (CLI, HTTP API)
│       └── services/        # Background services
├── converters/              # User converter plugins
├── docs/                    # Documentation
├── examples/                # Usage examples by domain
└── pyproject.toml           # Project configuration

Documentation

Official Documentation

Complete guides shipped with the package:

Domain API Reference

Client Documentation

Additional Resources

Documentation available in the GitHub repository (not shipped with package):

Testing

# Run all tests
pytest

# Run with coverage
pytest --cov=src --cov-report=html

Contributing

This project is maintained by Virinco AS.

For Maintainers: Releasing a New Beta Version

There is only ONE command to release:

.\scripts\bump.ps1

See RELEASE.md for complete details. Never manually edit versions or create tags.

License

MIT License - see LICENSE for details.

Links

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

pywats_api-0.1.0b37.tar.gz (609.1 kB view details)

Uploaded Source

Built Distribution

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

pywats_api-0.1.0b37-py3-none-any.whl (623.8 kB view details)

Uploaded Python 3

File details

Details for the file pywats_api-0.1.0b37.tar.gz.

File metadata

  • Download URL: pywats_api-0.1.0b37.tar.gz
  • Upload date:
  • Size: 609.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pywats_api-0.1.0b37.tar.gz
Algorithm Hash digest
SHA256 f0dcd10d255800a8a9f483ff2c4414c6df030dd4e4feb05ef5f2df2f8a003be7
MD5 4cae74d606e449d8908d76a9d1eb7c2a
BLAKE2b-256 7b6b68cb0915e90852799af3392c61e02e6b66123cdd6448e390b1e8877c47e4

See more details on using hashes here.

Provenance

The following attestation bundles were made for pywats_api-0.1.0b37.tar.gz:

Publisher: publish.yml on olreppe/pyWATS

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pywats_api-0.1.0b37-py3-none-any.whl.

File metadata

  • Download URL: pywats_api-0.1.0b37-py3-none-any.whl
  • Upload date:
  • Size: 623.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pywats_api-0.1.0b37-py3-none-any.whl
Algorithm Hash digest
SHA256 9e384d4d7522a75185a36c012d0a703273d88f6f7b290c5a4d05de2181130f48
MD5 3157909e4e82d3d3fd419f5f7a747759
BLAKE2b-256 40ebde00042e4728bbb2c5abdc1f377d4827937713059cb97401062f9bbda6b3

See more details on using hashes here.

Provenance

The following attestation bundles were made for pywats_api-0.1.0b37-py3-none-any.whl:

Publisher: publish.yml on olreppe/pyWATS

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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