Welltested is an AI testing autopilot for Flutter developers add and maintain intelligent tests coverage and deliver stable welltested apps to users.
Welltested is completely free for individual developers. To create an account, please sign up here.
Create a .env
file in root of your project, and add your key received in the email.
WELLTESTED_API=YOUR_API_KEY
We uses dotenv
to retrive API Key. Once .env
file is created, please declare it as an asset in pubspec.yaml
to make is accessible to the package.
assets:
- .env
Add the @Welltested()
annotation to the class whose methods are to be tested.
@Welltested()
class Auth {
Future<void> logInUser() {...}
Future<void> logOutUser() {...}
}
In the above case, it will generate unit tests for logInUser
and logOutUser
methods of Auth
class.
By default, all methods in an annotated class are included. To exclude any method from testing, add their name to the excludedMethods
list in the Welltested
annotation.
@Welltested(excludedMethods: ['logOutUser'])
class Auth {
Future<void> logInUser() {...}
Future<void> logOutUser() {...}
}
In the above case, it will not create unit tests for logOutUser
method.
To specify custom testcases for any method, use @Testcases()
annotation.
@Welltested()
class Auth {
@Testcases(['Throws exception when email is empty'])
Future<User> logInUser() {...}
}
To generate unit tests for annotated classes, please run the following command:
dart run welltested:ai build
At times, tests generated by welltested might have syntax issues. When encountering such issues, please makes the fixes and run the below command to save your changes. We remember your fixes and don't repeat the mistake.
dart run welltested:save build
To read detailed setup instructions, code guidelines and supported platform infromation, read our Usage Wiki.
- The minimum supported Flutter SDK version is 3.0.0 with Dart SDK 2.17.0. Any prior projects need to be upgraded for welltested to work.
For complete Example please check example project.