gg
gg is a Dart package designed to streamline your development workflow by offering a suite of pre-commit checks. These include code analysis, linting, testing, and coverage verification, all complemented by highly optimized and colorized error messages.
Key Features
- ✅ Precise Colorized Error Messages: Get detailed feedback with error messages that are both precise and easy to understand, enhanced with color for better readability.
- ✅ Optimized for VSCode: Error messages are tailored for display in Visual Studio Code, ensuring a seamless integration into your development environment.
- ✅ Enforces 100% Code Coverage: Achieve and maintain high-quality code with enforced 100% test coverage for your codebase.
- ✅ GitHub Action Integration: Easily integrate gg with GitHub Actions to automate your testing workflow directly within GitHub.
Preparation
Install required tools
dart global activate pana
Create a New Library Project
dart create -t package hello_world
cd hello_world
Add gg as a Development Dependency
Enhance your project with gg by adding it as a development dependency:
dart pub add --dev gg
Discover gg Commands
Learn about the available commands and their applications:
dart pub run gg -h
Execute All Tests and Checks
dart run gg all
Fix the issues
Address issues identified by gg, aiming for a clean, error-free codebase..
Ensure Comprehensive Code Coverage
gg demands excellence in testing:
- Achieve 100% Code Coverage: Mandatory complete test coverage for all code.
- Review Short and Precise Coverage Reports: Analyze uncovered lines and their corresponding tests.
- Maintain Mandatory Test Files: Ensure each implementation file has a dedicated test file achieving 100% coverage.
Exclude lines from code that should be excluded from code coverage:
// coverage:ignore-line
// coverage:ignore-start
// coverage:ignore-end
Set Up GitHub Action for Automated Checks
Automate your testing process by setting up the gg GitHub Action, like here:
github.com/inlavigo/gg/blob/main/.github/workflows/pipeline.yaml
Contributions
Report your errors and contributions to github.com/inlavigo/gg.