test 1.15.2

  • Readme
  • Changelog
  • Installing
  • 97

test provides a standard way of writing and running tests in Dart.

Writing Tests #

Tests are specified using the top-level test() function, and test assertions are made using expect():

import 'package:test/test.dart';

void main() {
  test('String.split() splits the string on the delimiter', () {
    var string = 'foo,bar,baz';
    expect(string.split(','), equals(['foo', 'bar', 'baz']));

  test('String.trim() removes surrounding whitespace', () {
    var string = '  foo ';
    expect(string.trim(), equals('foo'));

Tests can be grouped together using the group() function. Each group's description is added to the beginning of its test's descriptions.

import 'package:test/test.dart';

void main() {
  group('String', () {
    test('.split() splits the string on the delimiter', () {
      var string = 'foo,bar,baz';
      expect(string.split(','), equals(['foo', 'bar', 'baz']));

    test('.trim() removes surrounding whitespace', () {
      var string = '  foo ';
      expect(string.trim(), equals('foo'));

  group('int', () {
    test('.remainder() returns the remainder of division', () {
      expect(11.remainder(3), equals(2));

    test('.toRadixString() returns a hex string', () {
      expect(11.toRadixString(16), equals('b'));

Any matchers from the matcher package can be used with expect() to do complex validations:

import 'package:test/test.dart';

void main() {
  test('.split() splits the string on the delimiter', () {
    expect('foo,bar,baz', allOf([

You can also test exceptions with the throwsA() function or a matcher such as [throwsException]:

import 'package:test/test.dart';

void main() {
  test('.parse() fails on invalid input', () {
    expect(() => int.parse('X'), throwsFormatException);

You can use the setUp() and tearDown() functions to share code between tests. The setUp() callback will run before every test in a group or test suite, and tearDown() will run after. tearDown() will run even if a test fails, to ensure that it has a chance to clean up after itself.

import 'package:test/test.dart';

void main() {
  HttpServer server;
  Uri url;
  setUp(() async {
    server = await HttpServer.bind('localhost', 0);
    url = Uri.parse('http://${server.address.host}:${server.port}');

  tearDown(() async {
    await server.close(force: true);
    server = null;
    url = null;

  // ...

Running Tests #

A single test file can be run just using pub run test path/to/test.dart.

Single file being run via

Many tests can be run at a time using pub run test path/to/dir.

Directory being run via

It's also possible to run a test on the Dart VM only by invoking it using dart path/to/test.dart, but this doesn't load the full test runner and will be missing some features.

The test runner considers any file that ends with _test.dart to be a test file. If you don't pass any paths, it will run all the test files in your test/ directory, making it easy to test your entire application at once.

You can select specific tests cases to run by name using pub run test -n "test name". The string is interpreted as a regular expression, and only tests whose description (including any group descriptions) match that regular expression will be run. You can also use the -N flag to run tests whose names contain a plain-text string.

By default, tests are run in the Dart VM, but you can run them in the browser as well by passing pub run test -p chrome path/to/test.dart. test will take care of starting the browser and loading the tests, and all the results will be reported on the command line just like for VM tests. In fact, you can even run tests on both platforms with a single command: pub run test -p "chrome,vm" path/to/test.dart.

Sharding Tests #

Tests can also be sharded with the --total-shards and --shard-index arguments, allowing you to split up your test suites and run them separately. For example, if you wanted to run 3 shards of your test suite, you could run them as follows:

pub run test --total-shards 3 --shard-index 0 path/to/test.dart
pub run test --total-shards 3 --shard-index 1 path/to/test.dart
pub run test --total-shards 3 --shard-index 2 path/to/test.dart

Shuffling Tests #

Test order can be shuffled with the --test-randomize-ordering-seed argument. This allows you to shuffle your tests with a specific seed (deterministic) or a random seed for each run. For example, consider the following test runs:

pub run test --test-randomize-ordering-seed=12345
pub run test --test-randomize-ordering-seed=random

Setting --test-randomize-ordering-seed=0 will have the same effect as not specifying it at all, meaning the test order will remain as-is.

Collecting Code Coverage #

To collect code coverage, you can run tests with the --coverage <directory> argument. The directory specified can be an absolute or relative path. If a directory does not exist at the path specified, a directory will be created. If a directory does exist, files may be overwritten with the latest coverage data, if they conflict.

This option will enable code coverage collection on a suite-by-suite basis, and the resulting coverage files will be outputted in the directory specified. The files can then be formatted using the package:coverage format_coverage executable.

Coverage gathering is currently only implemented for tests run on the Dart VM or Chrome.

Restricting Tests to Certain Platforms #

Some test files only make sense to run on particular platforms. They may use dart:html or dart:io, they might test Windows' particular filesystem behavior, or they might use a feature that's only available in Chrome. The @TestOn annotation makes it easy to declare exactly which platforms a test file should run on. Just put it at the top of your file, before any library or import declarations:


import 'dart:io';

import 'package:test/test.dart';

void main() {
  // ...

The string you pass to @TestOn is what's called a "platform selector", and it specifies exactly which platforms a test can run on. It can be as simple as the name of a platform, or a more complex Dart-like boolean expression involving these platform names.

You can also declare that your entire package only works on certain platforms by adding a test_on field to your package config file.

Platform Selectors #

Platform selectors use the boolean selector syntax defined in the boolean_selector package, which is a subset of Dart's expression syntax that only supports boolean operations. The following identifiers are defined:

  • vm: Whether the test is running on the command-line Dart VM.

  • chrome: Whether the test is running on Google Chrome.

  • phantomjs: Whether the test is running on PhantomJS.

  • firefox: Whether the test is running on Mozilla Firefox.

  • safari: Whether the test is running on Apple Safari.

  • ie: Whether the test is running on Microsoft Internet Explorer.

  • node: Whether the test is running on Node.js.

  • dart-vm: Whether the test is running on the Dart VM in any context. It's identical to !js.

  • browser: Whether the test is running in any browser.

  • js: Whether the test has been compiled to JS. This is identical to !dart-vm.

  • blink: Whether the test is running in a browser that uses the Blink rendering engine.

  • windows: Whether the test is running on Windows. This can only be true if either vm or node is true.

  • mac-os: Whether the test is running on Mac OS. This can only be true if either vm or node is true.

  • linux: Whether the test is running on Linux. This can only be true if either vm or node is true.

  • android: Whether the test is running on Android. If vm is false, this will be false as well, which means that this won't be true if the test is running on an Android browser.

  • ios: Whether the test is running on iOS. If vm is false, this will be false as well, which means that this won't be true if the test is running on an iOS browser.

  • posix: Whether the test is running on a POSIX operating system. This is equivalent to !windows.

For example, if you wanted to run a test on every browser but Chrome, you would write @TestOn('browser && !chrome').

Running Tests on Node.js #

The test runner also supports compiling tests to JavaScript and running them on Node.js by passing --platform node. Note that Node has access to neither dart:html nor dart:io, so any platform-specific APIs will have to be invoked using the js package. However, it may be useful when testing APIs that are meant to be used by JavaScript code.

The test runner looks for an executable named node (on Mac OS or Linux) or node.exe (on Windows) on your system path. When compiling Node.js tests, it passes -Dnode=true, so tests can determine whether they're running on Node using const bool.fromEnvironment('node'). It also sets --server-mode, which will tell the compiler that dart:html is not available.

If a top-level node_modules directory exists, tests running on Node.js can import modules from it.

Asynchronous Tests #

Tests written with async/await will work automatically. The test runner won't consider the test finished until the returned Future completes.

import 'dart:async';

import 'package:test/test.dart';

void main() {
  test('Future.value() returns the value', () async {
    var value = await Future.value(10);
    expect(value, equals(10));

There are also a number of useful functions and matchers for more advanced asynchrony. The completion() matcher can be used to test Futures; it ensures that the test doesn't finish until the Future completes, and runs a matcher against that Future's value.

import 'dart:async';

import 'package:test/test.dart';

void main() {
  test('Future.value() returns the value', () {
    expect(Future.value(10), completion(equals(10)));

The throwsA() matcher and the various throwsExceptionType matchers work with both synchronous callbacks and asynchronous Futures. They ensure that a particular type of exception is thrown:

import 'dart:async';

import 'package:test/test.dart';

void main() {
  test('Future.error() throws the error', () {
    expect(Future.error('oh no'), throwsA(equals('oh no')));
    expect(Future.error(StateError('bad state')), throwsStateError);

The expectAsync() function wraps another function and has two jobs. First, it asserts that the wrapped function is called a certain number of times, and will cause the test to fail if it's called too often; second, it keeps the test from finishing until the function is called the requisite number of times.

import 'dart:async';

import 'package:test/test.dart';

void main() {
  test('Stream.fromIterable() emits the values in the iterable', () {
    var stream = Stream.fromIterable([1, 2, 3]);

    stream.listen(expectAsync1((number) {
      expect(number, inInclusiveRange(1, 3));
    }, count: 3));

Stream Matchers #

The test package provides a suite of powerful matchers for dealing with asynchronous streams. They're expressive and composable, and make it easy to write complex expectations about the values emitted by a stream. For example:

import 'dart:async';

import 'package:test/test.dart';

void main() {
  test('process emits status messages', () {
    // Dummy data to mimic something that might be emitted by a process.
    var stdoutLines = Stream.fromIterable([
      'Loading took 150ms.',

    expect(stdoutLines, emitsInOrder([
      // Values match individual events.

      // Matchers also run against individual events.
      startsWith('Loading took'),

      // Stream matchers can be nested. This asserts that one of two events are
      // emitted after the "Loading took" line.
      emitsAnyOf(['Succeeded!', 'Failed!']),

      // By default, more events are allowed after the matcher finishes
      // matching. This asserts instead that the stream emits a done event and
      // nothing else.

A stream matcher can also match the async package's StreamQueue class, which allows events to be requested from a stream rather than pushed to the consumer. The matcher will consume the matched events, but leave the rest of the queue alone so that it can still be used by the test, unlike a normal Stream which can only have one subscriber. For example:

import 'dart:async';

import 'package:async/async.dart';
import 'package:test/test.dart';

void main() {
  test('process emits a WebSocket URL', () async {
    // Wrap the Stream in a StreamQueue so that we can request events.
    var stdout = StreamQueue(Stream.fromIterable([
      'WebSocket URL:',
      'Waiting for connection...'

    // Ignore lines from the process until it's about to emit the URL.
    await expectLater(stdout, emitsThrough('WebSocket URL:'));

    // Parse the next line as a URL.
    var url = Uri.parse(await stdout.next);
    expect(url.host, equals('localhost'));

    // You can match against the same StreamQueue multiple times.
    await expectLater(stdout, emits('Waiting for connection...'));

The following built-in stream matchers are available:

  • emits() matches a single data event.
  • emitsError() matches a single error event.
  • emitsDone matches a single done event.
  • mayEmit() consumes events if they match an inner matcher, without requiring them to match.
  • mayEmitMultiple() works like mayEmit(), but it matches events against the matcher as many times as possible.
  • emitsAnyOf() consumes events matching one (or more) of several possible matchers.
  • emitsInOrder() consumes events matching multiple matchers in a row.
  • emitsInAnyOrder() works like emitsInOrder(), but it allows the matchers to match in any order.
  • neverEmits() matches a stream that finishes without matching an inner matcher.

You can also define your own custom stream matchers with StreamMatcher().

Running Tests With Custom HTML #

By default, the test runner will generate its own empty HTML file for browser tests. However, tests that need custom HTML can create their own files. These files have three requirements:

  • They must have the same name as the test, with .dart replaced by .html. You can also provide a configuration path to an html file if you want it to be reused across all tests. See Providing a custom HTML template below.

  • They must contain a link tag with rel="x-dart-test" and an href attribute pointing to the test script.

  • They must contain <script src="packages/test/dart.js"></script>.

For example, if you had a test called custom_html_test.dart, you might write the following HTML file:

<!doctype html>
<!-- custom_html_test.html -->
    <title>Custom HTML Test</title>
    <link rel="x-dart-test" href="custom_html_test.dart">
    <script src="packages/test/dart.js"></script>
    // ...

Providing a custom HTML template #

If you want to share the same HTML file across all tests, you can provide a custom-html-template-path configuration option to your configuration file. This file should follow the rules above, except that instead of the link tag add exactly one {{testScript}} in the place where you want the template processor to insert it.

You can also optionally use any number of {{testName}} placeholders which will be replaced by the test filename.

The template can't be named like any test file, as that would clash with using the custom HTML mechanics. In such a case, an error will be thrown.

For example:

custom-html-template-path: html_template.html.tpl
<!doctype html>
<!-- html_template.html.tpl -->
    <title>{{testName}} Test</title>
    <script src="packages/test/dart.js"></script>
    // ...

Configuring Tests #

Skipping Tests #

If a test, group, or entire suite isn't working yet and you just want it to stop complaining, you can mark it as "skipped". The test or tests won't be run, and, if you supply a reason why, that reason will be printed. In general, skipping tests indicates that they should run but is temporarily not working. If they're is fundamentally incompatible with a platform, @TestOn/testOn should be used instead.

To skip a test suite, put a @Skip annotation at the top of the file:

@Skip('currently failing (see issue 1234)')

import 'package:test/test.dart';

void main() {
  // ...

The string you pass should describe why the test is skipped. You don't have to include it, but it's a good idea to document why the test isn't running.

Groups and individual tests can be skipped by passing the skip parameter. This can be either true or a String describing why the test is skipped. For example:

import 'package:test/test.dart';

void main() {
  group('complicated algorithm tests', () {
    // ...
  }, skip: "the algorithm isn't quite right");

  test('error-checking test', () {
    // ...
  }, skip: 'TODO: add error-checking.');

Timeouts #

By default, tests will time out after 30 seconds of inactivity. The timeout applies to deadlocks or cases where the test stops making progress, it does not ensure that an overall test case or test suite completes within any set time.

Timeouts can be configured on a per-test, -group, or -suite basis. To change the timeout for a test suite, put a @Timeout annotation at the top of the file:

@Timeout(const Duration(seconds: 45))

import 'package:test/test.dart';

void main() {
  // ...

In addition to setting an absolute timeout, you can set the timeout relative to the default using @Timeout.factor. For example, @Timeout.factor(1.5) will set the timeout to one and a half times as long as the default—45 seconds.

Timeouts can be set for tests and groups using the timeout parameter. This parameter takes a Timeout object just like the annotation. For example:

import 'package:test/test.dart';

void main() {
  group('slow tests', () {
    // ...

    test('even slower test', () {
      // ...
    }, timeout: Timeout.factor(2))
  }, timeout: Timeout(Duration(minutes: 1)));

Nested timeouts apply in order from outermost to innermost. That means that "even slower test" will take two minutes to time out, since it multiplies the group's timeout by 2.

Platform-Specific Configuration #

Sometimes a test may need to be configured differently for different platforms. Windows might run your code slower than other platforms, or your DOM manipulation might not work right on Safari yet. For these cases, you can use the @OnPlatform annotation and the onPlatform named parameter to test() and group(). For example:

@OnPlatform(const {
  // Give Windows some extra wiggle-room before timing out.
  'windows': const Timeout.factor(2)

import 'package:test/test.dart';

void main() {
  test('do a thing', () {
    // ...
  }, onPlatform: {
    'safari': Skip('Safari is currently broken (see #1234)')

Both the annotation and the parameter take a map. The map's keys are platform selectors which describe the platforms for which the specialized configuration applies. Its values are instances of some of the same annotation classes that can be used for a suite: Skip and Timeout. A value can also be a list of these values.

If multiple platforms match, the configuration is applied in order from first to last, just as they would in nested groups. This means that for configuration like duration-based timeouts, the last matching value wins.

You can also set up global platform-specific configuration using the package configuration file.

Tagging Tests #

Tags are short strings that you can associate with tests, groups, and suites. They don't have any built-in meaning, but they're very useful nonetheless: you can associate your own custom configuration with them, or you can use them to easily filter tests so you only run the ones you need to.

Tags are defined using the @Tags annotation for suites and the tags named parameter to test() and group(). For example:

@Tags(const ['browser'])

import 'package:test/test.dart';

void main() {
  test('successfully launches Chrome', () {
    // ...
  }, tags: 'chrome');

  test('launches two browsers at once', () {
    // ...
  }, tags: ['chrome', 'firefox']);

If the test runner encounters a tag that wasn't declared in the package configuration file, it'll print a warning, so be sure to include all your tags there. You can also use the file to provide default configuration for tags, like giving all browser tests twice as much time before they time out.

Tests can be filtered based on their tags by passing command line flags. The --tags or -t flag will cause the test runner to only run tests with the given tags, and the --exclude-tags or -x flag will cause it to only run tests without the given tags. These flags also support boolean selector syntax. For example, you can pass --tags "(chrome || firefox) && !slow" to select quick Chrome or Firefox tests.

Note that tags must be valid Dart identifiers, although they may also contain hyphens.

Whole-Package Configuration #

For configuration that applies across multiple files, or even the entire package, test supports a configuration file called dart_test.yaml. At its simplest, this file can contain the same sort of configuration that can be passed as command-line arguments:

# This package's tests are very slow. Double the default timeout.
timeout: 2x

# This is a browser-only package, so test on chrome by default.
platforms: [chrome]

The configuration file sets new defaults. These defaults can still be overridden by command-line arguments, just like the built-in defaults. In the example above, you could pass --platform firefox to run on Firefox.

A configuration file can do much more than just set global defaults. See the full documentation for more details.

Debugging #

Tests can be debugged interactively using platforms' built-in development tools. Tests running on browsers can use those browsers' development consoles to inspect the document, set breakpoints, and step through code. Those running on the Dart VM use the Dart Observatory's .

The first step when debugging is to pass the --pause-after-load flag to the test runner. This pauses the browser after each test suite has loaded, so that you have time to open the development tools and set breakpoints. For PhantomJS, and the Dart VM it will print the remote debugger URL.

Once you've set breakpoints, either click the big arrow in the middle of the web page or press Enter in your terminal to start the tests running. When you hit a breakpoint, the runner will open its own debugging console in the terminal that controls how tests are run. You can type "restart" there to re-run your test as many times as you need to figure out what's going on.

Normally, browser tests are run in hidden iframes. However, when debugging, the iframe for the current test suite is expanded to fill the browser window so you can see and interact with any HTML it renders. Note that the Dart animation may still be visible behind the iframe; to hide it, just add a background-color to the page's HTML.

Browser/VM Hybrid Tests #

Code that's written for the browser often needs to talk to some kind of server. Maybe you're testing the HTML served by your app, or maybe you're writing a library that communicates over WebSockets. We call tests that run code on both the browser and the VM hybrid tests.

Hybrid tests use one of two functions: spawnHybridCode() and spawnHybridUri(). Both of these spawn Dart VM isolates that can import dart:io and other VM-only libraries. The only difference is where the code from the isolate comes from: spawnHybridCode() takes a chunk of actual Dart code, whereas spawnHybridUri() takes a URL. They both return a StreamChannel that communicates with the hybrid isolate. For example:

// ## test/web_socket_server.dart

// The library loaded by spawnHybridUri() can import any packages that your
// package depends on, including those that only work on the VM.
import 'package:shelf/shelf_io.dart' as io;
import 'package:shelf_web_socket/shelf_web_socket.dart';
import 'package:stream_channel/stream_channel.dart';

// Once the hybrid isolate starts, it will call the special function
// hybridMain() with a StreamChannel that's connected to the channel
// returned spawnHybridCode().
hybridMain(StreamChannel channel) async {
  // Start a WebSocket server that just sends "hello!" to its clients.
  var server = await io.serve(webSocketHandler((webSocket) {
  }), 'localhost', 0);

  // Send the port number of the WebSocket server to the browser test, so
  // it knows what to connect to.

// ## test/web_socket_test.dart


import 'dart:html';

import 'package:test/test.dart';

void main() {
  test('connects to a server-side WebSocket', () async {
    // Each spawnHybrid function returns a StreamChannel that communicates with
    // the hybrid isolate. You can close this channel to kill the isolate.
    var channel = spawnHybridUri('web_socket_server.dart');

    // Get the port for the WebSocket server from the hybrid isolate.
    var port = await channel.stream.first;

    var socket = WebSocket('ws://localhost:$port');
    var message = await socket.onMessage.first;
    expect(message.data, equals('hello!'));

A diagram showing a test in a browser communicating with a Dart VM isolate outside the browser.

Note: If you write hybrid tests, be sure to add a dependency on the stream_channel package, since you're using its API!

Support for Other Packages #

build_runner #

If you are using package:build_runner to build your package, then you will need a dependency on build_test in your dev_dependencies, and then you can use the pub run build_runner test command to run tests.

To supply arguments to package:test, you need to separate them from your build args with a -- argument. For example, running all web tests in release mode would look like this pub run build_runner test --release -- -p vm.

term_glyph #

The term_glyph package provides getters for Unicode glyphs with ASCII alternatives. test ensures that it's configured to produce ASCII when the user is running on Windows, where Unicode isn't supported. This ensures that testing libraries can use Unicode on POSIX operating systems without breaking Windows users.

Further Reading #

Check out the API docs for detailed information about all the functions available to tests.

The test runner also supports a machine-readable JSON-based reporter. This reporter allows the test runner to be wrapped and its progress presented in custom ways (for example, in an IDE). See the protocol documentation for more details.

1.15.2 #

  • Use the latest test_core which resolves an issue with the latest package:meta.

1.15.1 #

  • Avoid a confusing stack trace when there is a problem loading a platform when using the JSON reporter and enabling debugging.
  • Restore behavior of listening for both IPv6 and IPv4 sockets for the node platform.

1.15.0 #

  • Update bootstrapping logic to ensure the bootstrap library has the same language version as the test.
  • The Node platform will now communicate over only IPv6 if it is available.

1.14.7 #

  • Support the latest package:coverage.

1.14.6 #

  • Update test_core to 0.3.6.

1.14.5 #

  • Add additional information to an exception when we end up with a null RunnerSuite.

1.14.4 #

  • Use non-headless Chrome when provided the flag --pause-after-load.

1.14.3 #

  • Fix an issue where coverage tests could not run in Chrome headless.
  • Fix an issue where coverage collection would not work with source maps that contained absolute file URIs.
  • Fix error messages for incorrect string literals in test annotations.
  • Update test_core to 0.3.4.

1.14.2 #

  • Update test_core to 0.3.3.

1.14.1 #

  • Allow the latest shelf_packages_handler.

1.14.0 #

  • Drop the package_resolver dependency for the package_config dependency which is lower level.

1.13.0 #

  • Enable asserts in code running through spawnHybrid APIs.
  • Exit with a non-zero code if no tests were ran, whether due to skips or having no tests defined.
  • Fix the stack trace labels in SDK code for dart2js compiled tests.
  • Cancel any StreamQueue that is created as a part of a stream matcher once it is done matching.
    • This fixes a bug where using a matcher on a custom stream controller and then awaiting the close() method on that controller would hang.
  • Avoid causing the test runner to hang if there is a timeout during a tearDown callback following a failing test case.

1.12.0 #

  • Bump minimum SDK to 2.4.0 for safer usage of for-loop elements.
  • Deprecate PhantomJS and provide warning when used. Support for PhantomJS will be removed in version 2.0.0.
  • Support coverage collection for the Chrome platform. See README.md for usage details.

1.11.1 #

  • Allow test_api 0.2.13 to work around a bug in the SDK version 2.3.0.

1.11.0 #

  • Add file_reporters configuration option and --file-reporter CLI option to allow specifying a separate reporter that writes to a file instead of stdout.

1.10.0 #

  • Add customHtmlTemplateFile configuration option to allow sharing an html template between tests
  • Depend on the latest package:test_core.
  • Depend on the latest package:test_api.

1.9.4 #

  • Extend the timeout for synthetic tests, e.g. tearDownAll.
  • Depend on the latest package:test_core.
  • Depend on the latest package:test_api.

1.9.3 #

  • Depend on the latest package:test_core.
  • Support the latest package:analyzer.
  • Update to latest package:matcher. Improves output for instances of private classes.

1.9.2 #

  • Depend on the latest package:test_api and package:test_core.
  • While using solo tests that are not run will now be reported as skipped.

1.9.1 #

  • Depend on latest test_core.

1.9.0 #

  • Implement code coverage collection for VM based tests

1.8.0 #

  • Expose the previously hidden sharding arguments
    • --total-shards specifies how many shards the suite should be split into
    • --shard-index specifies which shard should be run

1.7.0 #

  • Add a --debug flag for running the VM/Chrome in debug mode.

1.6.11 #

  • Depend on the latest test_core and test_api.

1.6.10 #

  • Depend on the latest test_core.

1.6.9 #

  • Add --disable-dev-shm-usage to the default Chrome flags.

1.6.8 #

  • Depend on the latest test_core and test_api.

1.6.7 #

  • Allow analyzer version 0.38.x.

1.6.6 #

  • Pass --server-mode to dart2js instead of --categories=Server to fix a warning about the flag deprecation.
  • Drop dependency on pub_semver.
  • Fix issue with the latest Utf8Decoder and the node platform.

1.6.5 #

  • Depend on the latest test_core.
  • Depend on the latest package:analyzer.

1.6.4 #

  • Don't swallow exceptions from callbacks in expectAsync*.
  • Internal cleanup - fix lints.

1.6.3 #

  • Depend on latests package:test_core.
    • This fixes an issue where non-completed tests were considered passing.

1.6.2 #

  • Avoid dart:isolate imports on code loaded in tests.

1.6.1 #

  • Allow stream_channel version 2.0.0.

1.6.0 #

  • Allow analyzer version 0.36.x.
  • Matcher changes:
    • Add isA() to create TypeMatcher instances in a more fluent way.
    • Add isCastError.
    • Potentially breaking bug fix. Ordering matchers no longer treat objects with a partial ordering (such as NaN for double values) as if they had a complete ordering. For instance greaterThan now compares with the > operator rather not < and not =. This could cause tests which relied on this bug to start failing.

1.5.3 #

  • Allow analyzer version 0.35.x.

1.5.2 #

  • Require Dart SDK >=2.1.0.
  • Depend on latest test_core and test_api.

1.5.1 #

  • Depend on latest test_core and test_api.

1.5.0 #

  • Depend on package:test_core for core functionality.

1.4.0 #

  • Depend on package:test_api for core functionality.

1.3.4 #

  • Allow remote_listener to be closed and sent an event on close.

1.3.3 #

  • Add conditional imports so that dart:io is not imported from the main test.dart entrypoint unless it is available.
  • Fix an issue with dartdevc in precompiled mode and the json reporter.
  • Fix an issue parsing test metadata annotations without explicit const.

1.3.2 #

  • Widen the constraints on the analyzer package.

1.3.1 #

  • Handle parsing annotations which omit const on collection literals.
  • Fix an issue where root_line, root_column, and root_url in the JSON reported may not be populated correctly on Windows.
  • Removed requirement for the test/pub_serve transformer in --pub-serve mode.

1.3.0 #

  • When using --precompiled, the test runner now allows symlinks to reach outside the precompiled directory. This allows more efficient creation of precompiled directories (using symlinks instead of copies).
  • Updated max sdk range to <3.0.0.

1.2.0 #

  • Added support for using precompiled kernel files when running vm tests.
    • When using the --precompiled flag we will now first check for a <original-test-path>.vm_test.vm.app.dill file, and if present load that directly in the isolate. Otherwise the <original-test-path>.vm_test.dart file will be used.

1.1.0 #

  • Added a new pid field to the StartEvent in the json runner containing the pid of the VM process running the tests.

1.0.0 #

  • No change from 0.12.42. We are simply signalling to users that this is a well supported package and is the prefered way to write Dart tests.

0.12.42 #

  • Add support for solo test and group. When the argument is true only tests and groups marked as solo will be run. It is still recommended that users instead filter their tests by using the runner argument -n.

  • Updated exported package:matcher to 0.12.3 which includes these updates:

    • Many improvements to TypeMatcher

      • Can now be used directly as const TypeMatcher<MyType>().

      • Added a type parameter to specify the target Type.

        • Made the name constructor parameter optional and marked it deprecated. It's redundant to the type parameter.
      • Migrated all isType matchers to TypeMatcher.

      • Added a having function that allows chained validations of specific features of the target type.

        /// Validates that the object is a [RangeError] with a message containing
        /// the string 'details' and `start` and `end` properties that are `null`.
        final _rangeMatcher = isRangeError
           .having((e) => e.message, 'message', contains('details'))
           .having((e) => e.start, 'start', isNull)
           .having((e) => e.end, 'end', isNull);
    • Deprecated the isInstanceOf class. Use TypeMatcher instead.

    • Improved the output of Matcher instances that fail due to type errors.

0.12.41 #

  • Add support for debugging VM tests.
  • Tweak default reporter and color logic again so that they are always enabled on all non-windows platforms.

0.12.40 #

  • Added some new optional fields to the json reporter, root_line, root_column, and root_url. These will be present if url is not the same as the suite url, and will represent the location in the original test suite from which the call to test originated.

0.12.39 #

  • Change the default reporter and color defaults to be based on stdout.supportsAnsiEscapes instead of based on platform (previously both were disabled on windows).

0.12.38+3 #

  • Fix Dart 2 runtime errors around communicating with browsers.

0.12.38+2 #

  • Fix more Dart 2 runtime type errors.

0.12.38+1 #

  • Fix several Dart 2 runtime type errors.

0.12.38 #

  • Give neverCalled a type that works in Dart 2 semantics.
  • Support package:analyzer 0.32.0.

0.12.37 #

  • Removed the transformer, and the pub_serve.dart entrypoint. This is not being treated as a breaking change because the minimum sdk constraint now points to an sdk which does not support pub serve or barback any more anyways.
  • Drop the dependency on barback.

0.12.36 #

  • Expose the test bootstrapping methods, so that build systems can precompile tests without relying on internal apis.

0.12.35 #

  • Dropped support for Dart 1. Going forward only Dart 2 will be supported.
    • If you experience blocking issues and are still on the Dart 1 sdk, we will consider bug fixes on a per-case basis based on severity and impact.
    • Drop support for dartium and content-shell platforms since those are removed from the Dart 2 SDK.
  • Fixed an issue --precompiled node tests in subdirectories.
  • Fixed some dart2 issues with node test bootstrapping code so that dartdevc tests can run.
  • Fixed default custom html handler so it correctly includes the packages/test/dart.js file. This allows you to get proper errors instead of timeouts if there are load exceptions in the browser.
  • Upgrade to package:matcher 0.12.2

0.12.34 #

  • Requires at least Dart 1.24.0.
  • The --precompiled flag is now supported for the vm platform and the node platform.
  • On browser platforms the --precompiled flag now serves all sources directly from the precompiled directory, and will never attempt to do its own compilation.

0.12.33 #

  • Pass --categories=Server to dart2js when compiling tests for Node.js. This tells it that dart:html is unavailable.

  • Don't crash when attempting to format stack traces when running via dart path/to/test.dart.

0.12.32+2 #

  • Work around an SDK bug that caused timeouts in asynchronous code.

0.12.32+1 #

  • Fix a bug that broke content shell on Dart 1.24.

0.12.32 #

  • Add an include configuration field which specifies the path to another configuration file whose configuration should be used.

  • Add a google platform selector variable that's only true on Google's internal infrastructure.

0.12.31 #

  • Add a headless configuration option for Chrome.

  • Re-enable headless mode for Chrome by default.

  • Don't hang when a Node.js test fails to compile.

0.12.30+4 #

  • Stop running Chrome in headless mode temporarily to work around a browser bug.

0.12.30+3 #

  • Fix a memory leak when loading browser tests.

0.12.30+2 #

  • Avoid loading test suites whose tags are excluded by --excluded-tags.

0.12.30+1 #

  • Internal changes.

0.12.30 #

  • Platform selectors for operating systems now work for Node.js tests (#742).

  • fail() is now typed to return Null, so it can be used in the same places as a raw throw.

  • Run Chrome in headless mode unless debugging is enabled.

0.12.29+1 #

  • Fix strong mode runtime cast failures.

0.12.29 #

  • Node.js tests can now import modules from a top-level node_modules directory, if one exists.

  • Raw console.log() calls no longer crash Node.js tests.

  • When a browser crashes, include its standard output in the error message.

0.12.28+1 #

  • Add a pumpEventQueue() function to make it easy to wait until all asynchronous tasks are complete.

  • Add a neverCalled getter that returns a function that causes the test to fail if it's ever called.

0.12.27+1 #

  • Increase the timeout for loading tests to 12 minutes.

0.12.27 #

  • When addTearDown() is called within a call to setUpAll(), it runs its callback after all tests instead of running it after the setUpAll() callback.

  • When running in an interactive terminal, the test runner now prints status lines as wide as the terminal and no wider.

0.12.26+1 #

  • Fix lower bound on package stack_trace. Now 1.6.0.
  • Manually close browser process streams to prevent test hangs.

0.12.26 #

  • The spawnHybridUri() function now allows root-relative URLs, which are interpreted as relative to the root of the package.

0.12.25 #

  • Add a override_platforms configuration field which allows test platforms' settings (such as browsers' executables) to be overridden by the user.

  • Add a define_platforms configuration field which makes it possible to define new platforms that use the same logic as existing ones but have different settings.

0.12.24+8 #

  • spawnHybridUri() now interprets relative URIs correctly in browser tests.

0.12.24+7 #

  • Declare support for async 2.0.0.

0.12.24+6 #

  • Small refactoring to make the package compatible with strong-mode compliant Zone API. No user-visible change.

0.12.24+5 #

  • Expose a way for tests to forward a loadException to the server.

0.12.24+4 #

  • Drain browser process stdout and stdin. This resolves test flakiness, especially in Travis with the Precise image.

0.12.24+3 #

  • Extend deserializeTimeout.

0.12.24+2 #

  • Only force exit if FORCE_TEST_EXIT is set in the environment.

0.12.24+1 #

  • Widen version constraint on analyzer.

0.12.24 #

  • Add a node platform for compiling tests to JavaScript and running them on Node.js.

0.12.23+1 #

  • Remove unused imports.

0.12.23 #

  • Add a fold_stack_frames field for dart_test.yaml. This will allow users to customize which packages' frames are folded.

0.12.22+2 #

  • Properly allocate ports when debugging Chrome and Dartium in an IPv6-only environment.

0.12.22+1 #

  • Support args 1.0.0.

  • Run tear-down callbacks in the same error zone as the test function. This makes it possible to safely share Futures and Streams between tests and their tear-downs.

0.12.22 #

  • Add a retry option to test() and group() functions, as well as @Retry() annotation for test files and a retry configuration field for dart_test.yaml. A test with reties enabled will be re-run if it fails for a reason other than a TestFailure.

  • Add a --no-retry runner flag that disables retries of failing tests.

  • Fix a "concurrent modification during iteration" error when calling addTearDown() from within a tear down.

0.12.21 #

  • Add a doesNotComplete matcher that asserts that a Future never completes.

  • throwsA() and all related matchers will now match functions that return Futures that emit exceptions.

  • Respect onPlatform for groups.

  • Only print browser load errors once per browser.

  • Gracefully time out when attempting to deserialize a test suite.

0.12.20+13 #

  • Upgrade to package:matcher 0.12.1

0.12.20+12 #

  • Now support v0.30.0 of pkg/analyzer

  • The test executable now does a "hard exit" when complete to ensure lingering isolates or async code don't block completion. This may affect users trying to use the Dart service protocol or observatory.

0.12.20+11 #

  • Refactor bootstrapping to simplify the test/pub_serve transformer.

0.12.20+10 #

  • Refactor for internal tools.

0.12.20+9 #

  • Introduce new flag --chain-stack-traces to conditionally chain stack traces.

0.12.20+8 #

  • Fixed more blockers for compiling with dev_compiler.

  • Dartfmt the entire repo.

  • Note: 0.12.20+5-0.12.20+7 were tagged but not officially published.

0.12.20+4 #

  • Fixed strong-mode errors and other blockers for compiling with dev_compiler.

0.12.20+3 #

  • --pause-after-load no longer deadlocks with recent versions of Chrome.

  • Fix Dartified stack traces for JS-compiled tests run through pub serve.

0.12.20+2 #

  • Print "[E]" after test failures to make them easier to identify visually and via automated search.

0.12.20+1 #

  • Tighten the dependency on stream_channel to reflect the APIs being used.

  • Use a 1024 x 768 iframe for browser tests.

0.12.20 #

  • Breaking change: The expect() method no longer returns a Future, since this broke backwards-compatibility in cases where a void function was returning an expect() (such as void foo() => expect(...)). Instead, a new expectLater() function has been added that return a Future that completes when the matcher has finished running.

  • The verbose parameter to expect() and the formatFailure() function are deprecated.

0.12.19+1 #

  • Make sure asynchronous matchers that can fail synchronously, such as throws*() and prints(), can be used with synchronous matcher operators like isNot().

0.12.19 #

  • Added the StreamMatcher class, as well as several built-in stream matchers: emits(), emitsError(), emitsDone, mayEmit(), mayEmitMultiple(), emitsAnyOf(), emitsInOrder(), emitsInAnyOrder(), and neverEmits().

  • expect() now returns a Future for the asynchronous matchers completes, completion(), throws*(), and prints().

  • Add a printOnFailure() method for providing debugging information that's only printed when a test fails.

  • Automatically configure the term_glyph package to use ASCII glyphs when the test runner is running on Windows.

  • Deprecate the throws matcher in favor of throwsA().

  • Deprecate the Throws class. These matchers should only be constructed via throwsA().

0.12.18+1 #

  • Fix the deprecated expectAsync() function. The deprecation caused it to fail to support functions that take arguments.

0.12.18 #

  • Add an addTearDown() function, which allows tests to register additional tear-down callbacks as they're running.

  • Add the spawnHybridUri() and spawnHybridCode() functions, which allow browser tests to run code on the VM.

  • Fix the new expectAsync functions so that they don't produce analysis errors when passed callbacks with optional arguments.

0.12.17+3 #

  • Internal changes only.

0.12.17+2 #

  • Fix Dartium debugging on Windows.

0.12.17+1 #

  • Fix a bug where tags couldn't be marked as skipped.

0.12.17 #

  • Deprecate expectAsync and expectAsyncUntil, since they currently can't be made to work cleanly in strong mode. They are replaced with separate methods for each number of callback arguments:
    • expectAsync0, expectAsync1, ... expectAsync6, and
    • expectAsyncUntil0, expectAsyncUntil1, ... expectAsyncUntil6.

0.12.16 #

  • Allow tools to interact with browser debuggers using the JSON reporter.

0.12.15+12 #

  • Fix a race condition that could cause the runner to stall for up to three seconds after completing.

0.12.15+11 #

  • Make test iframes visible when debugging.

0.12.15+10 #

  • Throw a better error if a group body is asynchronous.

0.12.15+9 #

  • Widen version constraint on analyzer.

0.12.15+8 #

  • Make test suites with thousands of tests load much faster on the VM (and possibly other platforms).

0.12.15+7 #

  • Fix a bug where tags would be dropped when on_platform was defined in a config file.

0.12.15+6 #

  • Fix a broken link in the --help documentation.

0.12.15+5 #

  • Internal-only change.

0.12.15+4 #

  • Widen version constraint on analyzer.

0.12.15+3 #

  • Move nestingMiddleware to lib/src/util/path_handler.dart to enable a cleaner separation between test-runner files and test writing files.

0.12.15+2 #

  • Support running without a packages/ directory.

0.12.15+1 #

  • Declare support for version 1.19 of the Dart SDK.

0.12.15 #

  • Add a skip parameter to expect(). Marking a single expect as skipped will cause the test itself to be marked as skipped.

  • Add a --run-skipped parameter and run_skipped configuration field that cause tests to be run even if they're marked as skipped.

0.12.14+1 #

  • Narrow the constraint on yaml.

0.12.14 #

  • Add test and group location information to the JSON reporter.

0.12.13+5 #

  • Declare support for version 1.18 of the Dart SDK.

  • Use the latest collection package.

0.12.13+4 #

  • Compatibility with an upcoming release of the collection package.

0.12.13+3 #

  • Internal changes only.

0.12.13+2 #

  • Fix all strong-mode errors and warnings.

0.12.13+1 #

  • Declare support for version 1.17 of the Dart SDK.

0.12.13 #

  • Add support for a global configuration file. On Windows, this file defaults to %LOCALAPPDATA%\DartTest.yaml. On Unix, it defaults to ~/.dart_test.yaml. It can also be explicitly set using the DART_TEST_CONFIG environment variable. See the configuration documentation for details.

  • The --name and --plain-name arguments may be passed more than once, and may be passed together. A test must match all name constraints in order to be run.

  • Add names and plain_names fields to the package configuration file. These allow presets to control which tests are run based on their names.

  • Add include_tags and exclude_tags fields to the package configuration file. These allow presets to control which tests are run based on their tags.

  • Add a pause_after_load field to the package configuration file. This allows presets to enable debugging mode.

0.12.12 #

  • Add support for test presets. These are defined using the presets field in the package configuration file. They can be selected by passing --preset or -P, or by using the add_presets field in the package configuration file.

  • Add an on_os field to the package configuration file that allows users to select different configuration for different operating systems.

  • Add an on_platform field to the package configuration file that allows users to configure all tests differently depending on which platform they run on.

  • Add an ios platform selector variable. This variable will only be true when the test executable itself is running on iOS, not when it's running browser tests on an iOS browser.

0.12.11+2 #

  • Update to shelf_web_socket 0.2.0.

0.12.11+1 #

  • Purely internal change.

0.12.11 #

  • Add a tags field to the package configuration file that allows users to provide configuration for specific tags.

  • The --tags and --exclude-tags command-line flags now allow boolean selector syntax. For example, you can now pass --tags "(chrome || firefox) && !slow" to select quick Chrome or Firefox tests.

0.12.10+2 #

  • Re-add help output separators.

  • Tighten the constraint on args.

0.12.10+1 #

  • Temporarily remove separators from the help output. Version 0.12.8 was erroneously released without an appropriate args constraint for the features it used; this version will help ensure that users who can't use args 0.13.1 will get a working version of test.

0.12.10 #

  • Add support for a package-level configuration file called dart_test.yaml.

0.12.9 #

  • Add SuiteEvent to the JSON reporter, which reports data about the suites in which tests are run.

  • Add AllSuitesEvent to the JSON reporter, which reports the total number of suites that will be run.

  • Add Group.testCount to the JSON reporter, which reports the total number of tests in each group.

0.12.8 #

  • Organize the --help output into sections.

  • Add a --timeout flag.

0.12.7 #

  • Add the ability to re-run tests while debugging. When the browser is paused at a breakpoint, the test runner will open an interactive console on the command line that can be used to restart the test.

  • Add support for passing any object as a description to test() and group(). These objects will be converted to strings.

  • Add the ability to tag tests. Tests with specific tags may be run by passing the --tags command-line argument, or excluded by passing the --exclude-tags parameter.

    This feature is not yet complete. For now, tags are only intended to be added temporarily to enable use-cases like focusing on a specific test or group. Further development can be followed on the issue tracker.

  • Wait for a test's tear-down logic to run, even if it times out.

0.12.6+2 #

  • Declare compatibility with http_parser 2.0.0.

0.12.6+1 #

  • Declare compatibility with http_multi_server 2.0.0.

0.12.6 #

  • Add a machine-readable JSON reporter. For details, see the protocol documentation.

  • Skipped groups now properly print skip messages.

0.12.5+2 #

  • Declare compatibility with Dart 1.14 and 1.15.

0.12.5+1 #

  • Fixed a deadlock bug when using setUpAll() and tearDownAll().

0.12.5 #

  • Add setUpAll() and tearDownAll() methods that run callbacks before and after all tests in a group or suite. Note that these methods are for special cases and should be avoided—they make it very easy to accidentally introduce dependencies between tests. Use setUp() and tearDown() instead if possible.

  • Allow setUp() and tearDown() to be called multiple times within the same group.

  • When a tearDown() callback runs after a signal has been caught, it can now schedule out-of-band asynchronous callbacks normally rather than having them throw exceptions.

  • Don't show package warnings when compiling tests with dart2js. This was accidentally enabled in 0.12.2, but was never intended.

0.12.4+9 #

  • If a tearDown() callback throws an error, outer tearDown() callbacks are still executed.

0.12.4+8 #

  • Don't compile tests to JavaScript when running via pub serve on Dartium or content shell.

0.12.4+7 #

  • Support http_parser 1.0.0.

0.12.4+6 #

  • Fix a broken link in the README.

0.12.4+5 #

  • Internal changes only.

0.12.4+4 #

  • Widen the Dart SDK constraint to include 1.13.0.

0.12.4+3 #

  • Make source maps work properly in the browser when not using --pub-serve.

0.12.4+2 #

  • Fix a memory leak when running many browser tests where old test suites failed to be unloaded when they were supposed to.

0.12.4+1 #

  • Require Dart SDK >= 1.11.0 and shelf >= 0.6.0, allowing test to remove various hacks and workarounds.

0.12.4 #

  • Add a --pause-after-load flag that pauses the test runner after each suite is loaded so that breakpoints and other debugging annotations can be added. Currently this is only supported on browsers.

  • Add a Timeout.none value indicating that a test should never time out.

  • The dart-vm platform selector variable is now true for Dartium and content shell.

  • The compact reporter no longer prints status lines that only update the clock if they would get in the way of messages or errors from a test.

  • The expanded reporter no longer double-prints the descriptions of skipped tests.

0.12.3+9 #

  • Widen the constraint on analyzer to include 0.26.0.

0.12.3+8 #

  • Fix an uncaught error that could crop up when killing the test runner process at the wrong time.

0.12.3+7 #

  • Add a missing dependency on the collection package.

0.12.3+6 #

This version was unpublished due to issue 287.

  • Properly report load errors caused by failing to start browsers.

  • Substantially increase browser timeouts. These timeouts are the cause of a lot of flakiness, and now that they don't block test running there's less harm in making them longer.

0.12.3+5 #

This version was unpublished due to issue 287.

  • Fix a crash when skipping tests because their platforms don't match.

0.12.3+4 #

This version was unpublished due to issue 287.

  • The compact reporter will update the timer every second, rather than only updating it occasionally.

  • The compact reporter will now print the full, untruncated test name before any errors or prints emitted by a test.

  • The expanded reporter will now always print the full, untruncated test name.

0.12.3+3 #

This version was unpublished due to issue 287.

  • Limit the number of test suites loaded at once. This helps ensure that the test runner won't run out of memory when running many test suites that each load a large amount of code.

0.12.3+2 #

This version was unpublished due to issue 287.

  • Improve the display of syntax errors in VM tests.

  • Work around a Firefox bug. Computed styles now work in tests on Firefox.

  • Fix a bug where VM tests would be loaded from the wrong URLs on Windows (or in special circumstances on other operating systems).

0.12.3+1 #

  • Fix a bug that caused the test runner to crash on Windows because symlink resolution failed.

0.12.3 #

  • If a future matched against the completes or completion() matcher throws an error, that error is printed directly rather than being wrapped in a string. This allows such errors to be captured using the Zone API and improves formatting.

  • Improve support for Polymer tests. This fixes a flaky time-out error and adds support for Dartifying JavaScript stack traces when running Polymer tests via pub serve.

  • In order to be more extensible, all exception handling within tests now uses the Zone API.

  • Add a heartbeat to reset a test's timeout whenever the test interacts with the test infrastructure.

  • expect(), expectAsync(), and expectAsyncUntil() throw more useful errors if called outside a test body.

0.12.2 #

  • Convert JavaScript stack traces into Dart stack traces using source maps. This can be disabled with the new --js-trace flag.

  • Improve the browser test suite timeout logic to avoid timeouts when running many browser suites at once.

0.12.1 #

  • Add a --verbose-trace flag to include core library frames in stack traces.

0.12.0 #

Test Runner #

0.12.0 adds support for a test runner, which can be run via pub run test:test (or pub run test in Dart 1.10). By default it runs all files recursively in the test/ directory that end in _test.dart and aren't in a packages/ directory.

The test runner supports running tests on the Dart VM and many different browsers. Test files can use the @TestOn annotation to declare which platforms they support. For more information on this and many more new features, see the README.

Removed and Changed APIs #

As part of moving to a runner-based model, most test configuration is moving out of the test file and into the runner. As such, many ancillary APIs have been removed. These APIs include skip_ and solo_ functions, Configuration and all its subclasses, TestCase, TestFunction, testConfiguration, formatStacks, filterStacks, groupSep, logMessage, testCases, BREATH_INTERVAL, currentTestCase, PASS, FAIL, ERROR, filterTests, runTests, ensureInitialized, setSoloTest, enableTest, disableTest, and withTestEnvironment.

FailureHandler, DefaultFailureHandler, configureExpectFailureHandler, and getOrCreateExpectFailureHandler which used to be exported from the matcher package have also been removed. They existed to enable integration between test and matcher that has been streamlined.

A number of APIs from matcher have been into test, including: completes, completion, ErrorFormatter, expect,fail, prints, TestFailure, Throws, and all of the throws methods. Some of these have changed slightly:

  • expect no longer has a named failureHandler argument.

  • expect added an optional formatter argument.

  • completion argument id renamed to description.

0.11.6+4 #

  • Fix some strong mode warnings we missed in the vm_config.dart and html_config.dart libraries.

0.11.6+3 #

  • Fix a bug introduced in 0.11.6+2 in which operator matchers broke when taking lists of matchers.

0.11.6+2 #

  • Fix all strong mode warnings.

0.11.6+1 #

  • Give tests more time to start running.

0.11.6 #

  • Merge in the last 0.11.x release of matcher to allow projects to use both test and unittest without conflicts.

  • Fix running individual tests with HtmlIndividualConfiguration when the test name contains URI-escaped values and is provided with the group query parameter.

0.11.5+1 #

  • Internal code cleanups and documentation improvements.

0.11.5 #

  • Bumped the version constraint for matcher.

0.11.4 #

  • Bump the version constraint for matcher.

0.11.3 #

  • Narrow the constraint on matcher to ensure that new features are reflected in unittest's version.

0.11.2 #

  • Prints a warning instead of throwing an error when setting the test configuration after it has already been set. The first configuration is always used.

0.11.1+1 #

  • Fix bug in withTestEnvironment where test cases were not reinitialized if called multiple times.

0.11.1 #

  • Add reason named argument to expectAsync and expectAsyncUntil, which has the same definition as expect's reason argument.
  • Added support for private test environments.

0.11.0+6 #

  • Refactored package tests.

0.11.0+5 #

  • Release test functions after each test is run.

0.11.0+4 #

0.11.0+3 #

  • Updated maximum matcher version.

0.11.0+2 #

  • Removed unused files from tests and standardized remaining test file names.

0.11.0+1 #

  • Widen the version constraint for stack_trace.

0.11.0 #

  • Deprecated methods have been removed:
    • expectAsync0, expectAsync1, and expectAsync2 - use expectAsync instead
    • expectAsyncUntil0, expectAsyncUntil1, and expectAsyncUntil2 - use expectAsyncUntil instead
    • guardAsync - no longer needed
    • protectAsync0, protectAsync1, and protectAsync2 - no longer needed
  • matcher.dart and mirror_matchers.dart have been removed. They are now in the matcher package.
  • mock.dart has been removed. It is now in the mock package.

0.10.1+2 #

  • Fixed deprecation message for mock.

0.10.1+1 #

  • Moved to triple-slash for all doc comments.

0.10.1 #

    • matcher.dart and mirror_matchers.dart are now in the matcher package.
    • mock.dart is now in the mock package.
  • equals now allows a nested matcher as an expected list element or map value when doing deep matching.
  • expectAsync and expectAsyncUntil now support up to 6 positional arguments and correctly handle functions with optional positional arguments with default values.

0.10.0 #

  • Each test is run in a separate Zone. This ensures that any exceptions that occur is async operations are reported back to the source test case.
  • DEPRECATED guardAsync, protectAsync0, protectAsync1, and protectAsync2
    • Running each test in a Zone addresses the need for these methods.
  • NEW! expectAsync replaces the now deprecated expectAsync0, expectAsync1 and expectAsync2
  • NEW! expectAsyncUntil replaces the now deprecated expectAsyncUntil0, expectAsyncUntil1 and expectAsyncUntil2
  • TestCase:
    • Removed properties: setUp, tearDown, testFunction
    • enabled is now get-only
    • Removed methods: pass, fail, error
  • interactive_html_config.dart has been removed.
  • runTests, tearDown, setUp, test, group, solo_test, and solo_group now throw a StateError if called while tests are running.
  • rerunTests has been removed.

Use this package as a library

1. Depend on it

Add this to your package's pubspec.yaml file:

  test: ^1.15.2

2. Install it

You can install packages from the command line:

with pub:

$ pub get

with Flutter:

$ flutter pub get

Alternatively, your editor might support pub get or flutter pub get. Check the docs for your editor to learn more.

3. Import it

Now in your Dart code, you can use:

import 'package:test/test.dart';
Describes how popular the package is relative to other packages. [more]
Code health derived from static analysis. [more]
Reflects how tidy and up-to-date the package is. [more]
Weighted score of the above. [more]
Learn more about scoring.

We analyzed this package on Jul 9, 2020, and provided a score, details, and suggestions below. Analysis was completed with status completed using:

  • Dart: 2.8.4
  • pana: 0.13.14

Maintenance suggestions

Maintain an example. (-10 points)

Create a short demo in the example/ directory to show how to use this package.

Common filename patterns include main.dart, example.dart, and test.dart. Packages with multiple examples should provide example/README.md.

For more information see the pub package layout conventions.

The package description is too short. (-1 points)

Add more detail to the description field of pubspec.yaml. Use 60 to 180 characters to describe the package, what it does, and its target use case.


Package Constraint Resolved Available
Direct dependencies
Dart SDK >=2.7.0 <3.0.0
analyzer >=0.36.0 <0.40.0 0.39.12
async ^2.0.0 2.4.2
boolean_selector >=1.0.0 <3.0.0 2.0.0
coverage >=0.13.4 <0.15.0 0.14.0
http ^0.12.0 0.12.1
http_multi_server ^2.0.0 2.2.0
io ^0.3.0 0.3.4
js ^0.6.0 0.6.2
node_preamble ^1.3.0 1.4.12
package_config ^1.9.0 1.9.3
path ^1.2.0 1.7.0
pedantic ^1.1.0 1.9.2
pool ^1.3.0 1.4.0
shelf ^0.7.0 0.7.7
shelf_packages_handler >=1.0.0 <3.0.0 2.0.0
shelf_static ^0.2.6 0.2.8
shelf_web_socket ^0.2.0 0.2.3
source_span ^1.4.0 1.7.0
stack_trace ^1.9.0 1.9.5
stream_channel >=1.7.0 <3.0.0 2.0.0
test_api 0.2.17 0.2.17
test_core 0.3.10 0.3.10
typed_data ^1.0.0 1.2.0 1.3.0-nullsafety
web_socket_channel ^1.0.0 1.1.0
webkit_inspection_protocol >=0.5.0 <0.8.0 0.7.3
yaml ^2.0.0 2.2.1
Transitive dependencies
_fe_analyzer_shared 5.0.0
args 1.6.0
charcode 1.1.3
collection 1.14.13 1.15.0-nullsafety
convert 2.1.1
crypto 2.1.5
csslib 0.16.1
glob 1.2.0
html 0.14.0+3
http_parser 3.1.4
logging 0.11.4
matcher 0.12.8
meta 1.2.2 1.3.0-nullsafety
mime 0.9.6+3
node_interop 1.1.1
node_io 1.1.1
pub_semver 1.4.4
source_map_stack_trace 2.0.0
source_maps 0.10.9
string_scanner 1.0.5
term_glyph 1.1.0
vm_service 4.1.0
watcher 0.9.7+15
Dev dependencies
fake_async ^1.0.0
shelf_test_handler ^1.0.0
test_descriptor ^1.0.0
test_process ^1.0.0