You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
samples/testing_app
Brett Morgan 84e7057abe
Update `pubspec.yaml` files (#958)
3 years ago
..
android Add desktop runners (#892) 3 years ago
integration_test Enforce `use_key_in_widget_constructors` and `file_names` lints (#913) 3 years ago
ios Landing beta changes in master for the new stable release (#747) 4 years ago
lib Remove unneeded types (#949) 3 years ago
linux Upgrade deps, format, fix web/filipino_cuisine (#898) 3 years ago
macos Add desktop runners (#892) 3 years ago
test Enforce `use_key_in_widget_constructors` and `file_names` lints (#913) 3 years ago
web Add desktop runners (#892) 3 years ago
windows Upgrade deps, format, fix web/filipino_cuisine (#898) 3 years ago
.gitignore Testing sample (#500) 4 years ago
.metadata Testing sample (#500) 4 years ago
README.md Add separate driver file for performance tests (#890) 3 years ago
analysis_options.yaml Enforce `use_key_in_widget_constructors` and `file_names` lints (#913) 3 years ago
pubspec.lock Update `pubspec.yaml` files (#958) 3 years ago
pubspec.yaml Upgrading samples to flutter_lints, part 1 of n (#804) 4 years ago

README.md

testing_app

A Sample app that shows different types of testing in Flutter.

This particular sample uses the Provider package but any other state management approach would do.

Goals for this sample

Show how to perform:

  • Widget Testing,
  • Integration Testing,
  • Performance Testing, and
  • State Management Testing using the Provider package.

How to run tests

  • Navigate to the project's root folder using command line and follow the instructions below.

To run tests using only the Flutter SDK:

The Flutter SDK can run unit tests and widget tests in a virtual machine, without the need of a physical device or emulator.

  • To run all the test files in the test/ directory in one go, run flutter test.
  • To run a particular test file, run flutter test test/<file_path>

To run tests on a physical device/emulator:

  • Widget Tests:
    • Run flutter run test/<file_path>
  • Integration Tests:
    • Run flutter drive --driver=integration_test/driver.dart --target=integration_test/app_test.dart
  • Performance Tests:
    • Run flutter drive --driver=integration_test/perf_driver.dart --target=integration_test/perf_test.dart --profile --trace-startup
      • Using a physical device and running performance tests in profile mode is recommended.
      • The --trace-startup option is used to avoid flushing older timeline events when the timeline gets long.
  • State Management Tests:
    • For testing state using Flutter Integration Tests
      • Run flutter drive --driver=integration_test/driver.dart --target=integration_test/state_mgmt_test.dart

To generate test coverage report:

  • Install the lcov tool:
    • For MacOS, run brew install lcov
    • For Linux, run sudo apt install lcov
  • Run tests with coverage:
    • flutter test --coverage
  • Convert lcov.info into readable html:
    • Run genhtml coverage/lcov.info -o coverage/index
  • Open coverage/index/index.html in your preferred browser.

CI/CD

  • Refer .github and the tool directory to see how to test Flutter projects using GitHub Actions.

Note that tools like GitHub Actions can't run tests on a physical device, which is required to run integration tests. Instead, you can use Firebase Test Lab, Codemagic or any platform of your choice to do that.

Questions/issues

If you have a general question about testing in Flutter, the best places to go are:

If you run into an issue with the sample itself, please file an issue.