🧪 Converting Email Templates

>-

About Converting Email Templates

Automatically convert email templates from other email service providers into Mailtrap-compatible Handlebars syntax. Handles both deterministic pattern conversions (via a Python script) and complex edge cases (via LLM intelligence).

This large 978-word instruction set is purpose-built for testing & qa work in AI coding agents. Paste directly into your CLAUDE.md or AI agent settings.

Key Capabilities

  • Source provider (required): `sendgrid`, `mailgun`, `mandrill-handlebars`, `mandrill-mergetags`, `postmark`, `brevo`, or `ses`
  • Input: a single template file path, a directory of `.html` template files, or raw HTML pasted inline
  • Output directory (optional): defaults to a `/converted/` subdirectory next to the input
  • Provider is `brevo` AND the template contains nested loops, multiple filters, or complex conditional nesting
  • The script flags patterns that could benefit from LLM judgment

What This Skill Covers

  • Purpose
  • Input
  • Workflow
  • Conversion Complete
  • Inline conversion (no file)
  • Rules

How It Works

  1. Read the flagged line in the original template.
  2. Consult `references/conversion-rules.md` for the specific rule and recommended action.
  3. Categorize the flag:
  4. Identify the source provider (ask if not stated).
  5. Apply the conversion rules from `references/conversion-rules.md` directly using LLM intelligence.

Use Cases

  • Writing unit, integration, and end-to-end tests
  • Setting up test coverage and CI pipelines
  • Refactoring legacy code with confidence using tests
  • Creating test plans and QA checklists

Example Prompts

Write tests Write unit tests for a user authentication function
Test strategy What testing strategy would you recommend for a REST API?

System Prompt (978 words)

Converting email templates

Purpose

Automatically convert email templates from other email service providers into Mailtrap-compatible Handlebars syntax. Handles both deterministic pattern conversions (via a Python script) and complex edge cases (via LLM intelligence).

Related skills: using-email-templates (Handlebars syntax, API template send), sending-emails (stream bases and auth), authorizing-api-requests (tokens, env vars, account_id resolution — needed when creating templates or sending via the Templates API after conversion).

Input

  • Source provider (required): sendgrid, mailgun, mandrill-handlebars, mandrill-mergetags, postmark, brevo, or ses
  • Input: a single template file path, a directory of .html template files, or raw HTML pasted inline
  • Output directory (optional): defaults to a /converted/ subdirectory next to the input
If the user does not specify the source provider, ask before proceeding. If the user provides template HTML inline (pasted in chat), save it to a temporary .html file first.

Workflow

Step 1: Detect mode

Fast mode (default): For providers with deterministic conversion patterns. The Python script handles these reliably.

Deep mode: Triggered when:

  • Provider is brevo AND the template contains nested loops, multiple filters, or complex conditional nesting

  • The script flags patterns that could benefit from LLM judgment

  • The user explicitly requests deep mode

  • Inline HTML is provided (run LLM conversion directly)


Step 2: Run the converter script

Execute the Python converter script:

python3 {skill_dir}/scripts/converter.py \
  --provider {provider} \
  --input {input_path} \
  --output {output_dir}

Where {skill_dir} is the directory containing this SKILL.md file.

Read the output:

  • Exit code 0: clean conversion, no flags. Proceed to Step 4.

  • Exit code 1: conversion completed with flags. Proceed to Step 3.

  • Exit code 2: error. Report to user and stop.


Read the .report.txt file(s) generated alongside each converted template. For bulk conversions, also read _summary.txt.

Note: When flags are present, the script automatically:

  • Prepends a <!-- WARNING: ... --> comment at the top of the converted file

  • Wraps unsupported syntax in <!-- FLAGGED [RULE]: message --> HTML comments so the file can be pasted into the Mailtrap editor without triggering parser errors


Step 3: Handle flags (Deep mode)

For each flag in the report:

  • Read the flagged line in the original template.
  • Consult references/conversion-rules.md for the specific rule and recommended action.
  • Categorize the flag:
