Testing topic
Testing Made Easy
Flutter supplies the means to test your source code right away. This topic will introduce the test files used to regularly test the Fluttery Framework package itself. It's hoped this overview will give you an appreciation of how easily testing your own code can be in Flutter.
widget_test.dart | Test with Tester | App Tests | Structured Testing | Setup Testing |
widget_test.dart
Below is a screenshot of the widget_test.dart file that runs every time the Fluttery Framework package is about to be released with its latest changes. Much of the Fluttery Framework's functions and features are tested to assure no errors occur as a consequence any changes made. The video below depicts that testing being performed when this Dart file is simply run in an IDE. Both integration testing as well as unit testing is involved in the process.
As you see in the screenshot below, the example app's main widget, FlutteryExampleApp, is instantiated in the Lambda function, testWidgets.
It's the very widget you'd see passed to the runApp() function: void main() => runApp(FlutteryExampleApp());
.
Not only is the app started up, but its main controller, ExampleAppController, is assigned
to the variable, con. This is done, in this case, to read its property, .application, so to proceed
with the integration testing using the very three small example apps that accompanies the Fluttery Framework package.
widget_test.dart |
---|
Test with Tester
The screenshots below displays the counterTest() function and the contactsTest() function that are eventually called in the widget_test.dart file. Both take in the WidgetTester object, tester. It serves as the active agent in the test environment performing the virtual 'pressing of buttons', the 'swiping of screens' and all the other necessary interactions with the very widgets being tested. The test environment also supplies a conglomerate of Finders using the constant, find(), as well as the high-level function, expect(), to both isolate and test particular widgets for expected outcomes. If, at any point, such a test fails the whole testing process stops and reports the issue.
counter_test.dart | contacts_test.dart |
---|
App Tests
The first screenshot below highlights the data property referenced in the first screenshot above. Note, because the controllers in this app use factory constructors allowing only one single instance of a particular controller class, they can be readily used in such test environments to, in this case, confirm the counter app has had its button pressed nine times. You see, this CounterController object has the public property, data, incremented and then tested for the expected count.
The second screenshot is that of the _deleteContact() function called in the second screenshot above. It demonstrates how you're free to use a static property from the app itself to contribute to its very testing. In this case, the property, App.useMaterial, is utilized to determine which interface design the app is current running in (Material or Cupertino). This property comes from the App class and will be available to you the next time you write your app with the Fluttery Framework.
counter_controller.dart | contacts_test.dart |
---|
Structured Testing
There are currently some 52 test files involved with the Fluttery Framework package. Admittedly, not all are fully implemented, but with that number of Dart files, there had to be some organizing involved. The screenshot below conveys the directory structure used to contain these test files. Among these test files, there are a number of 'export' files (named with leading underscores) that collect, in a way, all of them together.
The screenshot also reveals the reams of export
statements that can be found in one of these export files listing out the test files contained in various folders.
That file and two others are listed below for your perusal:
_unit_test_view.dart
_unit_imports.dart
_test_imports.dart.
This all follows the Dart team’s own approach to organizing a library package
_test_imports.dart |
---|
With 'export' files, instead of your Dart files listing dozens of import
statements, you have just one or two 'import' statement taking in all that code.
The first screenshot below, for example, lists all the code taken in by the file, unit_tests.dart, in the second screenshot.
As a result, just one 'import' statement is necessary to complete the unit testing here. Very nice.
_unit_imports.dart | unit_tests.dart |
---|
Setup Testing
Below are screenshots of the Fluttery Framework's pubspec.yaml file.
You'll see highlighted the settings necessary for testing.
For example, the libraries, flutter_test
and integration_test,
have to be introduced into your pubspec.yaml file.
Unlike Fluttery Framework, for your app, place flutter_test library under the heading, dev_dependencies:
.
pubspec.yaml | pubspec.yaml |
---|
Further documentation on setting up and getting started is available to you at flutter.dev:
An introduction to widget testing
Testing Flutter apps
Classes
-
StateX<
T extends StatefulWidget> Get started StateX class Testing - The extension of the State class.
- StateXController Get started State Object Controller Testing Event handling
- Your 'working' class most concerned with the app's functionality. Add it to a 'StateX' object to associate it with that State object.