Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1732)

Unified Diff: test/runner/test_on_test.dart

Issue 1027193004: Respect top-level @TestOn declarations. (Closed) Base URL: git@github.com:dart-lang/unittest@master
Patch Set: Add another test. Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« lib/src/frontend/test_on.dart ('K') | « test/runner/runner_test.dart ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: test/runner/test_on_test.dart
diff --git a/test/runner/test_on_test.dart b/test/runner/test_on_test.dart
new file mode 100644
index 0000000000000000000000000000000000000000..547f758cf5bcd388c67115e22a7bed5920d919fc
--- /dev/null
+++ b/test/runner/test_on_test.dart
@@ -0,0 +1,118 @@
+// Copyright (c) 2015, 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.
+
+@TestOn("vm")
+
+import 'dart:io';
+
+import 'package:path/path.dart' as p;
+import 'package:unittest/src/util/io.dart';
+import 'package:unittest/unittest.dart';
+
+import '../io.dart';
+
+String _sandbox;
+
+final _vm = """
+@TestOn("vm")
+
+import 'package:unittest/unittest.dart';
+
+void main() {
+ test("success", () {});
+}
+""";
+
+final _chrome = """
+@TestOn("chrome")
+
+// Make sure that loading this test file on the VM will break.
+import 'dart:html';
+
+import 'package:unittest/unittest.dart';
+
+void main() {
+ test("success", () {});
+}
+""";
+
+final _thisOS = """
+@TestOn("$currentOS")
+
+import 'package:unittest/unittest.dart';
+
+void main() {
+ test("success", () {});
+}
+""";
+
+final _otherOS = """
+@TestOn("${Platform.isWindows ? "mac-os" : "windows"}")
+
+// Make sure that loading this test file on the VM will break.
+import 'dart:html';
+
+import 'package:unittest/unittest.dart';
+
+void main() {
+ test("success", () {});
+}
+""";
+
+void main() {
+ setUp(() {
+ _sandbox = Directory.systemTemp.createTempSync('unittest_').path;
+ });
+
+ tearDown(() {
+ new Directory(_sandbox).deleteSync(recursive: true);
+ });
+
+ test("runs a test suite on a matching platform", () {
+ new File(p.join(_sandbox, "vm_test.dart")).writeAsStringSync(_vm);
+
+ var result = _runUnittest(["vm_test.dart"]);
+ expect(result.stdout, contains("All tests passed!"));
+ expect(result.exitCode, equals(0));
+ });
+
+ test("doesn't run a test suite on a non-matching platform", () {
+ new File(p.join(_sandbox, "vm_test.dart")).writeAsStringSync(_vm);
+
+ var result = _runUnittest(["--platform", "chrome", "vm_test.dart"]);
+ expect(result.stdout, contains("No tests ran."));
+ expect(result.exitCode, equals(0));
+ });
+
+ test("runs a test suite on a matching operating system", () {
+ new File(p.join(_sandbox, "os_test.dart")).writeAsStringSync(_thisOS);
+
+ var result = _runUnittest(["os_test.dart"]);
+ expect(result.stdout, contains("All tests passed!"));
+ expect(result.exitCode, equals(0));
+ });
+
+ test("doesn't run a test suite on a non-matching operating system", () {
+ new File(p.join(_sandbox, "os_test.dart")).writeAsStringSync(_otherOS);
+
+ var result = _runUnittest(["os_test.dart"]);
+ expect(result.stdout, contains("No tests ran."));
+ expect(result.exitCode, equals(0));
+ });
+
+ test("only loads matching files when loading as a group", () {
+ new File(p.join(_sandbox, "vm_test.dart")).writeAsStringSync(_vm);
+ new File(p.join(_sandbox, "chrome_test.dart")).writeAsStringSync(_chrome);
+ new File(p.join(_sandbox, "this_os_test.dart")).writeAsStringSync(_thisOS);
+ new File(p.join(_sandbox, "other_os_test.dart"))
+ .writeAsStringSync(_otherOS);
+
+ var result = _runUnittest(["."]);
+ expect(result.stdout, contains("+2: All tests passed!"));
+ expect(result.exitCode, equals(0));
+ });
+}
+
+ProcessResult _runUnittest(List<String> args) =>
+ runUnittest(args, workingDirectory: _sandbox);
« lib/src/frontend/test_on.dart ('K') | « test/runner/runner_test.dart ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698