- App-layer change required (e.g., formatDate, comparison helpers): Cannot be resolved in the template. Report to the user with a clear explanation of what they need to change in their application code. Suggest the replacement variable name. - Template-level fix possible (e.g., Brevo nested loops, Mandrill mc:edit regions): Apply the conversion using LLM judgment. Show the user the before/after and ask for confirmation before writing. - Ambiguous (e.g., Postmark closing tag mismatch): Show the user both the original context and the converted output. Ask them to verify.

Present flags grouped by category:

## Conversion Complete

### Auto-converted: [count] changes
[Brief summary or collapsed details]

### Needs your application code: [count] flags
[For each: what to change, why, suggested variable name]

### Needs verification: [count] flags
[For each: show before/after, ask for confirmation]

Step 4: Present results

Single file:

Converted: {filename}
Changes: [count] | Flags: [count]
Output: {output_path}

[Show the conversion report summary]
[If flags exist, show the categorized flag breakdown from Step 3]

Bulk conversion:

Converted: [count] files
Total changes: [count] | Total flags: [count]
Clean: [count] files | Needs review: [count] files
Output: {output_dir}

[Show the summary report]
[List files needing review with their specific flags]

Step 5: API field mapping reminder

After template conversion, always remind the user about the API-side changes they need to make. Reference the quick mapping table:

| Provider | Old template field | Old variables field | Mailtrap field | Mailtrap variables |
|----------|-------------------|--------------------|-----------------------|------------------------|
| SendGrid | template_id | personalizations[].dynamic_template_data | template_uuid | template_variables |
| Mailgun | template | t:variables | template_uuid | template_variables |
| Mandrill | template_name | global_merge_vars + merge_vars | template_uuid | template_variables |
| Postmark | TemplateId/TemplateAlias | TemplateModel | template_uuid | template_variables |
| Brevo | templateId | params | template_uuid | template_variables |
| Amazon SES | TemplateName/TemplateArn | TemplateData | template_uuid | template_variables |

Only show the row for the provider that was just converted.

Inline conversion (no file)

If the user pastes template HTML directly in chat instead of providing a file path:

  • Identify the source provider (ask if not stated).
  • Apply the conversion rules from references/conversion-rules.md directly using LLM intelligence.
  • Comment out unsupported syntax in the converted output by wrapping it in <!-- FLAGGED [RULE]: message --> HTML comments (same format as the script). This prevents editor errors when the user pastes the output into Mailtrap.
  • If there are flags, prepend a <!-- WARNING: ... --> comment at the top of the converted output noting how many flagged patterns need resolution.
  • Present the converted Handlebars output with a list of changes made.
  • Flag any patterns that need app-layer changes.
  • Offer to save the result to a file.
This mode always uses Deep mode (LLM) since there is no file to pass to the script.

Rules

  • Never silently skip a flagged pattern. Every flag must be reported to the user.
  • Never modify the original file. Converted output always goes to the output directory.
  • Preserve HTML structure. Only modify template syntax (variables, conditionals, loops, helpers). Do not touch HTML tags, attributes, CSS, or non-template content.
  • When in doubt, flag. If a pattern is ambiguous, flag it for manual review rather than making an incorrect conversion.
  • Report counts. Always show the number of changes and flags so the user knows the scope.
  • One provider at a time. If a directory contains templates from multiple providers, ask the user to separate them or specify the provider for the batch.

Frequently Asked Questions

What is Converting Email Templates?

Converting Email Templates is a free testing & qa skill for AI coding agents. >-. It provides a specialized system prompt that configures your agent with testing & qa expertise.

How do I use Converting Email Templates with Claude Code?

Copy the system prompt below and paste it into your CLAUDE.md file or Claude Code's custom instructions to activate Converting Email Templates.

Which AI coding agents work with Converting Email Templates?

Converting Email Templates is compatible with Claude Code, Cursor, GitHub Copilot, Windsurf, OpenClaw, Cline, and any AI agent that supports custom system prompts or .cursorrules files.

Is Converting Email Templates free to use?

Yes, Converting Email Templates is completely free and open source. The full source is available on GitHub at https://github.com/mailtrap/mailtrap-skills/blob/main/skills/converting-email-templates/SKILL.md. You only need a subscription to the AI agent you use it with.

Related Skills

Get the best new skills
in your inbox

Weekly roundup of top Claude Code skills, MCP servers, and AI coding tips.