From PRD-Driven Context Engineering
Documents development environment requirements including CLIs, packages, and configurations for team consistency and onboarding. Triggers on "environment setup", "dev environment", or "what tools do I need?".
How this skill is triggered — by the user, by Claude, or both
Slash command
/prd-ce:prd-v06-environment-setupThis skill is limited to the following tools:
The summary Claude sees in its skill listing — used to decide when to auto-load this skill
Position in workflow: v0.6 Architecture Design / Technical Specification → **v0.6 Environment Setup** → v0.7 Build Execution
Position in workflow: v0.6 Architecture Design / Technical Specification → v0.6 Environment Setup → v0.7 Build Execution
Environment setup documents the tools, packages, and configurations developers need to work on the project. This eliminates environment drift and speeds up onboarding.
This skill requires prior work from v0.5-v0.6:
This skill assumes v0.5 Technical Stack Selection is complete with TECH- entries specifying the tech stack.
This skill creates/updates:
All ENV- entries are specifications, not confidence-based. They are:
Example ENV-001 entry (Development Environment):
ENV-001: Development Environment
Category: Development Setup
Status: Approved | Date: 2026-02-26
Owner: Engineering Team
Purpose:
Local development setup for team consistency and AI agent understanding.
CLIs (Global, install once):
- Node.js 20.x: https://nodejs.org — Language runtime
Install: `curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash && nvm install 20`
Verify: `node --version`
- mise: https://mise.jdx.dev — Version manager
Install: `curl https://mise.jdx.dev/install.sh | sh`
Verify: `mise --version`
Packages (Per-Project):
- typescript: Type checking (devDependency)
- eslint, prettier: Code quality (devDependencies)
- jest: Testing framework (devDependency)
- Listed in package.json, installed via: `npm install`
Configuration Files:
| File | Purpose |
|------|---------|
| package.json | Dependencies, scripts, project metadata |
| tsconfig.json | TypeScript compiler options |
| .eslintrc.json | Linting rules |
| .prettierrc | Code formatting rules |
| .env.example | Template for environment variables |
Scripts:
{
"validate": "npm run lint && npm run type-check",
"lint": "eslint src/",
"fix": "eslint src/ --fix && prettier --write src/",
"type-check": "tsc --noEmit",
"test": "jest",
"dev": "next dev",
"build": "next build"
}
Verification:
# 1. Check global CLIs
node --version
mise --version
# 2. Check per-project packages
npm list | head -20
# 3. Run validation
npm run validate
# 4. Run tests
npm run test
Related IDs: TECH-001 (Next.js), TECH-002 (TypeScript), ARC-001 (monolith structure)
Example ENV-002 entry (CI/CD):
ENV-002: CI/CD Pipeline
Category: Automation
Status: Approved | Date: 2026-02-26
Purpose:
Automated testing and deployment configuration.
Workflow Files:
- .github/workflows/test.yml: Run tests on push to any branch
- .github/workflows/deploy.yml: Deploy main branch to production on merge
Required Secrets (set in GitHub Settings → Secrets):
| Secret | Purpose |
|--------|---------|
| VERCEL_TOKEN | Authentication for Vercel deployment |
| DATABASE_URL | Production database connection string |
| API_KEY | Third-party API credentials |
Pipeline Stages:
1. Install: `npm install`
2. Lint: `npm run validate` (must pass)
3. Test: `npm run test` (must pass)
4. Build: `npm run build` (must succeed)
5. Deploy: Push to Vercel (main branch only)
Related IDs: ENV-001, TECH-002 (Node.js), ARC-001 (monolith deployment)
| Type | What It Defines | When Required |
|---|---|---|
| ENV-001 | Development environment (local setup) | Always |
| ENV-002 | CI/CD pipeline configuration | When using automated testing/deployment |
| ENV-003 | Production infrastructure | When deploying to production |
Rule: ENV-001 (Development Environment) is required for every project. ENV-002 and ENV-003 are optional based on project needs.
Rule: Use CLIs for operations, MCPs only when CLIs are insufficient.
| Factor | CLI | MCP |
|---|---|---|
| Works in CI/CD | Yes | No |
| Works locally | Yes | Yes (limited contexts) |
| Structured output | JSON, exit codes | Varies |
| Debugging | Standard tools | Harder |
Decision: Default to CLI. Only document MCPs for operations where CLIs don't exist.
Rule: Language-specific packages installed per-project, not globally.
Global (OK):
Per-Project (Required):
Rule: ENV- specs use structured data (tables, code blocks), not narrative.
Why:
Rule: Every ENV- spec includes verification commands.
Why:
ENV-001: Development Environment
Category: Development Setup
Status: Approved | Date: YYYY-MM-DD
Owner: {Team/Person}
Purpose:
Document local development requirements for team consistency.
CLIs (Global):
- {tool}: {purpose} — {install command}
Packages (Per-Project):
- {package}: {purpose}
Configuration Files:
| File | Purpose |
|------|---------|
| {file} | {purpose} |
Scripts:
{
"validate": "{quality check command}",
"fix": "{auto-fix command}",
"test": "{test command}"
}
Verification:
# 1. Check tools
{tool} --version
# 2. Check packages
{package manager list command}
# 3. Run validation
npm run validate
Related IDs: TECH-XXX, ARC-XXX
ENV-002: CI/CD Pipeline
Category: Automation
Status: Approved | Date: YYYY-MM-DD
Purpose:
Document automated testing and deployment configuration.
Workflow Files:
- {path}: {purpose}
Required Secrets:
| Secret | Purpose | Where to Set |
|--------|---------|--------------|
| {name} | {purpose} | {location} |
Pipeline Stages:
1. {Stage}: {What happens}
2. {Stage}: {What happens}
Related IDs: ENV-001, DEP-XXX
ENV-003: Production Infrastructure
Category: Infrastructure
Status: Approved | Date: YYYY-MM-DD
Purpose:
Document production hosting and services configuration.
Hosting Platform:
{Platform and configuration details}
Environment Variables:
| Variable | Purpose | Required |
|----------|---------|----------|
| {name} | {purpose} | {yes/no} |
Services:
| Service | Purpose | Connection |
|---------|---------|------------|
| {service} | {purpose} | {how connected} |
Related IDs: DEP-XXX, MON-XXX
mise, asdf, nvm, pyenv, rbenveslint, prettier, biomeruff, black, pylintgolangci-linttypescriptmypy, pyrightjq (JSON), yq (YAML)httpie, curl, bruno-cligh (GitHub CLI), glab (GitLab CLI)| Anti-Pattern | Signal | Fix |
|---|---|---|
| Global package pollution | npm install -g for project packages | Use devDependencies |
| Missing verification | No way to confirm setup | Add verification commands |
| Prose instead of structure | Long paragraphs describing setup | Use tables and code blocks |
| MCP over CLI | Using MCP when CLI exists | Prefer CLI for portability |
| Undocumented config | Config files without explanation | Document purpose of each file |
| Implicit dependencies | Setup fails without warning | List all dependencies explicitly |
Before proceeding to Build Execution:
ENV- entries feed into:
| Consumer | What It Uses | Example |
|---|---|---|
| v0.7 Build Execution | ENV-001 defines dev setup | Developer follows ENV-001 to set up |
| Onboarding | ENV-001 as setup guide | New dev uses ENV-001 for first day |
| CI/CD | ENV-002 defines pipeline | GitHub Actions mirrors ENV-002 |
| Deployment | ENV-003 defines infrastructure | DEP- references ENV-003 |
assets/env.mdreferences/examples.mdnpx claudepluginhub mattgierhart/prd-driven-context-engineering --plugin prd-ceDefines standardized development environments or onboards developers by generating setup scripts, container configs, CI workflows, toolchain pins, and dev-setup documents.
Generates a complete local development setup guide for any service or project, walking a new engineer from zero to passing tests in under 30 minutes.
Generates CI/CD workflows, Dockerfiles, and deployment configs from a tech stack definition. Use when scaffolding infrastructure for a project.