Index: sdk/lib/_internal/pub/test/run/displays_transformer_logs_test.dart |
diff --git a/sdk/lib/_internal/pub/test/run/displays_transformer_logs_test.dart b/sdk/lib/_internal/pub/test/run/displays_transformer_logs_test.dart |
new file mode 100644 |
index 0000000000000000000000000000000000000000..d47b9501fa52248b026f38fa236a50aa56189116 |
--- /dev/null |
+++ b/sdk/lib/_internal/pub/test/run/displays_transformer_logs_test.dart |
@@ -0,0 +1,94 @@ |
+// Copyright (c) 2014, 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 'package:scheduled_test/scheduled_test.dart'; |
+ |
+import '../descriptor.dart' as d; |
+import '../test_pub.dart'; |
+import 'utils.dart'; |
+ |
+const SCRIPT = """ |
+import "package:myapp/lib.dart"; |
+main() { |
+ callLib(); |
+} |
+"""; |
+ |
+const LIB = """ |
+callLib() { |
+ print("lib"); |
+} |
+"""; |
+ |
+// Make it lazy so that "lib.dart" isn't transformed until after the process |
+// is started. Otherwise, since this tranformer modifies .dart files, it will |
+// be run while the transformers themselves are loading during pub run's |
+// startup. |
+const TRANSFORMER = """ |
+import 'dart:async'; |
+ |
+import 'package:barback/barback.dart'; |
+ |
+class LoggingTransformer extends Transformer implements LazyTransformer { |
+ LoggingTransformer.asPlugin(); |
+ |
+ String get allowedExtensions => '.dart'; |
+ |
+ void apply(Transform transform) { |
+ transform.logger.info('\${transform.primaryInput.id}.'); |
+ transform.logger.warning('\${transform.primaryInput.id}.'); |
+ } |
+ |
+ void declareOutputs(DeclaringTransform transform) { |
+ // TODO(rnystrom): Remove this when #19408 is fixed. |
+ transform.declareOutput(transform.primaryId); |
+ } |
+} |
+"""; |
+ |
+main() { |
+ initConfig(); |
+ withBarbackVersions("any", () { |
+ integration('displays transformer log messages', () { |
+ d.dir(appPath, [ |
+ d.pubspec({ |
+ "name": "myapp", |
+ "transformers": ["myapp/src/transformer"] |
+ }), |
+ d.dir("lib", [ |
+ d.file("lib.dart", LIB), |
+ d.dir("src", [ |
+ d.file("transformer.dart", TRANSFORMER) |
+ ]) |
+ ]), |
+ d.dir("bin", [ |
+ d.file("script.dart", SCRIPT) |
+ ]) |
+ ]).create(); |
+ |
+ createLockFile('myapp', pkg: ['barback']); |
+ |
+ var pub = pubRun(args: ["script"], |
+ transformers: ["myapp/src/transformer"]); |
+ |
+ // Note that the info log is only displayed here because the test |
+ // harness runs pub in verbose mode. By default, only the warning would |
+ // be shown. |
+ pub.stdout.expect("[Info from Logging]:"); |
+ pub.stdout.expect("myapp|bin/script.dart."); |
+ |
+ pub.stderr.expect("[Warning from Logging]:"); |
+ pub.stderr.expect("myapp|bin/script.dart."); |
+ |
+ pub.stdout.expect("[Info from Logging]:"); |
+ pub.stdout.expect("myapp|lib/lib.dart."); |
+ |
+ pub.stderr.expect("[Warning from Logging]:"); |
+ pub.stderr.expect("myapp|lib/lib.dart."); |
+ |
+ pub.stdout.expect("lib"); |
+ pub.shouldExit(); |
+ }); |
+ }); |
+} |