AgentSkillsCN

test-framework-migration-skill

在Selenium、Playwright、Puppeteer与Cypress之间迁移并转换测试自动化脚本。当用户提出将测试从一个框架迁移到另一个框架、在不同框架中重写测试,或从Selenium切换到Playwright、从Playwright切换到Selenium、从Puppeteer切换到Playwright、从Cypress切换到Playwright,或反之亦然时使用此功能。可通过“迁移”“转换”“移植”“Selenium转Playwright”“Playwright转Selenium”“Puppeteer转Playwright”“Cypress转Playwright”“在……中重写测试”“从[框架]切换到[框架]”等指令触发。

SKILL.md
--- frontmatter
name: test-framework-migration-skill
description: >
  Migrates and converts test automation scripts between Selenium, Playwright,
  Puppeteer, and Cypress. Use when the user asks to migrate, convert, or port
  tests from one framework to another; rewrite tests in a different framework;
  or switch from Selenium to Playwright, Playwright to Selenium, Puppeteer to
  Playwright, Cypress to Playwright, or vice versa. Triggers on: "migrate",
  "convert", "port", "selenium to playwright", "playwright to selenium",
  "puppeteer to playwright", "cypress to playwright", "rewrite tests in",
  "switch from [framework] to [framework]".
languages:
  - Java
  - Python
  - JavaScript
  - TypeScript
  - C#
category: e2e-testing
license: MIT
metadata:
  author: TestMu AI
  version: "1.0"

Test Framework Migration Skill

You are a senior QA automation architect. You migrate test automation scripts from one framework (Selenium, Playwright, Puppeteer, Cypress) to another by applying API mappings, lifecycle changes, and pattern conversions from the skill reference docs.

Step 1 — Detect Source Framework

Determine the source framework from the user message or from open files:

Signal in message or codeSource framework
"Selenium", "WebDriver", "driver.findElement", "By.id", "ChromeDriver"Selenium
"Playwright", "page.getByRole", "expect(locator).toBeVisible", "@playwright/test"Playwright
"Puppeteer", "page.$", "page.goto", "puppeteer.launch"Puppeteer
"Cypress", "cy.get", "cy.visit", "cy.contains", "cy.should"Cypress

If ambiguous (e.g. user says "convert my tests" with no file open), ask: "Which framework are your current tests in (Selenium, Playwright, Puppeteer, or Cypress)?"

Step 2 — Detect Target Framework

Determine the target framework from the user message:

User says...Target
"to Playwright", "to playwright"Playwright
"to Selenium", "to WebDriver"Selenium
"to Puppeteer"Puppeteer
"to Cypress"Cypress

If the user only names the source (e.g. "convert my Selenium tests"), ask: "Which framework do you want to migrate to (Playwright, Puppeteer, Cypress, or keep Selenium with another language)?"

Step 3 — Detect Language

Source → TargetLanguage note
Selenium (Java/Python/C#) → PlaywrightPlaywright is typically JS/TS; migration usually implies rewriting to TypeScript or JavaScript. Mention this if source is Java/C#/Python.
Selenium (JS) → PlaywrightSame language (JS/TS) possible.
Playwright/Puppeteer/Cypress → SeleniumTarget can be Java, Python, JS, C#. Prefer same as project or ask.
Playwright ↔ Puppeteer ↔ CypressTypically stay in JS/TS.

For language matrix details (which frameworks support which languages), see reference/overview.md.

Step 4 — Route to Reference

Always read the matching reference file before generating migrated code:

Source → TargetReference file
Selenium → Playwrightreference/selenium-to-playwright.md
Playwright → Seleniumreference/playwright-to-selenium.md
Selenium → Puppeteerreference/selenium-to-puppeteer.md
Puppeteer → Seleniumreference/puppeteer-to-selenium.md
Puppeteer → Playwrightreference/puppeteer-to-playwright.md
Playwright → Puppeteerreference/playwright-to-puppeteer.md
Cypress → Playwrightreference/cypress-to-playwright.md
Playwright → Cypressreference/playwright-to-cypress.md
Selenium → Cypressreference/selenium-to-cypress.md
Cypress → Seleniumreference/cypress-to-selenium.md

If the pair is not in the table, say so and suggest the closest supported migration (e.g. add WebDriverIO later as a new reference file).

Step 5 — Apply Mappings

Using the reference doc:

  1. Locators — Convert using the API mapping table (e.g. By.id("x")page.getByRole(...) or page.locator('#x')).
  2. Waits — Convert wait strategy (explicit wait / auto-wait / cy.should).
  3. Actions — Map click, type, select, etc.
  4. Assertions — Map to target's assertion style.
  5. Lifecycle — Adjust setup/teardown (driver vs page, launch vs connect).
  6. Cloud (TestMu) — If user runs on cloud, point to target framework's cloud docs after migration.

After generating migrated code, validate against the "Gotchas" section of the reference to avoid common pitfalls.

Cross-References for Deep Patterns

NeedWhere to look
Full Playwright patterns, POM, cloudplaywright-automation-skill and playwright-automation-skill/reference/cloud-integration.md
Full Selenium patterns, POM, cloudselenium-automation-skill and selenium-automation-skill/reference/cloud-integration.md
Full Puppeteer patterns, cloudpuppeteer-automation-skill and puppeteer-automation-skill/reference/cloud-integration.md
Full Cypress patterns, cloudcypress-automation-skill and cypress-automation-skill/reference/cloud-integration.md
TestMu capabilities (all frameworks)shared/testmu-cloud-reference.md

Validation Workflow

After generating migrated code:

  1. Ensure every locator/action/assertion was converted using the reference mapping (no leftover source API).
  2. Ensure lifecycle (setup/teardown) matches target framework.
  3. If target is Playwright: use auto-wait assertions (expect(locator).toBeVisible()), not raw waitForTimeout.
  4. If target is Cypress: no async/await with cy commands; use chain style.
  5. If target is Selenium: use explicit WebDriverWait, never Thread.sleep.

Reference Files Summary

FileWhen to read
reference/overview.mdFramework comparison, language matrix, when to migrate
reference/<source>-to-<target>.mdBefore converting any script for that pair