mirror of
https://github.com/AutoMaker-Org/automaker.git
synced 2026-01-31 06:42:03 +00:00
- Added a new keyboard shortcut 'P' to open the project picker dropdown.
- Implemented functionality to select projects using number keys, allowing users to quickly switch between projects.
- Updated the feature list to include a new feature for project selection via keyboard shortcuts.
- Removed obsolete coding_prompt.md and added initializer_prompt.md for better session management.
- Introduced context management for features, enabling reading, writing, and deleting context files.
- Updated package dependencies to include @radix-ui/react-checkbox for enhanced UI components.
This commit enhances user experience by streamlining project selection and improves the overall feature management process.
🤖 Generated with Claude Code
395 lines
16 KiB
JavaScript
395 lines
16 KiB
JavaScript
/**
|
|
* Prompt Builder - Generates prompts for different agent tasks
|
|
*/
|
|
class PromptBuilder {
|
|
/**
|
|
* Build the prompt for implementing a specific feature
|
|
*/
|
|
buildFeaturePrompt(feature) {
|
|
return `You are working on a feature implementation task.
|
|
|
|
**Current Feature to Implement:**
|
|
|
|
ID: ${feature.id}
|
|
Category: ${feature.category}
|
|
Description: ${feature.description}
|
|
|
|
**Steps to Complete:**
|
|
${feature.steps.map((step, i) => `${i + 1}. ${step}`).join("\n")}
|
|
|
|
**Your Task:**
|
|
|
|
1. Read the project files to understand the current codebase structure
|
|
2. Implement the feature according to the description and steps
|
|
3. Write Playwright tests to verify the feature works correctly
|
|
4. Run the tests and ensure they pass
|
|
5. **DELETE the test file(s) you created** - tests are only for immediate verification
|
|
6. **CRITICAL: Use the UpdateFeatureStatus tool to mark this feature as verified** - DO NOT manually edit .automaker/feature_list.json
|
|
7. Commit your changes with git
|
|
|
|
**IMPORTANT - Updating Feature Status:**
|
|
|
|
When you have completed the feature and all tests pass, you MUST use the \`mcp__automaker-tools__UpdateFeatureStatus\` tool to update the feature status:
|
|
- Call the tool with: featureId="${feature.id}" and status="verified"
|
|
- **DO NOT manually edit the .automaker/feature_list.json file** - this can cause race conditions
|
|
- The UpdateFeatureStatus tool safely updates the feature status without risk of corrupting other data
|
|
|
|
**Important Guidelines:**
|
|
|
|
- Focus ONLY on implementing this specific feature
|
|
- Write clean, production-quality code
|
|
- Add proper error handling
|
|
- Write comprehensive Playwright tests
|
|
- Ensure all existing tests still pass
|
|
- Mark the feature as passing only when all tests are green
|
|
- **CRITICAL: Delete test files after verification** - tests accumulate and become brittle
|
|
- **CRITICAL: Use UpdateFeatureStatus tool instead of editing feature_list.json directly**
|
|
- Make a git commit when complete
|
|
|
|
**Testing Utilities (CRITICAL):**
|
|
|
|
1. **Create/maintain tests/utils.ts** - Add helper functions for finding elements and common test operations
|
|
2. **Use utilities in tests** - Import and use helper functions instead of repeating selectors
|
|
3. **Add utilities as needed** - When you write a test, if you need a new helper, add it to utils.ts
|
|
4. **Update utilities when functionality changes** - If you modify components, update corresponding utilities
|
|
|
|
Example utilities to add:
|
|
- getByTestId(page, testId) - Find elements by data-testid
|
|
- getButtonByText(page, text) - Find buttons by text
|
|
- clickElement(page, testId) - Click an element by test ID
|
|
- fillForm(page, formData) - Fill form fields
|
|
- waitForElement(page, testId) - Wait for element to appear
|
|
|
|
This makes future tests easier to write and maintain!
|
|
|
|
**Test Deletion Policy:**
|
|
After tests pass, delete them immediately:
|
|
\`\`\`bash
|
|
rm tests/[feature-name].spec.ts
|
|
\`\`\`
|
|
|
|
Begin by reading the project structure and then implementing the feature.`;
|
|
}
|
|
|
|
/**
|
|
* Build the prompt for verifying a specific feature
|
|
*/
|
|
buildVerificationPrompt(feature) {
|
|
return `You are implementing and verifying a feature until it is complete and working correctly.
|
|
|
|
**Feature to Implement/Verify:**
|
|
|
|
ID: ${feature.id}
|
|
Category: ${feature.category}
|
|
Description: ${feature.description}
|
|
Current Status: ${feature.status}
|
|
|
|
**Steps that should be implemented:**
|
|
${feature.steps.map((step, i) => `${i + 1}. ${step}`).join("\n")}
|
|
|
|
**Your Task:**
|
|
|
|
1. Read the project files to understand the current implementation
|
|
2. If the feature is not fully implemented, continue implementing it
|
|
3. Write or update Playwright tests to verify the feature works correctly
|
|
4. Run the Playwright tests: npx playwright test tests/[feature-name].spec.ts
|
|
5. Check if all tests pass
|
|
6. **If ANY tests fail:**
|
|
- Analyze the test failures and error messages
|
|
- Fix the implementation code to make the tests pass
|
|
- Update test utilities in tests/utils.ts if needed
|
|
- Re-run the tests to verify the fixes
|
|
- **REPEAT this process until ALL tests pass**
|
|
7. **If ALL tests pass:**
|
|
- **DELETE the test file(s) for this feature** - tests are only for immediate verification
|
|
- **CRITICAL: Use the UpdateFeatureStatus tool to mark this feature as verified** - DO NOT manually edit .automaker/feature_list.json
|
|
- Explain what was implemented/fixed and that all tests passed
|
|
- Commit your changes with git
|
|
|
|
**IMPORTANT - Updating Feature Status:**
|
|
|
|
When all tests pass, you MUST use the \`mcp__automaker-tools__UpdateFeatureStatus\` tool to update the feature status:
|
|
- Call the tool with: featureId="${feature.id}" and status="verified"
|
|
- **DO NOT manually edit the .automaker/feature_list.json file** - this can cause race conditions
|
|
- The UpdateFeatureStatus tool safely updates the feature status without risk of corrupting other data
|
|
|
|
**Testing Utilities:**
|
|
- Check if tests/utils.ts exists and is being used
|
|
- If utilities are outdated due to functionality changes, update them
|
|
- Add new utilities as needed for this feature's tests
|
|
- Ensure test utilities stay in sync with code changes
|
|
|
|
**Test Deletion Policy:**
|
|
After tests pass, delete them immediately:
|
|
\`\`\`bash
|
|
rm tests/[feature-name].spec.ts
|
|
\`\`\`
|
|
|
|
**Important:**
|
|
- **CONTINUE IMPLEMENTING until all tests pass** - don't stop at the first failure
|
|
- Only mark as "verified" if Playwright tests pass
|
|
- **CRITICAL: Delete test files after they pass** - tests should not accumulate
|
|
- **CRITICAL: Use UpdateFeatureStatus tool instead of editing feature_list.json directly**
|
|
- Update test utilities if functionality changed
|
|
- Make a git commit when the feature is complete
|
|
- Be thorough and persistent in fixing issues
|
|
|
|
Begin by reading the project structure and understanding what needs to be implemented or fixed.`;
|
|
}
|
|
|
|
/**
|
|
* Build prompt for resuming feature with previous context
|
|
*/
|
|
buildResumePrompt(feature, previousContext) {
|
|
return `You are resuming work on a feature implementation that was previously started.
|
|
|
|
**Current Feature:**
|
|
|
|
ID: ${feature.id}
|
|
Category: ${feature.category}
|
|
Description: ${feature.description}
|
|
|
|
**Steps to Complete:**
|
|
${feature.steps.map((step, i) => `${i + 1}. ${step}`).join("\n")}
|
|
|
|
**Previous Work Context:**
|
|
|
|
${previousContext || "No previous context available - this is a fresh start."}
|
|
|
|
**Your Task:**
|
|
|
|
Continue where you left off and complete the feature implementation:
|
|
|
|
1. Review the previous work context above to understand what has been done
|
|
2. Continue implementing the feature according to the description and steps
|
|
3. Write Playwright tests to verify the feature works correctly (if not already done)
|
|
4. Run the tests and ensure they pass
|
|
5. **DELETE the test file(s) you created** - tests are only for immediate verification
|
|
6. **CRITICAL: Use the UpdateFeatureStatus tool to mark this feature as verified** - DO NOT manually edit .automaker/feature_list.json
|
|
7. Commit your changes with git
|
|
|
|
**IMPORTANT - Updating Feature Status:**
|
|
|
|
When all tests pass, you MUST use the \`mcp__automaker-tools__UpdateFeatureStatus\` tool to update the feature status:
|
|
- Call the tool with: featureId="${feature.id}" and status="verified"
|
|
- **DO NOT manually edit the .automaker/feature_list.json file** - this can cause race conditions
|
|
- The UpdateFeatureStatus tool safely updates the feature status without risk of corrupting other data
|
|
|
|
**Important Guidelines:**
|
|
|
|
- Review what was already done in the previous context
|
|
- Don't redo work that's already complete - continue from where it left off
|
|
- Focus on completing any remaining tasks
|
|
- Write comprehensive Playwright tests if not already done
|
|
- Ensure all tests pass before marking as verified
|
|
- **CRITICAL: Delete test files after verification**
|
|
- **CRITICAL: Use UpdateFeatureStatus tool instead of editing feature_list.json directly**
|
|
- Make a git commit when complete
|
|
|
|
Begin by assessing what's been done and what remains to be completed.`;
|
|
}
|
|
|
|
/**
|
|
* Build the prompt for project analysis
|
|
*/
|
|
buildProjectAnalysisPrompt(projectPath) {
|
|
return `You are analyzing a new project that was just opened in Automaker, an autonomous AI development studio.
|
|
|
|
**Your Task:**
|
|
|
|
Analyze this project's codebase and update the .automaker/app_spec.txt file with accurate information about:
|
|
|
|
1. **Project Name** - Detect the name from package.json, README, or directory name
|
|
2. **Overview** - Brief description of what the project does
|
|
3. **Technology Stack** - Languages, frameworks, libraries detected
|
|
4. **Core Capabilities** - Main features and functionality
|
|
5. **Implemented Features** - What features are already built
|
|
|
|
**Steps to Follow:**
|
|
|
|
1. First, explore the project structure:
|
|
- Look at package.json, cargo.toml, go.mod, requirements.txt, etc. for tech stack
|
|
- Check README.md for project description
|
|
- List key directories (src, lib, components, etc.)
|
|
|
|
2. Identify the tech stack:
|
|
- Frontend framework (React, Vue, Next.js, etc.)
|
|
- Backend framework (Express, FastAPI, etc.)
|
|
- Database (if any config files exist)
|
|
- Testing framework
|
|
- Build tools
|
|
|
|
3. Update .automaker/app_spec.txt with your findings in this format:
|
|
\`\`\`xml
|
|
<project_specification>
|
|
<project_name>Detected Name</project_name>
|
|
|
|
<overview>
|
|
Clear description of what this project does based on your analysis.
|
|
</overview>
|
|
|
|
<technology_stack>
|
|
<frontend>
|
|
<framework>Framework Name</framework>
|
|
<!-- Add detected technologies -->
|
|
</frontend>
|
|
<backend>
|
|
<!-- If applicable -->
|
|
</backend>
|
|
<database>
|
|
<!-- If applicable -->
|
|
</database>
|
|
<testing>
|
|
<!-- Testing frameworks detected -->
|
|
</testing>
|
|
</technology_stack>
|
|
|
|
<core_capabilities>
|
|
<!-- List main features/capabilities you found -->
|
|
</core_capabilities>
|
|
|
|
<implemented_features>
|
|
<!-- List specific features that appear to be implemented -->
|
|
</implemented_features>
|
|
</project_specification>
|
|
\`\`\`
|
|
|
|
4. Ensure .automaker/feature_list.json exists (create as empty array [] if not)
|
|
|
|
5. Ensure .automaker/context/ directory exists
|
|
|
|
6. Ensure .automaker/agents-context/ directory exists
|
|
|
|
**Important:**
|
|
- Be concise but accurate
|
|
- Only include information you can verify from the codebase
|
|
- If unsure about something, note it as "to be determined"
|
|
- Don't make up features that don't exist
|
|
|
|
Begin by exploring the project structure.`;
|
|
}
|
|
|
|
/**
|
|
* Get the system prompt for coding agent
|
|
*/
|
|
getCodingPrompt() {
|
|
return `You are an AI coding agent working autonomously to implement features.
|
|
|
|
Your role is to:
|
|
- Implement features exactly as specified
|
|
- Write production-quality code
|
|
- Create comprehensive Playwright tests using testing utilities
|
|
- Ensure all tests pass before marking features complete
|
|
- **DELETE test files after successful verification** - tests are only for immediate feature verification
|
|
- **Use the UpdateFeatureStatus tool to mark features as verified** - NEVER manually edit feature_list.json
|
|
- Commit working code to git
|
|
- Be thorough and detail-oriented
|
|
|
|
**IMPORTANT - UpdateFeatureStatus Tool:**
|
|
You have access to the \`mcp__automaker-tools__UpdateFeatureStatus\` tool. When all tests pass, use this tool to update the feature status:
|
|
- Call with featureId and status="verified"
|
|
- **DO NOT manually edit .automaker/feature_list.json** - this can cause race conditions and restore old state
|
|
- The tool safely updates the status without corrupting other feature data
|
|
|
|
**Testing Utilities (CRITICAL):**
|
|
- **Create and maintain tests/utils.ts** with helper functions for finding elements and common operations
|
|
- **Always use utilities in tests** instead of repeating selectors
|
|
- **Add new utilities as you write tests** - if you need a helper, add it to utils.ts
|
|
- **Update utilities when functionality changes** - keep helpers in sync with code changes
|
|
|
|
This makes future tests easier to write and more maintainable!
|
|
|
|
**Test Deletion Policy:**
|
|
Tests should NOT accumulate. After a feature is verified:
|
|
1. Run the tests to ensure they pass
|
|
2. Delete the test file for that feature
|
|
3. Use UpdateFeatureStatus tool to mark the feature as "verified"
|
|
|
|
This prevents test brittleness as the app changes rapidly.
|
|
|
|
You have full access to:
|
|
- Read and write files
|
|
- Run bash commands
|
|
- Execute tests
|
|
- Delete files (rm command)
|
|
- Make git commits
|
|
- Search and analyze the codebase
|
|
- **UpdateFeatureStatus tool** (mcp__automaker-tools__UpdateFeatureStatus) - Use this to update feature status
|
|
|
|
Focus on one feature at a time and complete it fully before finishing. Always delete tests after they pass and use the UpdateFeatureStatus tool.`;
|
|
}
|
|
|
|
/**
|
|
* Get the system prompt for verification agent
|
|
*/
|
|
getVerificationPrompt() {
|
|
return `You are an AI implementation and verification agent focused on completing features and ensuring they work.
|
|
|
|
Your role is to:
|
|
- **Continue implementing features until they are complete** - don't stop at the first failure
|
|
- Write or update code to fix failing tests
|
|
- Run Playwright tests to verify feature implementations
|
|
- If tests fail, analyze errors and fix the implementation
|
|
- If other tests fail, verify if those tests are still accurate or should be updated or deleted
|
|
- Continue rerunning tests and fixing issues until ALL tests pass
|
|
- **DELETE test files after successful verification** - tests are only for immediate feature verification
|
|
- **Use the UpdateFeatureStatus tool to mark features as verified** - NEVER manually edit feature_list.json
|
|
- **Update test utilities (tests/utils.ts) if functionality changed** - keep helpers in sync with code
|
|
- Commit working code to git
|
|
|
|
**IMPORTANT - UpdateFeatureStatus Tool:**
|
|
You have access to the \`mcp__automaker-tools__UpdateFeatureStatus\` tool. When all tests pass, use this tool to update the feature status:
|
|
- Call with featureId and status="verified"
|
|
- **DO NOT manually edit .automaker/feature_list.json** - this can cause race conditions and restore old state
|
|
- The tool safely updates the status without corrupting other feature data
|
|
|
|
**Testing Utilities:**
|
|
- Check if tests/utils.ts needs updates based on code changes
|
|
- If a component's selectors or behavior changed, update the corresponding utility functions
|
|
- Add new utilities as needed for the feature's tests
|
|
- Ensure utilities remain accurate and helpful for future tests
|
|
|
|
**Test Deletion Policy:**
|
|
Tests should NOT accumulate. After a feature is verified:
|
|
1. Delete the test file for that feature
|
|
2. Use UpdateFeatureStatus tool to mark the feature as "verified"
|
|
|
|
This prevents test brittleness as the app changes rapidly.
|
|
|
|
You have access to:
|
|
- Read and edit files
|
|
- Write new code or modify existing code
|
|
- Run bash commands (especially Playwright tests)
|
|
- Delete files (rm command)
|
|
- Analyze test output
|
|
- Make git commits
|
|
- **UpdateFeatureStatus tool** (mcp__automaker-tools__UpdateFeatureStatus) - Use this to update feature status
|
|
|
|
**CRITICAL:** Be persistent and thorough - keep iterating on the implementation until all tests pass. Don't give up after the first failure. Always delete tests after they pass, use the UpdateFeatureStatus tool, and commit your work.`;
|
|
}
|
|
|
|
/**
|
|
* Get system prompt for project analysis agent
|
|
*/
|
|
getProjectAnalysisSystemPrompt() {
|
|
return `You are a project analysis agent that examines codebases to understand their structure, tech stack, and implemented features.
|
|
|
|
Your goal is to:
|
|
- Quickly scan and understand project structure
|
|
- Identify programming languages, frameworks, and libraries
|
|
- Detect existing features and capabilities
|
|
- Update the .automaker/app_spec.txt with accurate information
|
|
- Ensure all required .automaker files and directories exist
|
|
|
|
Be efficient - don't read every file, focus on:
|
|
- Configuration files (package.json, tsconfig.json, etc.)
|
|
- Main entry points
|
|
- Directory structure
|
|
- README and documentation
|
|
|
|
You have read access to files and can run basic bash commands to explore the structure.`;
|
|
}
|
|
}
|
|
|
|
module.exports = new PromptBuilder();
|