A Model Context Protocol (MCP) server that generates Playwright visual testing scripts from CSV data with advanced configuration management, environment switching capabilities, and organized code structure.
This MCP server provides automated generation of Playwright visual testing scripts, helping developers quickly create comprehensive UI test suites from CSV test specifications. It includes automatic Playwright configuration validation, organized folder structure creation, intelligent code generation following best practices, and environment switching capabilities for multi-environment testing.
# Install globally for system-wide access
npm install -g ui-test-gen-mcp
# Or install locally in your project
npm install ui-test-gen-mcp
# Clone the repository
git clone <repository-url>
cd ui-test-gen-mcp
# Install dependencies
npm install
# Build the TypeScript code
npm run build
ui-test-gen-mcp/
βββ main.ts # MCP server entry point
βββ tools/
β βββ index.ts # Tool exports
β βββ visual-test-generator.ts # Main test generation tool
β βββ tool-lister.ts # Tool listing utility
βββ helper/
β βββ index.ts # Helper function exports
β βββ template.ts # Test templates and tag definitions
β βββ test-tags.ts # Tag utility functions
β βββ env-config.ts # Environment configuration helpers
β βββ test-data.ts # Test data management
β βββ register.ts # Tool registration helper
βββ data/
β βββ core-test-script.content.txt # Test script template
β βββ template-usage-guide.md # Template usage documentation
βββ dist/ # Compiled JavaScript output
Purpose: Generate comprehensive Playwright visual testing scripts from CSV data
Features:
- Automatic Playwright Config Validation: Checks and updates
playwright.config.ts
for propersnapshotDir
configuration - Organized Folder Structure: Creates
./tests/ui/
,./utils/ui/
,./data/ui/
, and./pages/ui/
directories - CSV-Based Test Generation: Processes CSV data to create test files following a strict template
- Environment Switching: NEW - Single test file handles multiple environments (prep, int, qa, prod, etc.)
- Smart Code Organization: Extracts utilities and organizes code during refactoring phase
- Project Style Integration: Analyzes existing code to match project's coding conventions
- Improved Tag System: NEW - Pre-calculated tag constants instead of function calls
Input Schema:
{
csvData: string // CSV content with test information
}
Required CSV Columns:
file_name
: Name for the generated test filetest_url
: URL to testtest_description
: Description of what to testtest_selector
: CSS selector for the elementtest_hide
: Elements to hide during testing (component-specific)test_action
: Action to perform (optional)test_env
: NEW - Environment name (prep, int, qa, prod, staging, etc.)
Purpose: Display all available tools with simple descriptions
Usage: Call this tool to see what's available in the MCP server
- Automatically validates
playwright.config.ts
files - Ensures
snapshotDir
is set to"./__screenshots__"
- Updates configuration if missing or incorrect (only modifies snapshotDir)
- Single Test File: One test file per component handles all environments
- Dynamic Environment Config: Environment configuration generated from CSV data
- User-Controlled Switching: Users manually configure environment selection
- Flexible Environment Support: Supports any environment name (prep, int, qa, prod, staging, etc.)
- Clean Paths:
__screenshots__/fileName/fileName.png
format - No Environment Nesting: Simple, clean structure without unnecessary directories
- Consistent Naming: Predictable and maintainable screenshot organization
- Pre-calculated Constants: Uses
fullPageTags
andsectionTags
constants - No Function Calls: Eliminates
getTagsForSelector()
function calls - Proper Playwright Syntax: Implements tags using
test('Name', { tag: tags }, async ({ page }) => {})
- Automatic Tag Selection: Body selector gets
fullPageTags
, others getsectionTags
./tests/ui/
- Generated test files (single file per component)./utils/ui/
- Utility functions organized by type:selectors.ts
- Reusable selectors and constantshelpers.ts
- Common helper functionstest-actions.ts
- Generated test action functionspage-objects.ts
- Page object model patternsvalidation.ts
- Validation and error handlingenv-config.ts
- NEW Environment configuration utilitiestest-tags.ts
- NEW Tag management utilities
./data/ui/
- Test data and configuration./pages/ui/
- Page object classes and locators
- Follows the embedded core test script template strictly
- Generates proper test action functions following Playwright best practices
- Preserves component-specific test_hide selectors
- Maintains separation between test files and utility/data files
The server uses a mandatory core test script template that ensures consistency:
- Standard Playwright test structure
- Proper screenshot handling with
toMatchSnapshot
- Element hiding for clean visual testing
- Scroll handling for element visibility
- Proper tag implementation
- Locate
playwright.config.ts
files in the project - Verify
snapshotDir
is set to"./__screenshots__"
- Update configuration if necessary
- Parse CSV data for test specifications
- Detect environment column and use appropriate template
- Create single test file per component in
./tests/ui/
folder - Apply the core test script template with environment switching
- Replace template variables with CSV data
- Create organized folder structure
- Generate utility files in appropriate locations
- Create data and page object files
- Generate environment configuration files
- Extract common utilities to grouped files
- Organize code for maintainability
- Follow project's existing coding style
- Ensure proper separation of concerns
- Implement proper tag system
- Node.js (v18 or higher)
- npm or yarn
- Playwright installed in your project
-
Install the package:
npm install ui-test-gen-mcp
-
Configure your MCP client (e.g., Cursor, VS Code with MCP extension):
{ "mcpServers": { "ui-test-gen-mcp": { "command": "npx", "args": ["-y", "ui-test-gen-mcp"] } } }
-
Alternative configuration (if using local installation):
{ "mcpServers": { "ui-test-gen-mcp": { "command": "node", "args": ["./node_modules/ui-test-gen-mcp/dist/main.js"] } } }
-
Restart your MCP client to load the new server
If you're developing or want to run from source:
# Start development mode with auto-reload
npm run dev
# Build for production
npm run build
# Start the built server
npm start
Add to your Cursor settings:
{
"mcpServers": {
"ui-test-gen-mcp": {
"command": "npx",
"args": ["-y", "ui-test-gen-mcp"]
}
}
}
Add to your VS Code settings:
{
"mcp.servers": {
"ui-test-gen-mcp": {
"command": "npx",
"args": ["ui-test-gen-mcp"]
}
}
}
{
"mcpServers": {
"ui-test-gen-mcp": {
"command": "npx",
"args": ["-y", "ui-test-gen-mcp"]
}
}
}
Test the MCP connection:
# If installed globally
ui-test-gen-mcp
# If installed locally
npx ui-test-gen-mcp
# If running from source
node test-connection.js
file_name,test_url,test_description,test_selector,test_hide,test_action
homepage,https://example.com,Homepage hero section,.hero-section,.ad-banner,click
product,https://example.com/product,Product image,.product-image,.cookie-banner,screenshot
file_name,test_url,test_description,test_selector,test_hide,test_action,test_env
pdp,https://prep.example.com/product,PDP Full Page,body,.banner,.modal,prep
pdp,https://int.example.com/product,PDP Full Page,body,.banner,.modal,int
pdp,https://qa.example.com/product,PDP Full Page,body,.banner,.modal,qa
Once configured, you can use the MCP server to:
-
Generate tests from CSV data:
- Call
create_playwright_visual_tests
with your CSV content - The server will automatically create test files and folder structure
- Call
-
List available tools:
- Call
list_tools
to see what's available
- Call
file_name,test_url,test_description,test_selector,test_hide,test_action,test_env
landing,https://myapp.com,Landing page header,.header-section,.notification-banner,screenshot,prep
dashboard,https://myapp.com/dashboard,Dashboard sidebar,.sidebar-nav,.ads-container,click,int
The server will create:
./tests/ui/landing.spec.ts
- Single test file for landing page (handles all environments)./tests/ui/dashboard.spec.ts
- Single test file for dashboard (handles all environments)./utils/ui/
- Organized utility files including environment config./data/ui/
- Test data files./pages/ui/
- Page object classes
// Generated test file with environment switching
test.describe('Landing - Visual testing', () => {
test('Landing page header', {
tag: sectionTags // Pre-calculated constant, no function call
}, async ({ page }) => {
const testData = landingTestData.find(t =>
t.test_description === 'Landing page header' &&
t.test_env === getCurrentEnv()
);
if (!testData) throw new Error('Test data not found');
await page.goto(testData.test_url);
// Hide elements specific to this component
await hideElements(page, testData.test_hide);
const locator = page.locator(testData.test_selector);
await locator.scrollIntoViewIfNeeded();
// Clean screenshot path structure
const fileName = generateFileName(testData.test_description);
expect(await locator.screenshot()).toMatchSnapshot(`${fileName}/${fileName}.png`);
});
});
- The core test script template is mandatory and non-negotiable
- Never deviate from the template structure
- Always use exact import statements and test patterns
- Single Test File: One test file per component handles all environments
- User Control: Users manually configure environment selection
- No Automatic Switching:
switchEnvironment()
calls are not automatically generated - Flexible Implementation: Users implement
getCurrentEnv()
based on their configuration
- No Function Calls: Tags use pre-calculated constants (
fullPageTags
,sectionTags
) - Proper Syntax: Implements Playwright tag syntax correctly
- Automatic Selection: Body selector gets
fullPageTags
, others getsectionTags
- Each CSV component maintains its own
test_hide
selectors - No cross-component selector sharing
- Preserve component-specific configurations during refactoring
- Test files must be created in
./tests/ui/
folder - Utilities must be organized in appropriate grouped files
- Data files and page objects must be separate from
.spec.ts
files
- Rapid Test Creation: Generate comprehensive test suites from CSV data
- Consistent Structure: Enforced template compliance ensures consistency
- Professional Organization: Industry-standard folder structure
- Automatic Configuration: Playwright config validation and updates
- Maintainable Code: Clean, organized, and well-structured test files
- Project Integration: Follows existing project coding styles and conventions
- Easy Installation: Available as npm package for quick setup
- Environment Support: NEW - Single test file handles multiple environments
- Clean Screenshots: NEW - Simple, organized screenshot paths
- Proper Tags: NEW - No function calls, uses pre-calculated constants
- MCP Connection Failed: Ensure the server is installed and configured correctly
- Template Errors: Verify CSV data follows required format
- Configuration Issues: Check that
playwright.config.ts
exists and is editable - Folder Creation Errors: Ensure write permissions in the project directory
- Environment Issues: NEW - Verify
test_env
column is present in CSV for environment switching
- Verify installation:
npm list ui-test-gen-mcp
- Test MCP connection:
npx ui-test-gen-mcp
- Check console logs for error messages
- Verify CSV data format and content
- Ensure project structure is properly set up
- Check for environment column in CSV data
- Model Context Protocol Documentation
- Playwright Testing Framework
- TypeScript Documentation
- npm Package Page
Contributions are welcome! Please ensure:
- Code follows existing patterns and style
- Tests are updated for new features
- Documentation is kept current
ISC License - see package.json for details
Note: This MCP server is designed for generating Playwright visual testing scripts with environment switching capabilities. Ensure you have Playwright properly configured in your project before using the generated tests.
Package: Available on npm as ui-test-gen-mcp
Recent Updates:
- β Environment switching capabilities
- β Improved screenshot path structure
- β Enhanced tag system (no function calls)
- β Single test file per component
- β User-controlled environment configuration