This skill should be used when the user asks to "set up MailHog", "test email functionality", "configure MailHog", "send test emails", "check MailHog messages", "configure SMTP testing", or "manage email capture". Provides comprehensive MailHog email testing server setup and management.
Sets up and manages MailHog email testing servers for development workflows. Triggers when users request MailHog setup, email testing configuration, or SMTP server management.
/plugin marketplace add Whamp/whamp-claude-tools/plugin install whamp-mailhog-mailhog-plugin@Whamp/whamp-claude-toolsThis skill inherits all available tools. When active, it can use any tool Claude has access to.
examples/app-configs/nodemailer.jsexamples/app-configs/python-smtp.pyexamples/docker-compose.ymlreferences/api-endpoints.mdreferences/configurations.mdreferences/integration-patterns.mdscripts/mailhog_manager.shscripts/send_test_email.shscripts/test_email_workflow.shMailHog provides a comprehensive email testing solution for development and testing environments. This skill enables complete MailHog server management, email testing workflows, and integration with development pipelines.
MailHog Architecture: MailHog consists of SMTP server (port 1025 by default) for receiving emails and HTTP API/UI (port 8025 by default) for viewing and managing captured emails.
Storage Options: Memory (default, ephemeral), MongoDB (persistent), or Maildir (file-based) for email storage.
Jim Simulation: Built-in chaotic network simulation for testing email resilience under adverse conditions.
Start MailHog with default settings (memory storage, ports 1025/8025):
# Basic start
mailhog
# Custom ports
mailhog -smtp-bind-addr :1025 -ui-bind-addr :8025 -api-bind-addr :8025
# Background execution
mailhog &
Configure MongoDB storage:
mailhog -storage mongodb -mongo-uri 127.0.0.1:27017 -mongo-db mailhog_test -mongo-coll messages
Configure Maildir storage:
mailhog -storage maildir -maildir-path ./mail_storage
# Custom hostname for EHLO/HELO
mailhog -hostname mailhog.test.local
# Custom bind addresses
mailhog -smtp-bind-addr 0.0.0.0:1025 -ui-bind-addr 0.0.0.0:8025
# CORS configuration
mailhog -cors-origin "http://localhost:3000,http://localhost:5173"
# Create bcrypt password file
echo "admin:$(bcrypt-hash 'password123')" > auth_file.txt
# Enable authentication
mailhog -auth-file auth_file.txt
Create outgoing SMTP configuration for email forwarding:
{
"server": "smtp.gmail.com",
"port": 587,
"username": "test@gmail.com",
"password": "app-password",
"tls": true
}
mailhog -outgoing-smtp outgoing_config.json
Use built-in test utilities or SMTP clients:
# Using telnet for basic SMTP test
telnet localhost 1025
EHLO test.local
MAIL FROM:test@sender.local
RCPT TO:recipient@test.local
DATA
Subject: Test Email
From: test@sender.local
To: recipient@test.local
This is a test email.
.
QUIT
Execute test email sending script:
./scripts/send_test_email.sh --to test@recipient.local --subject "Test Message" --body "Test content"
Query captured emails via API:
# Get all messages
curl http://localhost:8025/api/v1/messages
# Get recent messages
curl http://localhost:8025/api/v1/messages?limit=10
# Search emails
curl -X POST http://localhost:8025/api/v1/search \
-H "Content-Type: application/json" \
-d '{"query": "subject:test"}'
Configure application environments for MailHog integration:
# Environment variables
export SMTP_HOST=localhost
export SMTP_PORT=1025
export SMTP_USER=
export SMTP_PASS=
export SMTP_TLS=false
Node.js/Nodemailer Configuration:
const transporter = nodemailer.createTransporter({
host: 'localhost',
port: 1025,
secure: false,
auth: false
});
Python/SMTP Configuration:
import smtplib
server = smtplib.SMTP('localhost', 1025)
server.sendmail(sender, recipients, message)
Execute automated testing script:
./scripts/test_email_workflow.sh --config test_config.json
Enable Jim for chaotic network testing:
# Enable Jim with default settings
mailhog -invite-jim
# Custom Jim behavior
mailhog -invite-jim \
-jim-accept 0.95 \
-jim-reject-sender 0.1 \
-jim-reject-recipient 0.1 \
-jim-disconnect 0.02 \
-jim-linkspeed-affect 0.2
mailhog \
-smtp-bind-addr 0.0.0.0:1025 \
-ui-bind-addr 0.0.0.0:8025 \
-api-bind-addr 0.0.0.0:8025 \
-storage mongodb \
-mongo-uri mongodb.example.com:27017 \
-mongo-db mailhog_prod \
-cors-origin "https://app.example.com" \
-hostname mailhog.example.com
Verify MailHog is running correctly:
# Check SMTP port
telnet localhost 1025
# Check UI/API
curl http://localhost:8025
# Check API status
curl http://localhost:8025/api/v1/messages
Monitor MailHog operations and troubleshoot issues:
# Start with verbose logging (if available)
mailhog 2>&1 | tee mailhog.log
# Monitor message count
watch -n 5 'curl -s http://localhost:8025/api/v1/messages | jq ".total"'
Optimize for high-volume testing:
# Memory cleanup for long-running instances
curl -X DELETE http://localhost:8025/api/v1/messages
# MongoDB indexing for performance
# Execute via mongo shell on mailhog database
db.messages.createIndex({ "created": -1 })
db.messages.createIndex({ "From": 1 })
http://localhost:8025)Port Conflicts: Kill existing processes or change ports:
lsof -i :1025 -i :8025
kill -9 <PID>
MongoDB Connection Issues: Verify MongoDB is running and accessible:
mongo mongodb://127.0.0.1:27017/mailhog_test
Email Not Appearing: Check SMTP client configuration and network connectivity.
UI Not Loading: Verify API bind address and check for port conflicts.
# Test SMTP connection manually
telnet localhost 1025
# Check MailHog process
ps aux | grep mailhog
# Verify API accessibility
curl -v http://localhost:8025/api/v1/messages
Production Usage: Never expose MailHog directly to internet without authentication and proper firewall configuration.
Email Privacy: Captured emails may contain sensitive information - secure MailHog instance appropriately.
Authentication: Always use authentication in production environments with -auth-file.
# Backup MailHog messages
mongodump --db mailhog_prod --collection messages --out ./backup
# Restore messages
mongorestore --db mailhog_prod --collection messages ./backup/messages.bson
# Backup maildir storage
tar -czf mailhog_maildir_backup.tar.gz ./mail_storage
For detailed configurations and advanced patterns, consult:
references/configurations.md - Advanced configuration examplesreferences/api-endpoints.md - Complete API referencereferences/integration-patterns.md - Framework integration guidesUtility scripts for common operations:
scripts/send_test_email.sh - Send test emails via SMTPscripts/test_email_workflow.sh - Automated testing workflowscripts/mailhog_manager.sh - Server management utilityWorking configurations and setups:
examples/docker-compose.yml - Docker container setupexamples/app-configs/ - Application configuration examplesexamples/terraform/ - Infrastructure as code examplesThis skill should be used when the user asks to "create a slash command", "add a command", "write a custom command", "define command arguments", "use command frontmatter", "organize commands", "create command with file references", "interactive command", "use AskUserQuestion in command", or needs guidance on slash command structure, YAML frontmatter fields, dynamic arguments, bash execution in commands, user interaction patterns, or command development best practices for Claude Code.
This skill should be used when the user asks to "create an agent", "add an agent", "write a subagent", "agent frontmatter", "when to use description", "agent examples", "agent tools", "agent colors", "autonomous agent", or needs guidance on agent structure, system prompts, triggering conditions, or agent development best practices for Claude Code plugins.
This skill should be used when the user asks to "create a hook", "add a PreToolUse/PostToolUse/Stop hook", "validate tool use", "implement prompt-based hooks", "use ${CLAUDE_PLUGIN_ROOT}", "set up event-driven automation", "block dangerous commands", or mentions hook events (PreToolUse, PostToolUse, Stop, SubagentStop, SessionStart, SessionEnd, UserPromptSubmit, PreCompact, Notification). Provides comprehensive guidance for creating and implementing Claude Code plugin hooks with focus on advanced prompt-based hooks API.