Skip to main content

TestQL with endpoint detection, OpenAPI, SUMD generation, SUMD parser and HTML report generation

Project description

TestQL โ€” Interface Query Language for Testing

AI Cost Tracking

PyPI Version Python License AI Cost Human Time Model

  • ๐Ÿค– LLM usage: $3.3000 (22 commits)
  • ๐Ÿ‘ค Human dev: ~$1786 (17.9h @ $100/h, 30min dedup)

Generated on 2026-04-19 using openrouter/qwen/qwen3-coder-next


TestQL is a declarative DSL (Domain Specific Language) for testing GUI, REST API, and hardware encoder interfaces. It provides a simple, readable syntax for writing automated tests without programming overhead.

Installation

# Install from source
pip install -e .

# Install with development dependencies
pip install -e ".[dev]"

Requirements

  • Python 3.10+
  • HTTPX for API testing
  • Playwright for GUI testing (optional)

Quick Start

# Run a test scenario
testql scenarios/tests/test-api.testql.toon.yaml --url http://localhost:8101

# Dry-run (parse + validate only)
testql scenarios/views/connect-id-barcode.testql.toon.yaml --dry-run

# JSON output for CI integration
testql scenarios/tests/test-api.testql.toon.yaml --output json

# Run with verbose logging
testql scenarios/tests/test-api.testql.toon.yaml --verbose

API Endpoint Detection

TestQL includes advanced endpoint detection for multiple frameworks:

# List all detected endpoints in a project
testql endpoints ./my-project
testql endpoints ./my-project --format json
testql endpoints ./my-project --framework fastapi

# Analyze project structure and generate tests
testql analyze ./my-project
testql generate ./my-project

Supported Frameworks

  • FastAPI โ€” Detects routers, decorators, include_router patterns
  • Flask โ€” Blueprints, MethodView, route decorators
  • Django โ€” URL patterns from urls.py
  • Express.js โ€” JavaScript/TypeScript route definitions
  • OpenAPI/Swagger โ€” Spec file parsing (JSON/YAML)
  • GraphQL โ€” Schema and resolver detection
  • WebSocket โ€” WS endpoint detection

Endpoint Detection Features

  • Framework Detection: Automatically identifies the web framework
  • Handler Names: Extracts function/method names for documentation
  • Parameters: Detects path/query/body parameters
  • Docstrings: Uses function docstrings for test descriptions
  • Test Inference: Analyzes existing tests to discover endpoints

OpenAPI Generation

Generate OpenAPI 3.0 specifications from your code:

# Generate OpenAPI spec (YAML format)
testql openapi ./my-project
testql openapi ./my-project --format json

# Generate with contract tests
testql openapi ./my-project --contract-tests

# Custom output file
testql openapi ./my-project -o ./docs/api-spec.yaml --title "My API"

Contract Testing

TestQL generates contract tests from OpenAPI specs:

# Auto-generated from openapi.yaml
API[25]{method, endpoint, expected_status}:
  GET, /api/v1/users, 200
  POST, /api/v1/users, 201
  ...

ASSERT[3]{field, operator, expected}:
  content_type, ==, application/json
  schema_valid, ==, true
  status, <, 500

Project Echo (AI Context)

Generate AI-friendly project metadata by combining TESTQL scenarios with DOQL system models:

# Generate unified project context
testql echo --toon-path testql-scenarios/ --doql-path app.doql.less

# JSON output for LLM consumption
testql echo --toon-path ./tests --doql-path ./app.doql.less --format json -o context.json

# Text output (human-readable)
testql echo --doql-path ./app.doql.less --format text

Echo Layers

Layer Source Content
API Contract *.testql.toon.yaml Endpoints, methods, assertions
System Model *.doql.less Entities, workflows, interfaces
Unified Context Combined Complete project metadata for AI

Example Output

๐Ÿ“ฆ Project: weboql (0.1.2)

๐Ÿง  Type:
  โ€ข API (fastapi)

๐Ÿ› ๏ธ Workflows:
  โ€ข install: pip install -e .
  โ€ข test: pytest
  โ€ข run: HARDWARE_MODE=mock weboql-server

๐ŸŒ API scenarios:
  โ€ข API Health Check (api) - 4 endpoint(s)

๐Ÿ’ก LLM suggestions:
  โ€ข Run tests: task test
  โ€ข Start server: task run

Language Reference

Variables

SET api_url "http://localhost:8101"
SET timeout 5000
GET api_url              # Prints variable value

Variables support ${var} and $var interpolation:

SET base_url "http://localhost:8101"
API GET "${base_url}/api/devices"

Logging

LOG "Starting test suite"
LOG "Current value: ${var}"

API Commands

# HTTP methods
API GET "/api/v3/data/devices"
API POST "/api/v3/scenarios" {"id": "ts1", "name": "Test"}
API PUT "/api/v3/devices/123" {"status": "active"}
API DELETE "/api/v3/scenarios/old"

Assertions

# Status code assertions
ASSERT_STATUS 200
ASSERT_OK                  # Shorthand for 2xx status

# Content assertions
ASSERT_CONTAINS "device"
ASSERT_CONTAINS "status": "ok"

# JSON path assertions
ASSERT_JSON data.length > 0
ASSERT_JSON devices[0].id == "dev-001"
ASSERT_JSON status != "error"

Operators: ==, !=, >, >=, <, <=

GUI Navigation (Playwright)

# Navigation
NAVIGATE "/connect-workshop"
NAVIGATE "${base_url}/devices"

# Interaction
WAIT 500
CLICK "[data-action='search']"
INPUT "#search-input" "drager"
CLICK "button[type='submit']"

# Assertions
ASSERT_VISIBLE "[data-testid='results']"
ASSERT_TEXT "#status" "Connected"

Hardware Encoder Commands

