Skip to main content

Allure TestOps MCP Server

Project description

Allure TestOps MCP Server

Lucius is a specialized Model Context Protocol (MCP) server for Allure TestOps, built with FastMCP and Starlette.

🎯 Motivation

Allure TestOps is a powerful tool with a huge API. When you're using an AI agent to manage your tests, it can easily get lost in the details or fail because of a small technical mistake.

Lucius makes this easier by giving your AI tools that are simple to use and hard to break:

  • Clear Tools: Every tool is designed for a specific task, like "finding a test case" or "updating a launch".
  • Helpful Errors: If an AI makes a mistake, Lucius doesn't just return a code—it provides an "Agent Hint" that explains exactly what went wrong and how to fix it.
  • Solid Foundation: We follow a clean "Thin Tool" structure, meaning the logic is consistent and easy for both humans and AI to follow.

🛠️ Supported Tools

Tool Category Description All Tools
Test Case Mgmt Full lifecycle for test documentation. create_test_case, update_test_case, delete_test_case, delete_archived_test_cases, get_test_case_details, list_test_cases, get_test_case_custom_fields
Search & Discovery Advanced search and project metadata discovery. search_test_cases, get_custom_fields, list_integrations
Shared Steps Create and manage reusable sequence sequences. create_shared_step, list_shared_steps, update_shared_step, delete_shared_step, delete_archived_shared_steps, link_shared_step, unlink_shared_step
Test Layers Manage test taxonomy and auto-mapping schemas. list_test_layers, create_test_layer, update_test_layer, delete_test_layer, list_test_layer_schemas, create_test_layer_schema, update_test_layer_schema, delete_test_layer_schema
Test Hierarchy Organize suites and assign tests in tree paths. create_test_suite, list_test_suites, assign_test_cases_to_suite, delete_test_suite
Custom Fields Project-level management of custom field values. list_custom_field_values, create_custom_field_value, update_custom_field_value, delete_custom_field_value, delete_unused_custom_fields
Test Plans Manage Test Plans and their content. create_test_plan, update_test_plan, delete_test_plan, list_test_plans, manage_test_plan_content
Defect Mgmt Track defects, linkage, and automation rules. create_defect, get_defect, update_defect, delete_defect, list_defects, link_defect_to_test_case, list_defect_test_cases, create_defect_matcher, list_defect_matchers, update_defect_matcher, delete_defect_matcher

🚀 Quick Start

  1. Install uv: curl -LsSf https://astral.sh/uv/install.sh | sh
  2. Setup Credentials: Create a .env file with the variables below.
  3. Run Server: uv run start

Basic .env for Quick Start

Variable Description Example
ALLURE_ENDPOINT Allure TestOps base URL https://example.testops.cloud
ALLURE_PROJECT_ID Default Allure project ID 123
ALLURE_API_TOKEN Allure API token <your_api_token>
MCP_MODE MCP transport mode for Lucius runtime stdio

🔌 Claude Desktop Integration

The easiest way to use Lucius in Claude Desktop is via the .mcpb bundle:

  1. Download the latest lucius-mcp.mcpb from Releases.
  2. Open with Claude Desktop.
  3. Configure your Allure credentials in the UI.

💻 Claude Code Integration

To add Lucius to Claude Code, use the following command from within your project directory:

claude mcp add --transport stdio --scope project \
  --env ALLURE_ENDPOINT=https://example.testops.cloud \
  --env ALLURE_PROJECT_ID=123 \
  --env ALLURE_API_TOKEN=<your_api_token> \
  --env MCP_MODE=stdio \
  testops-mcp -- uvx --from lucius-mcp --refresh start

Project-scoped text config example (.mcp.json):

{
  "mcpServers": {
    "testops-mcp": {
      "type": "stdio",
      "command": "uvx",
      "args": [
        "--from",
        "lucius-mcp",
        "--refresh",
        "start"
      ],
      "env": {
        "ALLURE_ENDPOINT": "https://example.testops.cloud",
        "ALLURE_PROJECT_ID": "123",
        "ALLURE_API_TOKEN": "<your_api_token>",
        "MCP_MODE": "stdio"
      }
    }
  }
}

🧠 Codex Integration

To add Lucius to Codex (CLI or IDE extension), use:

codex mcp add testops-mcp \
  --env ALLURE_ENDPOINT=https://example.testops.cloud \
  --env ALLURE_PROJECT_ID=123 \
  --env ALLURE_API_TOKEN=<your_api_token> \
  --env MCP_MODE=stdio \
  -- uvx --from lucius-mcp --refresh start

