Skip to content

A comprehensive Angular performance analyzer that identifies performance bottlenecks, memory leaks, and optimization opportunities in Angular applications.

License

Notifications You must be signed in to change notification settings

eawebmaster20/ngperf

Repository files navigation

ngperf-audit

A comprehensive Angular performance analyzer that identifies performance bottlenecks, memory leaks, and optimization opportunities in Angular applications.

License: MIT

Features

  • πŸ” Smart OnPush Detection - recommends OnPush for components that would actually benefit from it
  • 🧠 Memory Leak Detection - Identifies subscription issues and memory leaks
  • ⚑ Template Optimization - Finds missing trackBy functions and template performance issues
  • πŸ“Š Performance Scoring - Gives each component a performance score out of 100
  • πŸ“ Detailed Reports - Generates comprehensive markdown reports with actionable recommendations
  • 🎯 Targeted Analysis - Focuses on components with actual complexity

Installation

Global Installation (Recommended)

npm install -g ngperf-audit

Project Installation

# As dev dependency
npm install --save-dev ngperf-audit

# Using npx (no installation required)
npx ngperf-audit project

Quick Start

Command Line Usage

# Analyze entire Angular project
ngperf project ./src/app

# Analyze specific component
ngperf component ./src/app/my-component/my-component.ts

# Generate detailed report
ngperf report ./src/app

# Get help
ngperf help

Programmatic Usage

import { PerformanceAnalyzerCLI, PerformanceAnalyzer } from 'ngperf-audit';

// Quick analysis with summary
const { analyses, summary } = PerformanceAnalyzerCLI.analyzeProjectWithSummary('./src/app');

console.log(`Found ${summary.totalComponents} components`);
console.log(`Average score: ${summary.averagePerformanceScore}/100`);

// Generate report
const report = PerformanceAnalyzerCLI.generateReportWithSummary(analyses, summary);
await PerformanceAnalyzerCLI.saveReportToFile(report, './performance-report.md');

Commands

ngperf project <path>

Analyzes all Angular components in the specified directory and generates a comprehensive report.

Options:

  • -o, --output <file>: Output file path for the report (default: ./performance-report.md)
  • -f, --format <type>: Report format - markdown or json (default: markdown)

Examples:

ngperf project ./src/app
ngperf project ./src/app -o ./reports/perf-analysis.md
ngperf project ./src/app -f json
ngperf project ./src/app -o ./reports/analysis.json -f json

ngperf component <path>

Analyzes a single Angular component file.

Example:

ngperf component ./src/app/user-profile/user-profile.component.ts

ngperf report <path>

Generates a detailed performance report for the specified directory.

ngperf help

Shows help information and available commands.

What It Analyzes

πŸ”₯ Smart OnPush Detection

Unlike other tools that blindly recommend OnPush for every component, ngperf intelligently determines which components would actually benefit:

  • βœ… Recommends OnPush for components with:

    • Service injections (HttpClient, APIs, etc.)
    • Lifecycle hooks (ngOnInit, ngOnChanges)
    • Observable subscriptions
    • Form handling (FormBuilder, FormGroup)
    • Complex methods and computed properties
    • Event handlers
    • Template complexity (ngFor, ngIf, event bindings)
  • ❌ Skips simple "dummy" components that:

    • Only display static content
    • Have minimal logic
    • Don't use services or observables
    • Have simple templates

🧠 Memory Leak Detection

  • Manual subscriptions without proper cleanup
  • Missing OnDestroy implementations
  • Multiple subscriptions that could be optimized

⚑ Template Performance

  • Missing trackBy functions in ngFor loops
  • Function calls in templates
  • Opportunities for async pipes
  • Large lists that need virtual scrolling

πŸ“Š Performance Scoring

Each component gets a score from 0-100 based on:

  • Change detection strategy appropriateness
  • Template optimization
  • Subscription management
  • Overall complexity vs. optimization

Sample Output

# Angular Performance Analysis Report

## πŸ“Š Project Overview
- **Components Analyzed**: 12
- **Average Performance Score**: 78.5/100
- **Total Issues Found**: 8

## 🚨 Top Priority Components (Lowest Scores)
1. **UserDashboard** - Score: 65/100
2. **ProductList** - Score: 70/100

### UserDashboard
**Performance Score**: 65/100

#### Issues Found (3)
πŸ”΄ **missing-onpush** (high)
   Component uses default change detection strategy
   *Fix*: Add ChangeDetectionStrategy.OnPush to component decorator

🟑 **manual-subscription** (medium)
   Manual subscription without proper cleanup
   *Fix*: Use async pipe, takeUntil pattern, or implement OnDestroy

🟑 **missing-trackby** (medium)
   *ngFor loop missing trackBy function
   *Fix*: Add trackBy function to prevent unnecessary DOM manipulations

Integration with CI/CD

Add performance checks to your build process:

{
  "scripts": {
    "perf-check": "ngperf project ./src/app --format json",
    "perf-report": "ngperf project ./src/app"
  }
}

Contributing

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

License

ngperf is free for everyone with attribution requirements πŸŽ‰

βœ… Free for All Use Cases

  • βœ… Personal projects
  • βœ… Open source projects
  • βœ… Commercial applications
  • βœ… Enterprise use
  • βœ… SaaS products
  • βœ… Consulting work

οΏ½ Attribution Required

Just give credit where it's due! Include attribution in one of these ways:

In your app's About/Credits section:

Performance analysis powered by ngperf-audit
Created by eawebmaster20 (https://eaweb-solutions.com)

In your project's README:

## Performance Analysis
This project uses [ngperf-audit](https://github.com/eawebmaster20/ngperf) 
for Angular performance analysis.

In CLI output:

Powered by ngperf-audit (https://github.com/eawebmaster20/ngperf)

🌟 Show Your Appreciation (Optional)

  • ⭐ Star the GitHub repository
  • 🐦 Share on social media
  • πŸ“ Write about your experience
  • πŸ”„ Contribute improvements

Full license details: MIT with Attribution

Support


Made with ❀️ for the Angular community

About

A comprehensive Angular performance analyzer that identifies performance bottlenecks, memory leaks, and optimization opportunities in Angular applications.

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published