Skip to content

A TypeScript utility that automatically adds detailed debug logs before and after method calls in classes, simplifying the tracking of execution flow and troubleshooting.

License

Notifications You must be signed in to change notification settings

krauters/debuggable

Repository files navigation

LinkedIn License visitors

Version npm version GitHub Stars Forks

GitHub Issues Open PRs Commits per Month Contributors Last Commit

install size Code Size Repo Size

Debuggable

A TypeScript utility that automatically adds detailed debug logs before and after method calls in classes, simplifying the tracking of execution flow and troubleshooting.

Usage

A TypeScript utility that automatically adds detailed debug logs before and after method calls in classes, simplifying the tracking of execution flow and troubleshooting.

import { debuggable } from '@krauters/debuggable'

@debuggable()
export class MyService {
  constructor() {
    console.info('Service initialized')
  }

  public processRequest(data: string): string {
    return `Processed: ${data}`
  }

  public anotherMethod() {
    return 'Another result'
  }
}

const service = new MyService()
service.processRequest('testData')
service.anotherMethod()

// Expected Output in Console:
//
// [DurationTracker] Initializing [DurationTracker]
// [Debuggable] Decorating the following [MyService] methods with debuggable: [length, name, prototype]
// [Debuggable] Decorating the following [MyService] methods with debuggable: [constructor, processRequest, anotherMethod]
// Service initialized
// [Debuggable] Calling [MyService.processRequest] with args ["testData"]
// [Debuggable] Called [MyService.processRequest] which returned ["Processed: testData"] and took [0] ms
// [Debuggable] Calling [MyService.anotherMethod] with args []
// [Debuggable] Called [MyService.anotherMethod] which returned ["Another result"] and took [0] ms

Installation

npm install @krauters/debuggable@latest

Husky

Husky helps manage Git hooks easily, automating things like running tests or linting before a commit is made. This ensures your code is in good shape.

Pre-commit hooks run scripts before a commit is finalized to catch issues or enforce standards. With Husky, setting up these hooks across your team becomes easy, keeping your codebase clean and consistent.

Our Custom Pre-Commit Hook

This project uses a custom pre-commit hook to run npm run bundle. This ensures that our bundled assets are always up to date before any commit (which is especially important for TypeScript GitHub Actions). Husky automates this, so no commits will go through without a fresh bundle, keeping everything streamlined.

Contributing

The goal of this project is to continually evolve and improve its core features, making it more efficient and easier to use. Development happens openly here on GitHub, and we’re thankful to the community for contributing bug fixes, enhancements, and fresh ideas. Whether you're fixing a small bug or suggesting a major improvement, your input is invaluable.

License

This project is licensed under the ISC License. Please see the LICENSE file for more details.

🥂 Thanks Contributors

Thanks for spending time on this project.



About

A TypeScript utility that automatically adds detailed debug logs before and after method calls in classes, simplifying the tracking of execution flow and troubleshooting.

Resources

License

Stars

Watchers

Forks

Packages

No packages published