flutter_keycheck 1.0.1  flutter_keycheck: ^1.0.1 copied to clipboard
flutter_keycheck: ^1.0.1 copied to clipboard
A CLI tool for verifying presence of ValueKey elements and test dependencies in Flutter projects.
Flutter Key Integration Validator #
A CLI tool to validate Flutter automation keys and integration test dependencies. Ensures your Flutter app is ready for automated testing with proper key coverage.
๐ฏ Features #
- Key Validation: Validates Flutter key usage in source code
- ValueKeydeclarations
- Keydeclarations
- find.byValueKeyfinders
- find.bySemanticsLabelfinders
- find.byTooltipfinders
 
- Dependency Check: Verifies required test dependencies
- Integration Test Setup: Validates test file structure
- Colorful Output: Beautiful console output with emojis
- Flexible Configuration: YAML-based key definitions
- CI/CD Ready: Perfect for automation pipelines
๐ฆ Installation #
dart pub global activate flutter_keycheck
๐ Quick Start #
- Create a keys configuration file:
# expected_keys.yaml
keys:
  - login_button
  - password_field
  - submit_button
  - help_tooltip
  - user_profile_card
- Run the validator:
flutter_keycheck --keys expected_keys.yaml
๐ Usage #
Basic Usage #
# Check keys in current directory
flutter_keycheck --keys expected_keys.yaml
# Check specific project path
flutter_keycheck --keys keys/production.yaml --path ./my_flutter_app
# Strict mode (fail on extra keys)
flutter_keycheck --keys expected_keys.yaml --strict
# Verbose output
flutter_keycheck --keys expected_keys.yaml --verbose
Command Line Options #
| Option | Short | Description | Default | 
|---|---|---|---|
| --keys | -k | Path to keys file (.yaml) | required | 
| --path | -p | Project source root | . | 
| --strict | -s | Fail if integration_test/appium_test.dart is missing | false | 
| --verbose | -v | Show detailed output | false | 
| --help | -h | Show help message | - | 
๐ Example Output #
๐ฏ [flutter_keycheck] ๐ Scanning project...
๐งฉ Keys Check
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ Missing Keys:
โ๏ธ login_button
โ๏ธ forgot_password_link
๐งผ Extra Keys:
๐ก debug_menu_button
๐ก temp_test_key
๐ Found Keys:
โ๏ธ password_input_field
โโโ lib/screens/auth/login_screen.dart
โ๏ธ submit_button
โโโ lib/widgets/forms/auth_form.dart
โโโ integration_test/auth_test.dart
๐ฆ Dependencies
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ๏ธ integration_test found in pubspec.yaml โ
โ๏ธ appium_flutter_server found in pubspec.yaml โ
๐งช Integration Test Setup
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ๏ธ Found integration_test/appium_test.dart โ
โ๏ธ Appium Flutter Driver initialized โ
๐จ Final Verdict
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ Project is NOT ready for automation build.
Missing 2 required keys. Please add them to your widgets.
๐ Supported Key Types #
1. Widget Keys #
// ValueKey
TextField(key: const ValueKey('email_input'))
ElevatedButton(key: const ValueKey('login_button'))
// Regular Key
Container(key: const Key('user_avatar'))
2. Test Finders #
// Integration tests
await tester.tap(find.byValueKey('login_button'));
await tester.enterText(find.byValueKey('email_input'), 'test@example.com');
// Semantic labels
await tester.tap(find.bySemanticsLabel('Submit Form'));
// Tooltips
await tester.tap(find.byTooltip('Help Information'));
๐ Configuration #
YAML Format #
keys:
  # Static keys
  - login_button
  - password_field
  - submit_button
  # Dynamic keys (with placeholders)
  - user_card_{userId}
  - game_level_{levelId}
  # Semantic labels
  - 'Welcome Message'
  - 'Error Dialog'
  # Tooltips
  - 'Help Button'
  - 'Settings Menu'
๐งช Appium Flutter Integration Setup #
For complete Appium Flutter integration testing setup, follow the official documentation:
๐ Appium Flutter Integration Driver Setup Guide
Quick Setup Steps #
- Add dependency to pubspec.yaml:
dev_dependencies:
  appium_flutter_server: '>=0.0.27 <1.0.0'
- Create integration_test/appium_test.dart:
import 'package:appium_flutter_server/appium_flutter_server.dart';
import 'package:your_app/main.dart';
void main() {
  initializeTest(app: const MyApp());
}
- Build your app for testing:
# Android
./gradlew app:assembleDebug -Ptarget=`pwd`/../integration_test/appium_test.dart
# iOS Simulator
flutter build ios integration_test/appium_test.dart --simulator
What flutter_keycheck validates #
โ Widget Keys - ValueKey and Key declarations in your widgets โ Test Finders - find.byValueKey, find.bySemanticsLabel, find.byTooltip usage โ Dependencies - Required integration_test and appium_flutter_server packages โ Test Setup - Proper integration test file structure
๐ง Integration with CI/CD #
GitHub Actions #
name: Flutter Key Check
on: [push, pull_request]
jobs:
  key-check:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v3
      - uses: dart-lang/setup-dart@v1
      - name: Install flutter_keycheck
        run: dart pub global activate flutter_keycheck
      - name: Validate keys
        run: flutter_keycheck --keys expected_keys.yaml --strict
Pre-commit Hook #
#!/bin/sh
# .git/hooks/pre-commit
flutter_keycheck --keys expected_keys.yaml --strict
if [ $? -ne 0 ]; then
  echo "โ Key validation failed. Please fix the issues above."
  exit 1
fi
๐ ๏ธ Development #
Running Tests #
dart test
Running from Source #
dart run bin/flutter_keycheck.dart --keys keys/testing_keys.yaml
๐ก Best Practices #
- 
Organize Keys by Feature keys: # Authentication - login_button - signup_link - password_field # Profile - edit_profile_button - save_changes_button
- 
Use Descriptive Names // โ Good ValueKey('user_profile_edit_button') // โ Avoid ValueKey('btn1')
- 
Keep Keys Consistent // Use consistent naming convention ValueKey('login_email_field') ValueKey('login_password_field') ValueKey('login_submit_button')
๐ค Contributing #
- Fork the repository
- Create your feature branch (git checkout -b feature/amazing-feature)
- Commit your changes (git commit -m 'Add some amazing feature')
- Push to the branch (git push origin feature/amazing-feature)
- Open a Pull Request
๐ License #
This project is licensed under the MIT License - see the LICENSE file for details.
๐ Acknowledgments #
- Built for Flutter automation testing
- Inspired by the need for reliable UI test coverage
- Perfect for CI/CD integration
- Works seamlessly with Appium Flutter Integration Driver