sajithrw/mcp-jira-xray
If you are the rightful owner of mcp-jira-xray and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
A Model Context Protocol (MCP) server for extracting test information from Jira Xray.
MCP Jira Xray Server
A Model Context Protocol (MCP) server for extracting test information from Jira Xray. This server connects to Jira instances with Xray Test Management and extracts test cases related to specific tickets.
Features
- 🔍 Extract tests related to any Jira ticket
- 📋 List test executions linked to tickets
- 🎨 Configurable JSON output format
- 💾 Automatic saving to the
extractionsfolder - 🔐 Secure connection using Jira API tokens
Installation
Prerequisites
- Node.js 17 or higher
- A Jira instance with Xray Test Management
- Jira API token
Setup
- Clone this repository or install via npm:
git clone <repository-url>
cd mcp-jira-xray
npm install
- Run the interactive setup:
npm run setup
This will guide you through:
- Entering your Jira host URL
- Providing your Jira email
- Adding your API token
- Validating the connection
- Configuring output format
Or manually create a .env file:
cp .env.example .env
# Edit .env with your credentials
Getting a Jira API Token
- Go to Atlassian Account Settings
- Click "Create API token"
- Give it a label and copy the token
- Use this token in your
.envfile
Configuration
Jira Connection
The server requires three configuration values:
JIRA_HOST: Your Jira instance URL (e.g.,https://mycompany.atlassian.net)JIRA_EMAIL: Your Jira account emailJIRA_API_TOKEN: Your Jira API token
Output Format
The OUTPUT_FORMAT environment variable defines the JSON structure for extracted test data. You can customize this to match your needs.
Default format:
{
"ticketId": "",
"test": "",
"testCases": []
}
Custom format example:
{
"ticket": {
"id": "",
"name": ""
},
"tests": {
"cases": []
}
}
The server will populate the fields based on these keys:
ticketId→ The Jira ticket IDtest→ The ticket summarytestCases→ Array of test case descriptions
Usage
With VS Code
Good news! The server is already configured for this project in .vscode/mcp.json.
Quick Start:
- Make sure you've run
npm run setup(configuration complete) - Open Command Palette:
Cmd/Ctrl + Shift + P - Type: "MCP: Enable" and press Enter
- Try: "Extract tests for ticket PROJ-123" in Copilot Chat
📖 See for complete VS Code installation guide
With Claude Desktop
Add this to your Claude Desktop configuration file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"jira-xray": {
"command": "node",
"args": ["/absolute/path/to/mcp-jira-xray/build/index.js"]
}
}
}
Available Tools
1. extract_tests
Extracts all tests related to a given Jira ticket.
Parameters:
ticketId(string): The Jira ticket ID (e.g., "PROJ-123")
Example:
Extract tests for ticket PROJ-123
Output:
- Test execution details
- All test cases with descriptions
- Saved to
extractions/PROJ-123_<timestamp>.json
2. list_test_executions
Lists all test executions linked to a Jira ticket.
Parameters:
ticketId(string): The Jira ticket ID
Example:
List test executions for PROJ-123
Output:
- List of test execution keys
- Test execution summaries
- Execution statuses
Output Files
All extracted test data is saved to the extractions/ folder with the following naming convention:
extractions/<TICKET-ID>_<TIMESTAMP>.json
Example: extractions/PROJ-123_2024-01-15T10-30-45-123Z.json
Development
Interactive Setup
Run the setup wizard:
npm run setup
Validate Configuration
Test your Jira connection:
npm run validate
This will:
- Check your .env configuration
- Test connection to Jira
- Verify authentication
- List accessible projects
- Confirm permissions
Build
npm run build
This compiles TypeScript to JavaScript in the build/ directory.
Project Structure
mcp-jira-xray/
├── src/
│ ├── index.ts # Main MCP server entry point
│ ├── jira-client.ts # Jira API client
│ ├── config.ts # Configuration management
│ └── output-handler.ts # File output handling
├── build/ # Compiled JavaScript (generated)
├── extractions/ # Output files (generated)
├── .env # Environment configuration
├── .env.example # Example configuration
├── package.json
├── tsconfig.json
└── README.md
Troubleshooting
"Missing required environment variables"
Make sure your .env file exists and contains all required variables (JIRA_HOST, JIRA_EMAIL, JIRA_API_TOKEN).
"Failed to get ticket"
- Verify your Jira credentials are correct
- Check that the ticket ID exists in your Jira instance
- Ensure your API token has appropriate permissions
"Xray API not available"
The server tries multiple methods to extract test data. If Xray-specific APIs aren't available, it falls back to standard Jira JQL queries. This may happen if:
- Xray is not installed on your Jira instance
- Your account doesn't have Xray permissions
Connection Issues
- Ensure your
JIRA_HOSTincludes the protocol (https://) - Check that your network allows connections to Jira
- Verify your API token is valid and not expired
License
MIT
Contributing
Contributions are welcome! Please feel free to submit issues or pull requests.
Support
For issues and questions:
- Check existing [GitHub Issues](
/issues) - Create a new issue with detailed information
- Include your Jira and Xray versions