Agent Skills: Tech Debt Report Generator

Find TODOs, deprecated APIs, and outdated patterns in codebase

UncategorizedID: IHKREDDY/agent-skills-ts/tech-debt-report

Install this agent skill to your local

pnpm dlx add-skill https://github.com/IHKREDDY/agent-skills-ts/tree/HEAD/skills/tech-debt-report

Skill Files

Browse the full folder contents for tech-debt-report.

Download Skill

Loading file tree…

skills/tech-debt-report/SKILL.md

Skill Metadata

Name
tech-debt-report
Description
Find TODOs, deprecated APIs, and outdated patterns in codebase

Tech Debt Report Generator

Scans the codebase to identify technical debt including TODO comments, deprecated API usage, outdated patterns, and potential refactoring opportunities.

🎯 Use Case Demo

Scenario: Quarterly Tech Debt Assessment

Before (Manual Process):

Tech Lead needs to assess tech debt for planning:

  1. Grep for TODO and FIXME comments
  2. Manually review code for deprecated APIs
  3. Check for outdated patterns
  4. Try to estimate effort for each item
  5. Create Jira tickets manually
  6. Prioritize based on gut feeling

Time: 1-2 days, incomplete coverage

After (With This Skill):

Tech Lead: "Generate tech debt report for the codebase"

Agent Response:

πŸ”§ TECHNICAL DEBT REPORT
═══════════════════════════════════════════════════════════════

πŸ“… Report Date: December 20, 2024
πŸ“ Scanned: 47 files, 8,234 lines of code

═══════════════════════════════════════════════════════════════
πŸ“Š DEBT SUMMARY
═══════════════════════════════════════════════════════════════

| Category | Count | Estimated Effort | Priority |
|----------|-------|------------------|----------|
| Critical TODOs | 3 | 2 days | πŸ”΄ High |
| Deprecated APIs | 5 | 1 day | πŸ”΄ High |
| Code Smells | 12 | 3 days | 🟑 Medium |
| Old Patterns | 8 | 2 days | 🟑 Medium |
| Minor TODOs | 15 | 1 day | 🟒 Low |
| **TOTAL** | **43** | **9 days** | |

═══════════════════════════════════════════════════════════════
πŸ”΄ CRITICAL ISSUES (Fix ASAP)
═══════════════════════════════════════════════════════════════

