Files
local-deep-research/.github/workflows/mcp-tests.yml
dependabot[bot] 56290b15c0 chore(deps): bump step-security/harden-runner from 2.19.0 to 2.19.1 (#3811)
Bumps [step-security/harden-runner](https://github.com/step-security/harden-runner) from 2.19.0 to 2.19.1.
- [Release notes](https://github.com/step-security/harden-runner/releases)
- [Commits](8d3c67de8e...a5ad31d6a1)

---
updated-dependencies:
- dependency-name: step-security/harden-runner
  dependency-version: 2.19.1
  dependency-type: direct:production
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2026-05-06 08:01:44 +02:00

127 lines
4.6 KiB
YAML

name: MCP Server Tests
on:
push:
branches: [ main, dev ]
paths:
- 'src/local_deep_research/mcp/**'
- 'src/local_deep_research/advanced_search_system/strategies/mcp_strategy.py'
- 'tests/mcp/**'
- 'scripts/mcp_smoke_test.sh'
- '.github/workflows/mcp-tests.yml'
pull_request:
branches: [ main, dev ]
paths:
- 'src/local_deep_research/mcp/**'
- 'src/local_deep_research/advanced_search_system/strategies/mcp_strategy.py'
- 'tests/mcp/**'
- 'scripts/mcp_smoke_test.sh'
- '.github/workflows/mcp-tests.yml'
workflow_dispatch:
# No concurrency group — intentionally omitted.
# Previous attempt (#3554, reverted #3599) used cancel-in-progress which
# killed in-progress PR runs before they produced useful results.
# Future iteration could safely add concurrency for scheduled/push-only
# triggers (where head_ref is empty and runs get unique groups).
permissions:
contents: read
jobs:
mcp-tests:
name: MCP Server Tests
runs-on: ubuntu-latest
timeout-minutes: 15
steps:
- name: Harden the runner (Audit all outbound calls)
uses: step-security/harden-runner@a5ad31d6a139d249332a2605b85202e8c0b78450 # v2.19.1
with:
egress-policy: audit
- name: Checkout code
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with:
persist-credentials: false
- name: Set up Python
uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 # v6
with:
python-version: '3.12'
- name: Install dependencies
run: |
python -m pip install pip==25.0
pip install pdm==2.26.2
pdm install --dev --no-editable -G mcp
- name: Check if MCP server module exists
id: check-mcp
run: |
if [ -f "src/local_deep_research/mcp/server.py" ]; then
echo "mcp_exists=true" >> "$GITHUB_OUTPUT"
echo "MCP server module found, will run tests"
else
echo "mcp_exists=false" >> "$GITHUB_OUTPUT"
echo "MCP server module not found (feature not yet merged), skipping tests"
fi
- name: Run MCP smoke tests
if: steps.check-mcp.outputs.mcp_exists == 'true'
run: pdm run bash scripts/mcp_smoke_test.sh
- name: Run MCP unit tests
if: steps.check-mcp.outputs.mcp_exists == 'true'
run: |
pdm run pytest tests/mcp/ -v --tb=short -n auto \
--ignore=tests/mcp/test_mcp_strategy.py
env:
LDR_TESTING_WITH_MOCKS: "true"
- name: Run MCP strategy tests
if: steps.check-mcp.outputs.mcp_exists == 'true'
run: |
pdm run pytest tests/mcp/test_mcp_strategy.py -v --tb=short -n auto
env:
LDR_TESTING_WITH_MOCKS: "true"
- name: Skip notice
if: steps.check-mcp.outputs.mcp_exists != 'true'
run: |
echo "::notice::MCP server module not yet implemented. Tests will run once feature/mcp-server is merged."
- name: Generate test summary
if: always()
env:
MCP_EXISTS: ${{ steps.check-mcp.outputs.mcp_exists }}
run: |
{
echo "## MCP Server Test Summary"
echo ""
if [ "$MCP_EXISTS" != "true" ]; then
echo "### ⏭️ Tests Skipped"
echo ""
echo "MCP server module (\`src/local_deep_research/mcp/server.py\`) not yet implemented."
echo "Tests will run automatically once the MCP feature branch is merged."
else
echo "### What was tested:"
echo "- 🔌 MCP server module loading"
echo "- 🔧 Discovery tools (list_strategies, list_search_engines, get_configuration)"
echo "- 🧪 Unit tests for all MCP tools"
echo "- 🤖 MCP strategy (ReAct pattern) tests"
echo "- 🚀 Server startup verification"
echo ""
echo "### MCP Tools Tested:"
echo "| Tool | Description |"
echo "|------|-------------|"
echo "| \`quick_research\` | Fast research summary (1-5 min) |"
echo "| \`detailed_research\` | Comprehensive analysis (5-15 min) |"
echo "| \`generate_report\` | Full markdown report (10-30 min) |"
echo "| \`analyze_documents\` | Search local collections |"
echo "| \`list_search_engines\` | List available search engines |"
echo "| \`list_strategies\` | List research strategies |"
echo "| \`get_configuration\` | Get current config |"
fi
} >> "$GITHUB_STEP_SUMMARY"