OLD | NEW |
1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file | |
2 // for details. All rights reserved. Use of this source code is governed by a | |
3 // BSD-style license that can be found in the LICENSE file. | |
4 | |
5 import '../descriptor.dart' as d; | 1 import '../descriptor.dart' as d; |
6 import '../test_pub.dart'; | 2 import '../test_pub.dart'; |
7 | |
8 const SCRIPT = """ | 3 const SCRIPT = """ |
9 import "package:myapp/lib.dart"; | 4 import "package:myapp/lib.dart"; |
10 main() { | 5 main() { |
11 callLib(); | 6 callLib(); |
12 } | 7 } |
13 """; | 8 """; |
14 | |
15 const LIB = """ | 9 const LIB = """ |
16 callLib() { | 10 callLib() { |
17 print("lib"); | 11 print("lib"); |
18 } | 12 } |
19 """; | 13 """; |
20 | |
21 // Make it lazy so that "lib.dart" isn't transformed until after the process | |
22 // is started. Otherwise, since this tranformer modifies .dart files, it will | |
23 // be run while the transformers themselves are loading during pub run's | |
24 // startup. | |
25 const TRANSFORMER = """ | 14 const TRANSFORMER = """ |
26 import 'dart:async'; | 15 import 'dart:async'; |
27 | 16 |
28 import 'package:barback/barback.dart'; | 17 import 'package:barback/barback.dart'; |
29 | 18 |
30 class LoggingTransformer extends Transformer implements LazyTransformer { | 19 class LoggingTransformer extends Transformer implements LazyTransformer { |
31 LoggingTransformer.asPlugin(); | 20 LoggingTransformer.asPlugin(); |
32 | 21 |
33 String get allowedExtensions => '.dart'; | 22 String get allowedExtensions => '.dart'; |
34 | 23 |
35 void apply(Transform transform) { | 24 void apply(Transform transform) { |
36 transform.logger.info('\${transform.primaryInput.id}.'); | 25 transform.logger.info('\${transform.primaryInput.id}.'); |
37 transform.logger.warning('\${transform.primaryInput.id}.'); | 26 transform.logger.warning('\${transform.primaryInput.id}.'); |
38 } | 27 } |
39 | 28 |
40 void declareOutputs(DeclaringTransform transform) { | 29 void declareOutputs(DeclaringTransform transform) { |
41 // TODO(rnystrom): Remove this when #19408 is fixed. | 30 // TODO(rnystrom): Remove this when #19408 is fixed. |
42 transform.declareOutput(transform.primaryId); | 31 transform.declareOutput(transform.primaryId); |
43 } | 32 } |
44 } | 33 } |
45 """; | 34 """; |
46 | |
47 main() { | 35 main() { |
48 initConfig(); | 36 initConfig(); |
49 withBarbackVersions("any", () { | 37 withBarbackVersions("any", () { |
50 integration('displays transformer log messages', () { | 38 integration('displays transformer log messages', () { |
51 d.dir(appPath, [ | 39 d.dir(appPath, [d.pubspec({ |
52 d.pubspec({ | |
53 "name": "myapp", | 40 "name": "myapp", |
54 "transformers": ["myapp/src/transformer"] | 41 "transformers": ["myapp/src/transformer"] |
55 }), | 42 }), |
56 d.dir("lib", [ | 43 d.dir( |
57 d.file("lib.dart", LIB), | 44 "lib", |
58 d.dir("src", [ | 45 [ |
59 d.file("transformer.dart", TRANSFORMER) | 46 d.file("lib.dart", LIB), |
60 ]) | 47 d.dir("src", [d.file("transformer.dart", TRANSFORMER)])]), |
61 ]), | 48 d.dir("bin", [d.file("script.dart", SCRIPT)])]).create(); |
62 d.dir("bin", [ | |
63 d.file("script.dart", SCRIPT) | |
64 ]) | |
65 ]).create(); | |
66 | |
67 createLockFile('myapp', pkg: ['barback']); | 49 createLockFile('myapp', pkg: ['barback']); |
68 | |
69 var pub = pubRun(args: ["script"]); | 50 var pub = pubRun(args: ["script"]); |
70 | |
71 // Note that the info log is only displayed here because the test | |
72 // harness runs pub in verbose mode. By default, only the warning would | |
73 // be shown. | |
74 pub.stdout.expect("[Info from Logging]:"); | 51 pub.stdout.expect("[Info from Logging]:"); |
75 pub.stdout.expect("myapp|bin/script.dart."); | 52 pub.stdout.expect("myapp|bin/script.dart."); |
76 | |
77 pub.stderr.expect("[Warning from Logging]:"); | 53 pub.stderr.expect("[Warning from Logging]:"); |
78 pub.stderr.expect("myapp|bin/script.dart."); | 54 pub.stderr.expect("myapp|bin/script.dart."); |
79 | |
80 pub.stdout.expect("[Info from Logging]:"); | 55 pub.stdout.expect("[Info from Logging]:"); |
81 pub.stdout.expect("myapp|lib/lib.dart."); | 56 pub.stdout.expect("myapp|lib/lib.dart."); |
82 | |
83 pub.stderr.expect("[Warning from Logging]:"); | 57 pub.stderr.expect("[Warning from Logging]:"); |
84 pub.stderr.expect("myapp|lib/lib.dart."); | 58 pub.stderr.expect("myapp|lib/lib.dart."); |
85 | |
86 pub.stdout.expect("lib"); | 59 pub.stdout.expect("lib"); |
87 pub.shouldExit(); | 60 pub.shouldExit(); |
88 }); | 61 }); |
89 }); | 62 }); |
90 } | 63 } |
OLD | NEW |