ENCODER_ON                    # Activate encoder mode
ENCODER_FOCUS column1         # Focus specific column
ENCODER_SCROLL 3              # Scroll 3 steps
ENCODER_CLICK                 # Confirm (single click)
ENCODER_DBLCLICK              # Cancel (double click)
ENCODER_PAGE_NEXT             # Next page
ENCODER_PAGE_PREV             # Previous page
ENCODER_STATUS                # Print current encoder state
ENCODER_OFF                   # Deactivate encoder mode

Script Composition

# Include common setup
INCLUDE "common-setup.testql.toon.yaml"

# Include relative paths
INCLUDE "../helpers/auth.testql.toon.yaml"

Control Flow (Planned)

IF status == "ready"
  LOG "System ready"
ELSE ERROR "System not ready"

LABEL start
REPEAT 3 {
  API GET "/api/ping"
}
GOTO start

Project Structure

testql/
โ”œโ”€โ”€ testql/
โ”‚   โ”œโ”€โ”€ cli.py           # Command-line interface
โ”‚   โ”œโ”€โ”€ base.py          # Base test runner
โ”‚   โ”œโ”€โ”€ commands/        # Command implementations
โ”‚   โ”œโ”€โ”€ runners/         # Test execution runners
โ”‚   โ””โ”€โ”€ reporters/       # Output formatters
โ”œโ”€โ”€ scenarios/           # Sample test scenarios
โ”‚   โ”œโ”€โ”€ tests/          # Automated test suites
โ”‚   โ”œโ”€โ”€ views/          # GUI view tests
โ”‚   โ”œโ”€โ”€ diagnostics/    # System diagnostic scripts
โ”‚   โ”œโ”€โ”€ examples/       # Usage examples
โ”‚   โ””โ”€โ”€ recordings/     # Recorded test sessions
โ”œโ”€โ”€ docs/
โ”‚   โ”œโ”€โ”€ testql-spec.md  # Full language specification
โ”‚   โ””โ”€โ”€ recipes/        # Common testing patterns
โ””โ”€โ”€ tests/              # Unit tests

Scenario Organization

TestQL scenarios use two formats:

  • *.testql.toon.yaml โ€” TestTOON tabular format for test sequences (preserves order)
  • *.testql.less โ€” LESS format for shared test configuration (variables, mixins)
Directory Purpose Example
scenarios/tests/ API/integration tests test-api.testql.toon.yaml
scenarios/views/ GUI view tests connect-id-barcode.testql.toon.yaml
scenarios/diagnostics/ System checks health-check.testql.toon.yaml
scenarios/examples/ Learning samples device-identification.testql.toon.yaml
scenarios/recordings/ Recorded sessions session-recording.testql.toon.yaml

TestTOON Format

Test files use the tabular TestTOON format where each section declares its schema:

# SCENARIO: API Smoke Test
# TYPE: api
# VERSION: 1.0

API[3]{method, endpoint, status}:
  GET,  /api/v3/health,   200
  GET,  /api/v3/devices,  200
  POST, /api/v3/start,    201

ASSERT[2]{field, op, expected}:
  status,  ==, ok
  count,   >,  0

LESS Configuration

Shared test configuration uses LESS for variables and mixins:

// config.testql.less
@api_url: http://localhost:8101;
@timeout_ms: 30000;

.api-test(@method, @endpoint) {
  method: @method;
  endpoint: @endpoint;
  expect_status: 200;
}

CLI Options

testql <file> [options]

Options:
  --url <url>         Base URL for API tests (default: http://localhost:8101)
  --dry-run           Parse and validate only, don't execute
  --output <format>   Output format: text (default), json, junit
  --verbose           Enable verbose logging
  --timeout <ms>      Default timeout for operations

Testing

# Run all tests
pytest

# Run with coverage
pytest --cov=testql

# Run specific test file
pytest tests/test_runner.py -v

Example Scenario

# scenarios/tests/test-api.testql.toon.yaml
# SCENARIO: Device API Test
# TYPE: api
# VERSION: 1.0

CONFIG[1]{key, value}:
  base_url,  http://localhost:8101

API[2]{method, endpoint, status}:
  GET,   /api/v3/data/devices,   200
  POST,  /api/v3/scenarios,      201

ASSERT[2]{field, op, expected}:
  data.length,  >,   0
  data.id,      !=,  null

Documentation

License

Licensed under Apache-2.0.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

testql-0.6.6.tar.gz (81.3 kB view details)

Uploaded Source

Built Distribution

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

testql-0.6.6-py3-none-any.whl (91.4 kB view details)

Uploaded Python 3

File details

Details for the file testql-0.6.6.tar.gz.

File metadata

  • Download URL: testql-0.6.6.tar.gz
  • Upload date:
  • Size: 81.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for testql-0.6.6.tar.gz
Algorithm Hash digest
SHA256 9d125cdb040f0cab7529f3bef2e7effe49445aa93185c34fe6ff1b477a90dce3
MD5 71b7cc154bd356245d4d91a7ac3eac15
BLAKE2b-256 ae050d819262338dba67f7bad41c2cff77031848cf5372ffc2b1f40402826bf1

See more details on using hashes here.

File details

Details for the file testql-0.6.6-py3-none-any.whl.

File metadata

  • Download URL: testql-0.6.6-py3-none-any.whl
  • Upload date:
  • Size: 91.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for testql-0.6.6-py3-none-any.whl
Algorithm Hash digest
SHA256 d58599b697e27bb9fd208c1949dcf7c28d50d6006267c5966ef3b852cfcfc08d
MD5 32829ed624fe1f09c10396ed4d9a6eed
BLAKE2b-256 ad7644b3d06331ed7a60647302a2f60d05e3f38345e6d3f5bbec2905580ed997

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