1. 🚨 Security: Hardcoded API Key
   πŸ“ Services/PaymentService.cs:23
   ```csharp
   // TODO: Move to environment variable - URGENT
   private const string ApiKey = "sk_live_xxxxx";

⏱️ Effort: 30 min 🎫 Suggested: Create Jira ticket with "security" label

  1. 🚨 Data Loss Risk: Missing Transaction πŸ“ Services/BookingService.cs:156

    // FIXME: No transaction wrapper - can cause partial bookings
    await _repository.CreateBooking(booking);
    await _paymentService.Charge(payment);
    

    ⏱️ Effort: 2 hours 🎫 Suggested: High priority bug ticket

  2. 🚨 Deprecated: Newtonsoft.Json πŸ“ Multiple files (7 occurrences) Issue: Using Newtonsoft.Json instead of System.Text.Json Impact: Performance, security updates ⏱️ Effort: 4 hours 🎫 Suggested: Refactoring ticket

═══════════════════════════════════════════════════════════════ 🟑 DEPRECATED API USAGE ═══════════════════════════════════════════════════════════════

| Location | Deprecated API | Replacement | |----------|----------------|-------------| | FlightsController.cs:45 | DateTime.Now | DateTime.UtcNow | | BookingService.cs:89 | HttpClient() | IHttpClientFactory | | FlightService.cs:34 | GetAwaiter().GetResult() | async/await | | SearchRequest.cs:12 | [Obsolete] FlightClass | CabinClass enum | | Program.cs:67 | UseUrls() | WebApplication.Urls |

═══════════════════════════════════════════════════════════════ πŸ“ TODO/FIXME COMMENTS ═══════════════════════════════════════════════════════════════

High Priority (blocking or risky): πŸ“ BookingService.cs:45 - TODO: Add retry logic for API calls πŸ“ PaymentService.cs:78 - FIXME: Handle timeout properly πŸ“ FlightService.cs:112 - TODO: Cache this query

Medium Priority (quality/performance): πŸ“ FlightsController.cs:89 - TODO: Add pagination πŸ“ BookingsController.cs:34 - TODO: Add input validation πŸ“ SearchRequest.cs:23 - TODO: Add date range validation ... and 6 more

Low Priority (nice to have): πŸ“ Multiple files - TODO: Add XML documentation πŸ“ Models/*.cs - TODO: Add validation attributes ... and 9 more

═══════════════════════════════════════════════════════════════ πŸ”„ OUTDATED PATTERNS ═══════════════════════════════════════════════════════════════

  1. Manual Dependency Injection πŸ“ Program.cs:23-45 Current: Manual service registration Better: Use Scrutor for assembly scanning Effort: 2 hours

  2. String Concatenation in Queries πŸ“ FlightService.cs:67 Current: String interpolation in SQL Better: Parameterized queries or EF Core Risk: SQL Injection (CRITICAL) Effort: 1 hour

  3. Synchronous File I/O πŸ“ Services/LogService.cs:34 Current: File.WriteAllText() Better: File.WriteAllTextAsync() Effort: 15 min

═══════════════════════════════════════════════════════════════ πŸ“‹ RECOMMENDED ACTION PLAN ═══════════════════════════════════════════════════════════════

Sprint 1 (Immediate - 2 days): β–‘ Fix hardcoded API key (security) β–‘ Add transaction wrapper (data integrity) β–‘ Fix SQL injection vulnerability

Sprint 2 (Next - 3 days): β–‘ Migrate from Newtonsoft.Json β–‘ Fix deprecated HttpClient usage β–‘ Add retry logic to API calls

Sprint 3 (Planned - 4 days): β–‘ Clean up remaining TODOs β–‘ Modernize DI registration β–‘ Add missing validation

═══════════════════════════════════════════════════════════════ 🎫 CREATE JIRA TICKETS? ═══════════════════════════════════════════════════════════════

Say "Create tickets for critical tech debt" to automatically create Jira tickets for the high-priority items.

═══════════════════════════════════════════════════════════════

Time Saved: 1-2 days β†’ 2 minutes (500x faster)


Agent Instructions

When this skill is activated:

  1. Scan for TODO/FIXME Comments:

    • Search all source files for TODO, FIXME, HACK, XXX comments
    • Extract the comment text and file location
    • Parse any ticket references or priority indicators
  2. Check for Deprecated APIs:

    • Look for [Obsolete] attributes
    • Check for known deprecated patterns:
      • DateTime.Now β†’ DateTime.UtcNow
      • new HttpClient() β†’ IHttpClientFactory
      • GetAwaiter().GetResult() β†’ proper async
      • Newtonsoft.Json β†’ System.Text.Json
    • Check for deprecated framework APIs
  3. Identify Code Smells:

    • Long methods (>50 lines)
    • Large classes (>500 lines)
    • Deep nesting (>4 levels)
    • Magic numbers/strings
    • Duplicate code patterns
  4. Assess Security Issues:

    • Hardcoded secrets/keys
    • SQL injection vulnerabilities
    • Missing input validation
  5. Categorize and Prioritize:

    • Critical: Security, data integrity
    • High: Deprecated APIs, blocking TODOs
    • Medium: Performance, code quality
    • Low: Documentation, minor cleanup
  6. Estimate Effort:

    • Based on scope and complexity
    • Consider testing requirements
  7. Generate Action Plan:

    • Group into sprint-sized chunks
    • Prioritize by risk and impact

Example Prompts

  • "Generate tech debt report"
  • "Find all TODO comments in the codebase"
  • "Check for deprecated API usage"
  • "What refactoring is needed?"
  • "Show me code quality issues"

Benefits

| Metric | Before | After | Improvement | |--------|--------|-------|-------------| | Assessment time | 1-2 days | 2 min | 500x faster | | Coverage | 60-70% | 100% | Complete scan | | Prioritization | Subjective | Data-driven | Better decisions | | Tracking | Ad-hoc | Systematic | Nothing forgotten |