AgentSkillsCN

tidewave-integration

Tidewave MCP 运行时工具,专为 Phoenix 开发打造。在开发环境中进行运行时调试、代码测试或数据库查询时加载这些工具。

SKILL.md
--- frontmatter
name: tidewave-integration
description: Tidewave MCP runtime tools for Phoenix development. Load when runtime debugging, testing code, or querying database in dev.

Tidewave MCP Integration

Runtime intelligence for Phoenix apps via MCP. Prefer Tidewave tools over Bash when available.

Iron Laws — Never Violate These

  1. DEV ONLY — Never use Tidewave tools in production contexts. Avoid on shared dev servers with production data copies
  2. PREFER TIDEWAVE OVER BASHmcp__tidewave__get_docs > web_fetch, execute_sql_query > psql
  3. CHECK AVAILABILITY FIRST — Use /mcp command or detect mcp__tidewave__ tools
  4. SQL IS READ-HEAVY — Use execute_sql_query for SELECT, be careful with mutations
  5. EXACT VERSIONSget_docs returns docs for YOUR mix.lock versions, not latest

Quick Reference

TaskTidewave ToolFallback
Get docsmcp__tidewave__get_docs Module.func/3web_fetch hexdocs.pm/...
Run codemcp__tidewave__project_evalmix run -e "code"
SQL querymcp__tidewave__execute_sql_querypsql $DATABASE_URL
Find sourcemcp__tidewave__get_source_locationgrep -rn "defmodule"
List schemasmcp__tidewave__get_ecto_schemasRead lib/*/schemas/
Read logsmcp__tidewave__get_logs level: :errortail -f log/dev.log

Detection

bash
# Check endpoint
curl -s http://localhost:4000/tidewave/mcp \
  -H "Content-Type: application/json" \
  -d '{"jsonrpc":"2.0","id":1,"method":"ping"}'

Or use /mcp in Claude Code to see connected servers.

Essential Patterns

Test Function Immediately

elixir
# mcp__tidewave__project_eval
MyApp.Accounts.create_user(%{email: "test@example.com"})

Verify Migration

sql
-- mcp__tidewave__execute_sql_query
SELECT column_name, data_type FROM information_schema.columns
WHERE table_name = 'users';

Debug LiveView (with PID from browser)

elixir
# mcp__tidewave__project_eval
pid = pid("0.1234.0")
:sys.get_state(pid) |> Map.get(:socket) |> Map.get(:assigns) |> Map.keys()

Setup Requirements

elixir
# mix.exs
{:tidewave, "~> 0.1", only: :dev}

# endpoint.ex (in dev block)
plug Tidewave

# config/dev.exs (for LiveView source mapping)
config :phoenix_live_view,
  debug_heex_annotations: true,
  debug_attributes: true

Proactive Runtime Checks

Don't just use Tidewave reactively. Query runtime state at workflow checkpoints automatically:

  • After code edits: get_logs level: :error (catch runtime crashes)
  • After features complete: project_eval smoke test (behavioral check)
  • Before planning: get_ecto_schemas + routes eval (concrete context)
  • When investigating: Auto-capture errors before asking user

See references/proactive-patterns.md for full integration points.

References

For detailed patterns, see:

  • references/proactive-patterns.md - Push-like runtime patterns at workflow checkpoints
  • references/tool-examples.md - Complete tool usage examples
  • references/validation-checklist.md - Runtime validation patterns