feat: Enhance Task Master CLI with Testing Framework, Perplexity AI Integration, and Refactored Core Logic
This commit introduces significant enhancements and refactoring to the Task Master CLI, focusing on improved testing, integration with Perplexity AI for research-backed task updates, and core logic refactoring for better maintainability and functionality.
**Testing Infrastructure Setup:**
- Implemented Jest as the primary testing framework, setting up a comprehensive testing environment.
- Added new test scripts to including , , and for streamlined testing workflows.
- Integrated necessary devDependencies for testing, such as , , , , and , to support unit, integration, and end-to-end testing.
**Dependency Updates:**
- Updated and to reflect the latest dependency versions, ensuring project stability and access to the newest features and security patches.
- Upgraded to version 0.9.16 and usage: openai [-h] [-v] [-b API_BASE] [-k API_KEY] [-p PROXY [PROXY ...]]
[-o ORGANIZATION] [-t {openai,azure}]
[--api-version API_VERSION] [--azure-endpoint AZURE_ENDPOINT]
[--azure-ad-token AZURE_AD_TOKEN] [-V]
{api,tools,migrate,grit} ...
positional arguments:
{api,tools,migrate,grit}
api Direct API calls
tools Client side tools for convenience
options:
-h, --help show this help message and exit
-v, --verbose Set verbosity.
-b, --api-base API_BASE
What API base url to use.
-k, --api-key API_KEY
What API key to use.
-p, --proxy PROXY [PROXY ...]
What proxy to use.
-o, --organization ORGANIZATION
Which organization to run as (will use your default
organization if not specified)
-t, --api-type {openai,azure}
The backend API to call, must be `openai` or `azure`
--api-version API_VERSION
The Azure API version, e.g.
'https://learn.microsoft.com/en-us/azure/ai-
services/openai/reference#rest-api-versioning'
--azure-endpoint AZURE_ENDPOINT
The Azure endpoint, e.g.
'https://endpoint.openai.azure.com'
--azure-ad-token AZURE_AD_TOKEN
A token from Azure Active Directory,
https://www.microsoft.com/en-
us/security/business/identity-access/microsoft-entra-
id
-V, --version show program's version number and exit to 4.89.0.
- Added dependency (version 2.3.0) and updated related dependencies to their latest versions.
**Perplexity AI Integration for Research-Backed Updates:**
- Introduced an option to leverage Perplexity AI for task updates, enabling research-backed enhancements to task details.
- Implemented logic to initialize a Perplexity AI client if the environment variable is available.
- Modified the function to accept a parameter, allowing dynamic selection between Perplexity AI and Claude AI for task updates based on API key availability and user preference.
- Enhanced to handle responses from Perplexity AI and update tasks accordingly, including improved error handling and logging for robust operation.
**Core Logic Refactoring and Improvements:**
- Refactored the function to utilize task IDs instead of dependency IDs, ensuring consistency and clarity in dependency management.
- Implemented a new function to rigorously check for both circular dependencies and self-dependencies within tasks, improving task relationship integrity.
- Enhanced UI elements in :
- Refactored to incorporate icons for different task statuses and utilize a object for color mapping, improving visual representation of task status.
- Updated to display colored complexity scores with emojis, providing a more intuitive and visually appealing representation of task complexity.
- Refactored the task data structure creation and validation process:
- Updated the JSON Schema for to reflect a more streamlined and efficient task structure.
- Implemented Task Model Classes for better data modeling and type safety.
- Improved File System Operations for task data management.
- Developed robust Validation Functions and an Error Handling System to ensure data integrity and application stability.
**Testing Guidelines Implementation:**
- Implemented guidelines for writing testable code when developing new features, promoting a test-driven development approach.
- Added testing requirements and best practices for unit, integration, and edge case testing to ensure comprehensive test coverage.
- Updated the development workflow to mandate writing tests before proceeding with configuration and documentation updates, reinforcing the importance of testing throughout the development lifecycle.
This commit collectively enhances the Task Master CLI's reliability, functionality, and developer experience through improved testing practices, AI-powered research capabilities, and a more robust and maintainable codebase.
This commit is contained in:
@@ -27,8 +27,9 @@ The standard pattern for adding a feature follows this workflow:
|
||||
1. **Core Logic**: Implement the business logic in the appropriate module
|
||||
2. **UI Components**: Add any display functions to [`ui.js`](mdc:scripts/modules/ui.js)
|
||||
3. **Command Integration**: Add the CLI command to [`commands.js`](mdc:scripts/modules/commands.js)
|
||||
4. **Configuration**: Update any configuration in [`utils.js`](mdc:scripts/modules/utils.js) if needed
|
||||
5. **Documentation**: Update help text and documentation in [dev_workflow.mdc](mdc:scripts/modules/dev_workflow.mdc)
|
||||
4. **Testing**: Write tests for all components of the feature (following [`tests.mdc`](mdc:.cursor/rules/tests.mdc))
|
||||
5. **Configuration**: Update any configuration in [`utils.js`](mdc:scripts/modules/utils.js) if needed
|
||||
6. **Documentation**: Update help text and documentation in [dev_workflow.mdc](mdc:scripts/modules/dev_workflow.mdc)
|
||||
|
||||
```javascript
|
||||
// 1. CORE LOGIC: Add function to appropriate module (example in task-manager.js)
|
||||
@@ -167,26 +168,125 @@ function formatDuration(ms) {
|
||||
}
|
||||
```
|
||||
|
||||
## Testing New Features
|
||||
## Writing Testable Code
|
||||
|
||||
Before submitting a new feature:
|
||||
When implementing new features, follow these guidelines to ensure your code is testable:
|
||||
|
||||
1. Verify export/import structure with:
|
||||
```bash
|
||||
grep -A15 "export {" scripts/modules/*.js
|
||||
grep -A15 "import {" scripts/modules/*.js | grep -v "^--$"
|
||||
- **Dependency Injection**
|
||||
- Design functions to accept dependencies as parameters
|
||||
- Avoid hard-coded dependencies that are difficult to mock
|
||||
```javascript
|
||||
// ✅ DO: Accept dependencies as parameters
|
||||
function processTask(task, fileSystem, logger) {
|
||||
fileSystem.writeFile('task.json', JSON.stringify(task));
|
||||
logger.info('Task processed');
|
||||
}
|
||||
|
||||
// ❌ DON'T: Use hard-coded dependencies
|
||||
function processTask(task) {
|
||||
fs.writeFile('task.json', JSON.stringify(task));
|
||||
console.log('Task processed');
|
||||
}
|
||||
```
|
||||
|
||||
- **Separate Logic from Side Effects**
|
||||
- Keep pure logic separate from I/O operations or UI rendering
|
||||
- This allows testing the logic without mocking complex dependencies
|
||||
```javascript
|
||||
// ✅ DO: Separate logic from side effects
|
||||
function calculateTaskPriority(task, dependencies) {
|
||||
// Pure logic that returns a value
|
||||
return computedPriority;
|
||||
}
|
||||
|
||||
function displayTaskPriority(task, dependencies) {
|
||||
const priority = calculateTaskPriority(task, dependencies);
|
||||
console.log(`Task priority: ${priority}`);
|
||||
}
|
||||
```
|
||||
|
||||
- **Callback Functions and Testing**
|
||||
- When using callbacks (like in Commander.js commands), define them separately
|
||||
- This allows testing the callback logic independently
|
||||
```javascript
|
||||
// ✅ DO: Define callbacks separately for testing
|
||||
function getVersionString() {
|
||||
// Logic to determine version
|
||||
return version;
|
||||
}
|
||||
|
||||
// In setupCLI
|
||||
programInstance.version(getVersionString);
|
||||
|
||||
// In tests
|
||||
test('getVersionString returns correct version', () => {
|
||||
expect(getVersionString()).toBe('1.5.0');
|
||||
});
|
||||
```
|
||||
|
||||
- **UI Output Testing**
|
||||
- For UI components, focus on testing conditional logic rather than exact output
|
||||
- Use string pattern matching (like `expect(result).toContain('text')`)
|
||||
- Pay attention to emojis and formatting which can make exact string matching difficult
|
||||
```javascript
|
||||
// ✅ DO: Test the essence of the output, not exact formatting
|
||||
test('statusFormatter shows done status correctly', () => {
|
||||
const result = formatStatus('done');
|
||||
expect(result).toContain('done');
|
||||
expect(result).toContain('✅');
|
||||
});
|
||||
```
|
||||
|
||||
## Testing Requirements
|
||||
|
||||
Every new feature **must** include comprehensive tests following the guidelines in [`tests.mdc`](mdc:.cursor/rules/tests.mdc). Testing should include:
|
||||
|
||||
1. **Unit Tests**: Test individual functions and components in isolation
|
||||
```javascript
|
||||
// Example unit test for a new utility function
|
||||
describe('newFeatureUtil', () => {
|
||||
test('should perform expected operation with valid input', () => {
|
||||
expect(newFeatureUtil('valid input')).toBe('expected result');
|
||||
});
|
||||
|
||||
test('should handle edge cases appropriately', () => {
|
||||
expect(newFeatureUtil('')).toBeNull();
|
||||
});
|
||||
});
|
||||
```
|
||||
|
||||
2. Test the feature with valid input:
|
||||
```bash
|
||||
task-master your-command --option1=value
|
||||
2. **Integration Tests**: Verify the feature works correctly with other components
|
||||
```javascript
|
||||
// Example integration test for a new command
|
||||
describe('newCommand integration', () => {
|
||||
test('should call the correct service functions with parsed arguments', () => {
|
||||
const mockService = jest.fn().mockResolvedValue('success');
|
||||
// Set up test with mocked dependencies
|
||||
// Call the command handler
|
||||
// Verify service was called with expected arguments
|
||||
});
|
||||
});
|
||||
```
|
||||
|
||||
3. Test the feature with edge cases:
|
||||
```bash
|
||||
task-master your-command --option1=""
|
||||
task-master your-command # without required options
|
||||
```
|
||||
3. **Edge Cases**: Test boundary conditions and error handling
|
||||
- Invalid inputs
|
||||
- Missing dependencies
|
||||
- File system errors
|
||||
- API failures
|
||||
|
||||
4. **Test Coverage**: Aim for at least 80% coverage for all new code
|
||||
|
||||
5. **Jest Mocking Best Practices**
|
||||
- Follow the mock-first-then-import pattern as described in [`tests.mdc`](mdc:.cursor/rules/tests.mdc)
|
||||
- Use jest.spyOn() to create spy functions for testing
|
||||
- Clear mocks between tests to prevent interference
|
||||
- See the Jest Module Mocking Best Practices section in [`tests.mdc`](mdc:.cursor/rules/tests.mdc) for details
|
||||
|
||||
When submitting a new feature, always run the full test suite to ensure nothing was broken:
|
||||
|
||||
```bash
|
||||
npm test
|
||||
```
|
||||
|
||||
## Documentation Requirements
|
||||
|
||||
|
||||
Reference in New Issue
Block a user