mcpmark / src /mcp_services /playwright /playwright_task_manager.py
haochengsama's picture
Add files using upload-large-folder tool
a2ec7b6 verified
Raw
History Blame Contribute Delete
3.64 kB
"""
Playwright Task Manager for MCPMark
====================================
Simple task manager for Playwright MCP tasks.
Follows anti-over-engineering principles: keep it simple, do what's needed.
"""
import sys
import os
import subprocess
from pathlib import Path
from typing import List, Dict, Any
from src.base.task_manager import BaseTask, BaseTaskManager
from src.logger import get_logger
logger = get_logger(__name__)
class PlaywrightTask(BaseTask):
"""Playwright-specific task that uses directory name as task name."""
class PlaywrightTaskManager(BaseTaskManager):
"""Simple task manager for Playwright MCP tasks."""
def __init__(self, tasks_root: Path = None, task_suite: str = "standard"):
"""Initialize with tasks directory."""
if tasks_root is None:
tasks_root = Path(__file__).resolve().parents[3] / "tasks"
super().__init__(
tasks_root,
mcp_service="playwright",
task_class=PlaywrightTask,
task_organization="directory",
task_suite=task_suite,
)
def _create_task_from_files(
self, category_id: str, task_files_info: Dict[str, Any]
) -> PlaywrightTask:
"""Instantiate a `PlaywrightTask` from the dictionary returned by `_find_task_files`."""
import json
# Check for meta.json
meta_path = task_files_info["instruction_path"].parent / "meta.json"
final_category_id = category_id
task_id = task_files_info["task_id"]
if meta_path.exists():
try:
with open(meta_path, 'r') as f:
meta_data = json.load(f)
# Use values from meta.json if available
final_category_id = meta_data.get("category_id", category_id)
task_id = meta_data.get("task_id", task_id)
except Exception as e:
logger.warning(f"Failed to load meta.json from {meta_path}: {e}")
return PlaywrightTask(
task_instruction_path=task_files_info["instruction_path"],
task_verification_path=task_files_info["verification_path"],
service="playwright",
category_id=final_category_id,
task_id=task_id,
)
def _get_verification_command(self, task: BaseTask) -> List[str]:
"""Get verification command - just run the verify.py script."""
return [sys.executable, str(task.task_verification_path)]
def run_verification(self, task: BaseTask) -> subprocess.CompletedProcess:
"""Run verification with Playwright-specific environment."""
env = os.environ.copy()
# Pass messages.json path and working directory to verification script
messages_path = os.getenv("MCP_MESSAGES")
work_dir = os.getenv("PLAYWRIGHT_WORK_DIR")
if messages_path:
env["MCP_MESSAGES"] = messages_path
logger.debug(f"Setting MCP_MESSAGES to: {messages_path}")
if work_dir:
env["PLAYWRIGHT_WORK_DIR"] = work_dir
logger.debug(f"Setting PLAYWRIGHT_WORK_DIR to: {work_dir}")
return subprocess.run(
self._get_verification_command(task),
capture_output=True,
text=True,
timeout=90,
env=env,
)
def _format_task_instruction(self, base_instruction: str) -> str:
"""Add Playwright-specific note to instructions."""
return (
base_instruction
+ "\n\nUse Playwright MCP tools to complete this web automation task."
)