Text config example (~/.codex/config.toml or project .codex/config.toml):

[mcp_servers.testops-mcp]
command = "uvx"
args = ["--from", "lucius-mcp", "--refresh", "start"]

[mcp_servers.testops-mcp.env]
ALLURE_ENDPOINT = "https://example.testops.cloud"
ALLURE_PROJECT_ID = "123"
ALLURE_API_TOKEN = "<your_api_token>"
MCP_MODE = "stdio"

For detailed setup, including Claude Desktop (MCPB) integration, see Setup Guide.

💻 Command-Line Interface (CLI)

Lucius also provides a universal CLI entry point for direct tool execution from the command line:

# Download pre-built binary for your platform
wget https://github.com/ivanostanin/lucius-mcp/releases/latest/download/lucius-linux-x86_64
chmod +x lucius-linux-x86_64
./lucius-linux-x86_64 --help

# List available actions for an entity
./lucius-linux-x86_64 test_case

# Execute an action
./lucius-linux-x86_64 test_case get --args '{"test_case_id": 1234}'

# Show help for a specific entity/action
./lucius-linux-x86_64 test_case get --help

CLI Features:

  • 🎯 Type-safe entity/action invocation with validation
  • 📊 Multiple output formats (JSON, table, csv, plain)
  • 🔍 Per-action help with parameters and examples
  • 🛡️ Clean error messages with guidance
  • 📦 Standalone binaries for Linux, macOS, and Windows

For local CLI binary builds with Nuitka, use Python 3.13 (the build scripts and CI workflow enforce this).

For full CLI documentation and installation instructions, see CLI Guide.

📡 Telemetry

Lucius collects privacy-preserving usage telemetry to improve tool quality. Telemetry is enabled by default and sends metadata to https://stats.ostanin.me, an endpoint operated by the project owner (no third party has access to this endpoint).

If this is acceptable in your environment, staying opted in helps improve Lucius over time. If you want to opt out, set TELEMETRY_ENABLED=false in your environment.

No API tokens, test content, or tool arguments are sent.

See Telemetry & Privacy for the full data dictionary and telemetry behavior details.

Shell Completions

Pre-generated shell completions are available in deployment/shell-completions/ for bash, zsh, fish, and PowerShell. They are generated from the current entity/action route matrix:

python3 deployment/scripts/generate_completions.py

Load one in your shell profile, for example:

source deployment/shell-completions/lucius.bash

📂 Documentation

Full documentation is available in the docs/ folder:

🤝 Contributing

Contributions are welcome! Please see the Contribution Guidelines and the Development Guide for more details.

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

lucius_mcp-0.8.1.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

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

lucius_mcp-0.8.1-py3-none-any.whl (1.9 MB view details)

Uploaded Python 3

File details

Details for the file lucius_mcp-0.8.1.tar.gz.

File metadata

  • Download URL: lucius_mcp-0.8.1.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for lucius_mcp-0.8.1.tar.gz
Algorithm Hash digest
SHA256 8570369a25caa1c0ad925b69d506f86d3912e3817f8f122b6f54aa9a9c0c7488
MD5 e49837431aaa4c7d7c23dd620c302964
BLAKE2b-256 eb7d0df36289ce8af0a4e9e23f37eb29665dd824e42899fac3d7485eed06d279

See more details on using hashes here.

Provenance

The following attestation bundles were made for lucius_mcp-0.8.1.tar.gz:

Publisher: release.yml on ivanostanin/lucius-mcp

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

File details

Details for the file lucius_mcp-0.8.1-py3-none-any.whl.

File metadata

  • Download URL: lucius_mcp-0.8.1-py3-none-any.whl
  • Upload date:
  • Size: 1.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for lucius_mcp-0.8.1-py3-none-any.whl
Algorithm Hash digest
SHA256 eb68d337bdba8e44b047ec79b98a09859cb508d578c4507e9900f9043154bc37
MD5 c4b8a21a582f46ec39b27e0ee956f4b3
BLAKE2b-256 c4451e98dead97cf5c813b29aa9f6ff4f48098e1955bc48e52e2317da0d854f3

See more details on using hashes here.

Provenance

The following attestation bundles were made for lucius_mcp-0.8.1-py3-none-any.whl:

Publisher: release.yml on ivanostanin/lucius-mcp

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