An MCP (Model Context Protocol) server that helps enforce development discipline and workflow best practices. This server acts as your coding conscience, reminding you to follow proper development workflows.
This MCP server guides you through a disciplined development workflow:
- Start Conscious - Be clear about what you're coding
- Fix/Implement - Write your code
- Create Tests - Always test your changes
- Run Tests - Tests must pass (GREEN)
- Document - Update documentation
- Commit & Push - Let the server drive the git commands once verification passes
- Release - Record the release details before closing out the task
npm installPoint your MCP client to the server entry point. Replace <PROJECT_ROOT> with the absolute path to this repository on your machine.
- Windsurf (~/Library/Application Support/Windsurf/config.json):
{
  "mcpServers": {
    "dev-workflow": {
      "command": "node",
      "args": ["<PROJECT_ROOT>/index.js"]
    }
  }
}- Claude Desktop (~/Library/Application Support/Claude/claude_desktop_config.json):
{
  "mcpServers": {
    "dev-workflow": {
      "command": "node",
      "args": ["<PROJECT_ROOT>/index.js"]
    }
  }
}- Windsurf (%APPDATA%\Windsurf\config.json):
{
  "mcpServers": {
    "dev-workflow": {
      "command": "node",
      "args": ["<PROJECT_ROOT>\\index.js"]
    }
  }
}- Claude Desktop (%APPDATA%\Claude\claude_desktop_config.json):
{
  "mcpServers": {
    "dev-workflow": {
      "command": "node",
      "args": ["<PROJECT_ROOT>\\index.js"]
    }
  }
}- Windsurf (~/.config/windsurf/config.json):
{
  "mcpServers": {
    "dev-workflow": {
      "command": "node",
      "args": ["<PROJECT_ROOT>/index.js"]
    }
  }
}- Claude Desktop (~/.config/claude/claude_desktop_config.json):
{
  "mcpServers": {
    "dev-workflow": {
      "command": "node",
      "args": ["<PROJECT_ROOT>/index.js"]
    }
  }
}Note: On Windows paths in JSON require escaped backslashes (e.g.,
"C:\\path\\to\\project").
After adding the configuration, restart the application to load the MCP server.
All tool invocations validate their arguments payload before running:
- Strings are parsed as JSON and must resolve to an object (key/value pairs).
- Passing non-object data (numbers, arrays, plain text) triggers a guidance error.
- Missing or malformed arguments safely default to empty input so the tool can respond with actionable reminders.
Example (stringified JSON object):
{
  "name": "start_task",
  "arguments": "{\"description\":\"Add reporting endpoint\",\"type\":\"feature\"}"
}
Start a new coding task. This is your first step - be conscious about what you're coding.
Parameters:
- description(string, required): Clear description of what you're going to code
- type(enum, required): Type of task - "feature", "bugfix", "refactor", or "other"
Example:
Use the start_task tool with:
- description: "Add user authentication to the login page"
- type: "feature"
Mark that the bug/feature is fixed. Reminder: Now you MUST create tests!
Parameters:
- summary(string, required): Brief summary of what was fixed/implemented
Confirm that you've created the necessary tests covering your change. Required before recording test results.
Parameters: none
Record an explicit justification when automated tests aren't feasible. Marks testing as satisfied so you can proceed with documentation and verification, while flagging the task for manual QA.
Parameters:
- reason(string, required): Why automated tests were skipped
Record test results. NEVER commit if tests fail! Only proceed if all tests are green.
Parameters:
- passed(boolean, required): Did all tests pass?
- testCommand(string, required): The test command that was run
- details(string, optional): Test results details
Example:
Use run_tests with:
- passed: true
- testCommand: "npm test"
- details: "All 15 tests passed"
Mark that documentation has been created/updated. This is required before committing.
Parameters:
- documentationType(enum, required): "README", "inline-comments", "API-docs", "changelog", or "other"
- summary(string, required): What was documented
Check if all workflow steps are completed and you're ready to commit & push.
Automatically run git add, git commit, and git push after the ready check passes.
Parameters:
- commitMessage(string, required): Conventional commit message to use
- branch(string, optional): Target branch to push (defaults to current branch)
Record the release after you've committed and pushed. Required before you can complete the task.
Parameters:
- command(string, required): Release command that was executed (e.g.,- npm run release)
- notes(string, optional): Additional release notes
Mark the task as complete after successful commit & push. Resets workflow for next task.
Parameters:
- commitMessage(string, required): The commit message used
Abandon the current task without completing the workflow. Preserves an audit entry with context, then resets the state so you can start fresh.
Parameters:
- reason(string, optional): Additional detail about why the task was dropped
Get current workflow status and what needs to be done next.
View workflow history of completed tasks.
Parameters:
- limit(number, optional): Number of recent tasks to show (default: 10)
Get a complete reminder of the development workflow discipline.
Get a pre-commit checklist to ensure nothing is missed before committing.
Here's how you'd use this MCP server in a typical coding session:
- 
Start your task: Ask Cascade to use start_task: "Start a new task: implementing user profile page, type: feature"
- 
Code your feature/fix - Write your code as usual
 
- 
Mark as fixed: "Mark the feature as fixed: User profile page with avatar and bio completed"
- 
Create tests: - Write your tests
- The server will remind you this is mandatory!
 
- 
Run tests: "Record test results: passed=true, command='npm test'"- If tests fail, the server will block you from proceeding!
 
- 
Document: "Create documentation: type=README, summary='Added user profile section to docs'"
- 
Check readiness: "Check if I'm ready to commit"
- 
Commit & Push: "Commit and push: commitMessage='feat: add user profile page with tests and docs'"
- 
Record release: 
"Record release: command='npm run release', notes='v1.2.3'"
- Complete:
"Complete the task with commit message: 'feat: add user profile page'"
- Drop task (optional):
"Drop task: reason='Switching to a different feature'"
- Enforces discipline: Won't let you skip steps
- Test-driven: Blocks commits if tests fail
- Documentation reminder: Ensures you document your work
- State tracking: Remembers where you are in the workflow
- History: Keeps track of completed tasks
- Prompts: Quick reminders of best practices
- β Committing without tests
- β Committing with failing tests
- β Committing without documentation
- β Losing track of what you're working on
- β Skipping important workflow steps
- Always start with start_task- This sets your intention
- Never skip tests without justification - Use skip_testsonly when absolutely necessary and document the reason for manual QA
- Use get_workflow_status- Check where you are anytime
- Review history - Learn from your past tasks
- Follow the prompts - They contain best practices
You can modify the workflow in index.js:
- Add more workflow phases
- Customize reminders
- Add integration with your test runner
- Add custom validation rules
The server maintains state in .workflow-state.json:
- Current phase
- Task description
- Completion status of each step
- History of completed tasks
This file is automatically created and managed by the server.
This MCP server aligns with your existing development rules:
- β Enforces test-first discipline
- β Prevents commits with failing tests
- β Reminds about documentation
- β Tracks workflow state
- β Maintains history
MIT
Feel free to customize this server to match your specific workflow needs!