flutter_keycheck 1.0.3 copy "flutter_keycheck: ^1.0.3" to clipboard
flutter_keycheck: ^1.0.3 copied to clipboard

A CLI tool for verifying presence of ValueKey elements and test dependencies in Flutter projects.

Flutter Key Integration Validator #

pub package License: MIT Dart

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
    • ValueKey declarations
    • Key declarations
    • find.byValueKey finders
    • find.bySemanticsLabel finders
    • find.byTooltip finders
  • 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 #

  1. Create a keys configuration file:
# expected_keys.yaml
keys:
  - login_button
  - password_field
  - submit_button
  - help_tooltip
  - user_profile_card
  1. 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 #

  1. Add dependency to pubspec.yaml:
dev_dependencies:
  appium_flutter_server: '>=0.0.27 <1.0.0'
  1. 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());
}
  1. 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 #

  1. Organize Keys by Feature

    keys:
      # Authentication
      - login_button
      - signup_link
      - password_field
    
      # Profile
      - edit_profile_button
      - save_changes_button
    
  2. Use Descriptive Names

    // โœ… Good
    ValueKey('user_profile_edit_button')
    
    // โŒ Avoid
    ValueKey('btn1')
    
  3. Keep Keys Consistent

    // Use consistent naming convention
    ValueKey('login_email_field')
    ValueKey('login_password_field')
    ValueKey('login_submit_button')
    

๐Ÿค 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 #

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

๐Ÿ“š Resources #

0
likes
0
points
80
downloads

Publisher

unverified uploader

Weekly Downloads

A CLI tool for verifying presence of ValueKey elements and test dependencies in Flutter projects.

Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

ansicolor, args, cli_util, glob, path, yaml

More

Packages that depend on flutter_keycheck