blob: 7cb77ae4e14ea2b6c8b289782d3770ce34fa9441 [file] [log] [blame]
// Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
import 'dart:io';
/// This file is the entrypoint of the Dart repository's custom test system.
/// It is used to test:
///
/// 1. The Dart VM
/// 2. The dart2js compiler
/// 3. The static analyzer
/// 4. The Dart core library
/// 5. Other standard dart libraries (DOM bindings, UI libraries,
/// IO libraries etc.)
/// 6. The Dart specification parser.
///
/// This script is normally invoked by test.py. (test.py finds the Dart VM and
/// passes along all command line arguments to this script.)
///
/// The command line args of this script are documented in "test_options.dart".
/// They are printed when this script is run with "--help".
///
/// The default test directory layout is documented in "test_suite.dart", above
/// `factory StandardTestSuite.forDirectory`.
import "package:test_runner/src/options.dart";
import "package:test_runner/src/build_configurations.dart";
import "package:test_runner/src/test_configurations.dart";
/// Runs all of the tests specified by the given command line [arguments].
void main(List<String> arguments) async {
// Parse the command line arguments to a configuration.
var parser = OptionsParser();
var configurations = <TestConfiguration>[];
try {
configurations = parser.parse(arguments);
} on OptionParseException catch (exception) {
print(exception.message);
exit(1);
}
if (configurations.isEmpty) return;
await buildConfigurations(configurations);
// Run all of the configured tests.
await testConfigurations(configurations);
}