Faker MCP Server
Generates realistic mock data using Faker.js for database seeding, API testing, and development environments. Supports person/company data, custom patterns, multi-locale generation, and structured datasets with referential integrity.
README
Faker MCP Server
A Model Context Protocol (MCP) server that provides fake/mock data generation capabilities using the Faker.js library. Generate realistic test data for database seeding, API testing, demo applications, and development environments.
Read more about why and when to use this MCP server in my blog post.
Features
- Basic Data Generation: Generate realistic person and company data with names, emails, addresses, and contact information
- Structured Datasets: Create multi-entity datasets with referential integrity for complex testing scenarios
- Custom Patterns: Generate data following custom patterns (regex, enum, format, range) for domain-specific requirements
- Multi-locale Support: Generate data in English, French, German, Spanish, and Japanese
- Reproducible Data: Seed-based generation for consistent test data
- High Performance: Generate 1000+ records per second
- MCP Protocol Compliant: Seamlessly integrates with MCP-compatible clients
Installation
Prerequisites
- Node.js 18+ installed on your system
- An MCP-compatible client (e.g., Claude Desktop, Cline, Cursor or any MCP client)
Quick Start
Add the Faker MCP server to the mcpServers section:
{
"mcpServers": {
"faker": {
"command": "npx",
"args": ["faker-mcp-server"]
}
}
}
See the MCP Client Configurations section for detailed setup instructions for various MCP clients.
Available Tools
The Faker MCP Server provides four powerful tools for generating fake data:
1. generate-person
Generate realistic person data including names, emails, phone numbers, and addresses.
Parameters:
count(number, optional): Number of person records to generate (1-10,000, default: 1)locale(string, optional): Locale for generated data -en,fr,de,es,ja(default:en)seed(number, optional): Seed for reproducible generationincludeAddress(boolean, optional): Whether to include address information (default:true)includePhone(boolean, optional): Whether to include phone number (default:true)includeDateOfBirth(boolean, optional): Whether to include date of birth (default:false)
Example Usage:
Generate 10 fake person records with names, emails, and addresses
Example Request (MCP protocol):
{
"method": "tools/call",
"params": {
"name": "generate-person",
"arguments": {
"count": 5,
"locale": "en",
"seed": 12345,
"includeAddress": true,
"includePhone": true,
"includeDateOfBirth": false
}
}
}
Sample Output:
[
{
"id": "person_12345_0",
"firstName": "John",
"lastName": "Doe",
"fullName": "John Doe",
"email": "john.doe@example.com",
"phone": "+1-555-123-4567",
"address": {
"street": "123 Main St",
"city": "Springfield",
"state": "IL",
"postalCode": "62701",
"country": "United States"
}
}
]
2. generate-company
Generate realistic company data including names, industries, contact information, and addresses.
Parameters:
count(number, optional): Number of company records to generate (1-10,000, default: 1)locale(string, optional): Locale for generated data -en,fr,de,es,ja(default:en)seed(number, optional): Seed for reproducible generationincludeAddress(boolean, optional): Whether to include address information (default:true)includeWebsite(boolean, optional): Whether to include website URL (default:true)includeFoundedYear(boolean, optional): Whether to include founded year (default:false)includeEmployeeCount(boolean, optional): Whether to include employee count (default:false)
Example Usage:
Generate 5 company records with seed 54321 for reproducibility
Example Request (MCP protocol):
{
"method": "tools/call",
"params": {
"name": "generate-company",
"arguments": {
"count": 3,
"locale": "en",
"seed": 54321,
"includeAddress": true,
"includeWebsite": true,
"includeFoundedYear": true,
"includeEmployeeCount": true
}
}
}
Sample Output:
[
{
"id": "company_54321_0",
"name": "Acme Corporation",
"industry": "Technology",
"email": "contact@acme.example.com",
"phone": "+1-555-111-2222",
"website": "https://acme.example.com",
"address": {
"street": "100 Tech Blvd",
"city": "San Francisco",
"state": "CA",
"postalCode": "94105",
"country": "United States"
},
"founded": 2010,
"employeeCount": 250
}
]
3. generate-dataset
Generate structured datasets with multiple entity types and referential integrity between them.
Parameters:
schema(object, required): Dataset schema defining entities and relationshipsentities(object): Map of entity names to entity definitionscount(number): Number of records to generate for this entity (1-10,000)type(string): Entity type -person,company, orcustomfields(array, optional): List of fields to include (defaults to all)relationships(object, optional): Foreign key relationships to other entitiesreferences(string): Name of the parent entitytype(string): Relationship type -one-to-manyormany-to-manynullable(boolean, optional): Whether the foreign key can be null (default:false)
locale(string, optional): Locale for generated data -en,fr,de,es,ja(default:en)seed(number, optional): Seed for reproducible generation
Example Usage:
Generate a dataset with 20 users and 100 orders, where each order references a user
Example Request (MCP protocol):
{
"method": "tools/call",
"params": {
"name": "generate-dataset",
"arguments": {
"schema": {
"entities": {
"users": {
"count": 10,
"type": "person",
"fields": ["id", "fullName", "email", "phone"]
},
"orders": {
"count": 30,
"type": "custom",
"fields": ["id", "userId", "productName", "price", "orderDate"],
"relationships": {
"userId": {
"references": "users",
"type": "one-to-many",
"nullable": false
}
}
}
}
},
"locale": "en",
"seed": 99999
}
}
}
Sample Output:
{
"users": [
{
"id": "user_99999_0",
"fullName": "John Doe",
"email": "john.doe@example.com",
"phone": "+1-555-100-0001"
},
{
"id": "user_99999_1",
"fullName": "Jane Smith",
"email": "jane.smith@example.com",
"phone": "+1-555-100-0002"
}
],
"orders": [
{
"id": "order_99999_0",
"userId": "user_99999_0",
"productName": "Laptop",
"price": 1299.99,
"orderDate": "2024-03-15"
},
{
"id": "order_99999_1",
"userId": "user_99999_0",
"productName": "Mouse",
"price": 29.99,
"orderDate": "2024-03-16"
},
{
"id": "order_99999_2",
"userId": "user_99999_1",
"productName": "Keyboard",
"price": 89.99,
"orderDate": "2024-03-17"
}
]
}
4. generate-custom
Generate data following custom patterns including regex patterns, enums, formats, and ranges.
Parameters:
count(number, optional): Number of records to generate (1-10,000, default: 1)patterns(object, required): Map of field names to pattern definitionstype(string): Pattern type -regex,enum,format, orrangevalue: Pattern value (depends on pattern type):regex: Regular expression string (e.g.,"PRD-[0-9]{4}-[A-Z]{2}")enum: Array of string values to choose from (e.g.,["pending", "active", "completed"])format: Template string with placeholders (e.g.,"REF-{{year}}-{{random:5}}")range: Object withminandmaxnumeric values (e.g.,{"min": 10, "max": 1000})
locale(string, optional): Locale for generated data - affects format-based patterns (default:en)seed(number, optional): Seed for reproducible generation
Example Usage:
Generate 50 product records with codes matching pattern PRD-####-XX where # is a digit and X is an uppercase letter
Example Request (MCP protocol):
{
"method": "tools/call",
"params": {
"name": "generate-custom",
"arguments": {
"count": 5,
"patterns": {
"productCode": {
"type": "regex",
"value": "PRD-[0-9]{4}-[A-Z]{2}"
},
"status": {
"type": "enum",
"value": ["pending", "active", "completed", "cancelled"]
},
"price": {
"type": "range",
"value": { "min": 10, "max": 1000 }
},
"reference": {
"type": "format",
"value": "REF-{{year}}-{{random:5}}"
}
},
"locale": "en",
"seed": 11111
}
}
}
Sample Output:
[
{
"id": "custom_11111_0",
"productCode": "PRD-1234-AB",
"status": "active",
"price": 456.78,
"reference": "REF-2024-A3B5C"
},
{
"id": "custom_11111_1",
"productCode": "PRD-5678-CD",
"status": "pending",
"price": 123.45,
"reference": "REF-2024-D7E9F"
}
]
Common Use Cases
Database Seeding
Generate realistic test data to populate development databases:
Generate a dataset with 100 users, 500 orders, and 1000 order items with proper relationships, using seed 100
API Integration Testing
Create test payloads with realistic data structures:
Generate 20 user registration payloads with emails, passwords, and profile information
UI Demo Data
Build demo environments with locale-specific data:
Generate French locale data: 50 customers with addresses and 200 orders for a demo e-commerce site
Performance Testing
Generate large volumes of data for load testing:
Generate 10000 person records for load testing my user import API
Best Practices
1. Use Seeds for Reproducibility
Always specify a seed when you need consistent test data across environments:
Generate 100 users with seed 12345
2. Choose Appropriate Locales
Match the locale to your target market for realistic data:
Generate 50 companies in German locale (de)
3. Batch Large Requests
For very large datasets, consider generating in batches:
Generate 3000 records with seed 111 (first batch)
Generate 3000 records with seed 222 (second batch)
Generate 3000 records with seed 333 (third batch)
4. Define Relationships Carefully
Ensure parent entities are generated before child entities:
{
"entities": {
"users": { "count": 10, "type": "person" },
"orders": {
"count": 50,
"type": "custom",
"relationships": {
"userId": { "references": "users", "type": "one-to-many" }
}
}
}
}
Performance Expectations
| Operation | Records | Expected Time | Memory Usage |
|---|---|---|---|
| Generate Person | 100 | <100ms | <5MB |
| Generate Person | 1,000 | <1s | <50MB |
| Generate Person | 10,000 | <10s | <100MB |
| Generate Company | 100 | <100ms | <5MB |
| Generate Dataset | 1,000 total | <2s | <50MB |
| Generate Custom | 1,000 | <1s | <30MB |
Performance may vary based on system resources and pattern complexity.
Error Handling
The server follows MCP standard error response format. Common errors include:
Invalid Parameters (code: -32602):
{
"error": {
"code": -32602,
"message": "Invalid count parameter: must be between 1 and 10000",
"data": {
"received": 50000,
"max": 10000
}
}
}
Unsupported Locale (code: -32001):
{
"error": {
"code": -32001,
"message": "Unsupported locale: zh. Supported locales: en, fr, de, es, ja",
"data": {
"received": "zh",
"supported": ["en", "fr", "de", "es", "ja"]
}
}
}
Schema Validation Error (code: -32602):
{
"error": {
"code": -32602,
"message": "Invalid schema: circular dependency detected in relationships",
"data": {
"cycle": ["orders", "items", "orders"]
}
}
}
MCP Client Configurations
Claude Desktop
Claude Desktop is an AI assistant application that supports MCP servers for extended functionality.
Configuration File Locations:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json - Linux:
~/.config/Claude/claude_desktop_config.json
Configuration:
{
"mcpServers": {
"faker": {
"command": "npx",
"args": ["faker-mcp-server"]
}
}
}
Alternative (using installed global package):
{
"mcpServers": {
"faker": {
"command": "faker-mcp-server",
"args": []
}
}
}
After configuration: Restart Claude Desktop. You can verify the connection by asking "What MCP tools are available?"
Cline (VS Code Extension)
Cline is a VS Code extension that brings AI assistance directly into your editor with MCP support.
Setup Steps:
- Install the Cline extension from VS Code Marketplace
- Open VS Code Settings (JSON) - Press
Cmd/Ctrl + Shift + P→ "Preferences: Open User Settings (JSON)" - Add the MCP server configuration:
{
"cline.mcpServers": {
"faker": {
"command": "npx",
"args": ["faker-mcp-server"],
"transport": "stdio"
}
}
}
Alternative (workspace-specific configuration):
Create or edit .vscode/settings.json in your project:
{
"cline.mcpServers": {
"faker": {
"command": "npx",
"args": ["faker-mcp-server"],
"transport": "stdio"
}
}
}
After configuration: Reload VS Code window or restart Cline extension.
Continue (VS Code Extension)
Continue is an open-source AI code assistant for VS Code with MCP support.
Configuration File Location: ~/.continue/config.json (or workspace-specific .continue/config.json)
Configuration:
{
"mcpServers": [
{
"name": "faker",
"command": "npx",
"args": ["faker-mcp-server"],
"transport": "stdio"
}
]
}
After configuration: Restart the Continue extension or reload VS Code.
Zed Editor
Zed is a high-performance code editor with built-in AI and MCP support.
Configuration File Location: ~/.config/zed/settings.json
Configuration:
{
"context_servers": {
"faker-mcp-server": {
"command": "npx",
"args": ["faker-mcp-server"]
}
}
}
After configuration: Restart Zed editor.
MCP Inspector (Development/Testing)
MCP Inspector is an official debugging tool for testing MCP servers during development.
Usage:
# Install MCP Inspector globally
npm install -g @modelcontextprotocol/inspector
# Run with Faker MCP Server
mcp-inspector npx faker-mcp-server
This will open a web interface at http://localhost:5173 where you can:
- Discover all available tools
- Test tool calls with custom parameters
- View request/response logs
- Validate MCP protocol compliance
Custom MCP Client (Generic Integration)
For any MCP-compatible client not listed above, use these configuration parameters:
Connection Parameters:
- Command:
npx faker-mcp-server(orfaker-mcp-serverif installed globally) - Transport:
stdio(standard input/output) - Protocol: MCP (Model Context Protocol)
- Environment: Node.js 18+ required
Generic JSON Configuration:
{
"command": "npx",
"args": ["faker-mcp-server"],
"transport": "stdio",
"env": {
"NODE_ENV": "production"
}
}
Using Absolute Path (when npx is not available):
{
"command": "/usr/local/bin/faker-mcp-server",
"args": [],
"transport": "stdio"
}
With Custom Node Path:
{
"command": "/usr/local/bin/node",
"args": ["/path/to/node_modules/.bin/faker-mcp-server"],
"transport": "stdio",
"env": {
"NODE_ENV": "production",
"NODE_OPTIONS": "--max-old-space-size=512"
}
}
Docker Container
For containerized environments or CI/CD pipelines:
Dockerfile:
FROM node:18-alpine
RUN npm install -g faker-mcp-server
CMD ["faker-mcp-server"]
Build and Run:
docker build -t faker-mcp-server .
docker run -i faker-mcp-server
Docker Compose (for integration with other services):
version: '3.8'
services:
faker-mcp:
image: node:18-alpine
command: npx faker-mcp-server
stdin_open: true
tty: true
Programmatic Usage (Node.js)
You can also use the MCP server programmatically in your Node.js applications:
import { spawn } from 'child_process';
// Start the MCP server process
const mcpServer = spawn('npx', ['faker-mcp-server'], {
stdio: ['pipe', 'pipe', 'inherit']
});
// Send MCP request to generate person data
const request = {
jsonrpc: '2.0',
id: 1,
method: 'tools/call',
params: {
name: 'generate-person',
arguments: {
count: 5,
locale: 'en',
seed: 12345
}
}
};
mcpServer.stdin.write(JSON.stringify(request) + '\n');
// Read response
mcpServer.stdout.on('data', (data) => {
const response = JSON.parse(data.toString());
console.log('Generated data:', response.result);
});
Configuration Troubleshooting
Problem: "Command not found: faker-mcp-server"
Solutions:
- Use
npx faker-mcp-serverinstead offaker-mcp-server - Install globally first:
npm install -g faker-mcp-server - Use absolute path to the binary
Problem: "MCP server connection timeout"
Solutions:
- Verify Node.js 18+ is installed:
node --version - Check if server starts manually:
npx faker-mcp-server - Review client logs for specific error messages
- Ensure no firewall/antivirus blocking Node.js processes
Problem: "Invalid JSON response from server"
Solutions:
- Ensure transport is set to
stdio(nothttporsse) - Check Node.js version compatibility (requires 18+)
- Verify no other process is using stdio streams
Platform-Specific Notes
macOS:
- Configuration files typically in
~/Library/Application Support/ - Use Homebrew for Node.js:
brew install node@18
Windows:
- Configuration files typically in
%APPDATA%\or%USERPROFILE%\.config\ - Use Node.js installer from nodejs.org or
nvm-windows - Use forward slashes or escaped backslashes in JSON paths
Linux:
- Configuration files typically in
~/.config/ - Use nvm for Node.js version management
- Ensure execute permissions:
chmod +x /path/to/faker-mcp-server
Troubleshooting
"MCP server not found"
Cause: Server not properly installed or configured.
Solution:
- Verify installation:
npm list -g faker-mcp-server - Check MCP client configuration file for correct command
- Restart MCP client after configuration changes
"Invalid locale error"
Cause: Requested locale not supported.
Solution: Use one of the supported locales: en, fr, de, es, ja
"Request timeout for large datasets"
Cause: Generating >5000 records may take several seconds.
Solution:
- Use smaller batch sizes
- Be patient (10,000 records typically takes <10 seconds)
- Check memory constraints if timeouts persist
"Referential integrity errors in dataset"
Cause: Schema defines relationships in wrong order or circular dependencies.
Solution:
- Define parent entities before child entities
- Avoid circular references
- Validate schema before generation
Development
Setup
# Clone the repository
git clone <repository-url>
cd faker-mcp
# Install dependencies
npm install
# Run tests
npm test
# Build the project
npm run build
# Run in development mode
npm run dev
Scripts
npm run build- Build the project for productionnpm run dev- Build in watch mode for developmentnpm test- Run tests oncenpm run test:watch- Run tests in watch modenpm run test:coverage- Run tests with coverage reportnpm run lint- Lint the codenpm run lint:fix- Lint and fix issuesnpm run format- Format code with Prettiernpm run typecheck- Type-check without emitting
License
MIT
Author
Funs Janssen
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
E2B
Using MCP to run code via e2b.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Neon Database
MCP server for interacting with Neon Management API and databases